@mlightcad/data-model 1.7.27 → 1.7.29

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 (87) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +224 -224
  3. package/dist/data-model.cjs +4 -3
  4. package/dist/data-model.js +6601 -3480
  5. package/dist/dxf-parser-worker.js +1023 -740
  6. package/lib/converter/AcDbDxfConverter.d.ts +1 -0
  7. package/lib/converter/AcDbDxfConverter.d.ts.map +1 -1
  8. package/lib/converter/AcDbDxfConverter.js +48 -1
  9. package/lib/converter/AcDbDxfConverter.js.map +1 -1
  10. package/lib/converter/AcDbEntitiyConverter.d.ts +12 -0
  11. package/lib/converter/AcDbEntitiyConverter.d.ts.map +1 -1
  12. package/lib/converter/AcDbEntitiyConverter.js +528 -3
  13. package/lib/converter/AcDbEntitiyConverter.js.map +1 -1
  14. package/lib/converter/AcDbObjectConverter.d.ts +10 -3
  15. package/lib/converter/AcDbObjectConverter.d.ts.map +1 -1
  16. package/lib/converter/AcDbObjectConverter.js +173 -1
  17. package/lib/converter/AcDbObjectConverter.js.map +1 -1
  18. package/lib/converter/AcDbRegenerator.d.ts.map +1 -1
  19. package/lib/converter/AcDbRegenerator.js +22 -4
  20. package/lib/converter/AcDbRegenerator.js.map +1 -1
  21. package/lib/database/AcDbBlockTableRecord.d.ts.map +1 -1
  22. package/lib/database/AcDbBlockTableRecord.js +1 -0
  23. package/lib/database/AcDbBlockTableRecord.js.map +1 -1
  24. package/lib/database/AcDbDatabase.d.ts +42 -0
  25. package/lib/database/AcDbDatabase.d.ts.map +1 -1
  26. package/lib/database/AcDbDatabase.js +250 -32
  27. package/lib/database/AcDbDatabase.js.map +1 -1
  28. package/lib/database/AcDbSysVarManager.d.ts.map +1 -1
  29. package/lib/database/AcDbSysVarManager.js +28 -1
  30. package/lib/database/AcDbSysVarManager.js.map +1 -1
  31. package/lib/database/AcDbSystemVariables.d.ts +7 -1
  32. package/lib/database/AcDbSystemVariables.d.ts.map +1 -1
  33. package/lib/database/AcDbSystemVariables.js +6 -0
  34. package/lib/database/AcDbSystemVariables.js.map +1 -1
  35. package/lib/entity/AcDbLeader.d.ts +32 -3
  36. package/lib/entity/AcDbLeader.d.ts.map +1 -1
  37. package/lib/entity/AcDbLeader.js +140 -10
  38. package/lib/entity/AcDbLeader.js.map +1 -1
  39. package/lib/entity/AcDbMLeader.d.ts +1092 -0
  40. package/lib/entity/AcDbMLeader.d.ts.map +1 -0
  41. package/lib/entity/AcDbMLeader.js +2553 -0
  42. package/lib/entity/AcDbMLeader.js.map +1 -0
  43. package/lib/entity/AcDbMLine.d.ts +670 -0
  44. package/lib/entity/AcDbMLine.d.ts.map +1 -0
  45. package/lib/entity/AcDbMLine.js +1510 -0
  46. package/lib/entity/AcDbMLine.js.map +1 -0
  47. package/lib/entity/dimension/AcDbDiametricDimension.d.ts +0 -33
  48. package/lib/entity/dimension/AcDbDiametricDimension.d.ts.map +1 -1
  49. package/lib/entity/dimension/AcDbDiametricDimension.js +0 -80
  50. package/lib/entity/dimension/AcDbDiametricDimension.js.map +1 -1
  51. package/lib/entity/dimension/AcDbDimension.d.ts +1 -9
  52. package/lib/entity/dimension/AcDbDimension.d.ts.map +1 -1
  53. package/lib/entity/dimension/AcDbDimension.js +0 -10
  54. package/lib/entity/dimension/AcDbDimension.js.map +1 -1
  55. package/lib/entity/dimension/AcDbRadialDimension.d.ts +0 -6
  56. package/lib/entity/dimension/AcDbRadialDimension.d.ts.map +1 -1
  57. package/lib/entity/dimension/AcDbRadialDimension.js +0 -8
  58. package/lib/entity/dimension/AcDbRadialDimension.js.map +1 -1
  59. package/lib/entity/index.d.ts +2 -0
  60. package/lib/entity/index.d.ts.map +1 -1
  61. package/lib/entity/index.js +2 -0
  62. package/lib/entity/index.js.map +1 -1
  63. package/lib/misc/AcDbConstants.d.ts +14 -0
  64. package/lib/misc/AcDbConstants.d.ts.map +1 -1
  65. package/lib/misc/AcDbConstants.js +14 -0
  66. package/lib/misc/AcDbConstants.js.map +1 -1
  67. package/lib/misc/AcDbMLeaderStyleColorCodec.d.ts +59 -0
  68. package/lib/misc/AcDbMLeaderStyleColorCodec.d.ts.map +1 -0
  69. package/lib/misc/AcDbMLeaderStyleColorCodec.js +101 -0
  70. package/lib/misc/AcDbMLeaderStyleColorCodec.js.map +1 -0
  71. package/lib/misc/index.d.ts +1 -0
  72. package/lib/misc/index.d.ts.map +1 -1
  73. package/lib/misc/index.js +1 -0
  74. package/lib/misc/index.js.map +1 -1
  75. package/lib/object/AcDbMLeaderStyle.d.ts +405 -0
  76. package/lib/object/AcDbMLeaderStyle.d.ts.map +1 -0
  77. package/lib/object/AcDbMLeaderStyle.js +1006 -0
  78. package/lib/object/AcDbMLeaderStyle.js.map +1 -0
  79. package/lib/object/AcDbMlineStyle.d.ts +58 -0
  80. package/lib/object/AcDbMlineStyle.d.ts.map +1 -0
  81. package/lib/object/AcDbMlineStyle.js +158 -0
  82. package/lib/object/AcDbMlineStyle.js.map +1 -0
  83. package/lib/object/index.d.ts +2 -0
  84. package/lib/object/index.d.ts.map +1 -1
  85. package/lib/object/index.js +2 -0
  86. package/lib/object/index.js.map +1 -1
  87. package/package.json +5 -5
@@ -1,4 +1,5 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var Fn=(i=>(i[i.Invalid=-9999]="Invalid",i[i.Start=0]="Start",i[i.Text=1]="Text",i[i.AttributeTag=2]="AttributeTag",i[i.BlockName=2]="BlockName",i[i.ShapeName=2]="ShapeName",i[i.SymbolTableName=2]="SymbolTableName",i[i.SymbolTableRecordName=2]="SymbolTableRecordName",i[i.MlineStyleName=2]="MlineStyleName",i[i.AttributePrompt=3]="AttributePrompt",i[i.Description=3]="Description",i[i.DimPostString=3]="DimPostString",i[i.DimStyleName=3]="DimStyleName",i[i.LinetypeProse=3]="LinetypeProse",i[i.TextFontFile=3]="TextFontFile",i[i.CLShapeName=4]="CLShapeName",i[i.DimensionAlternativePrefixSuffix=4]="DimensionAlternativePrefixSuffix",i[i.SymbolTableRecordComments=4]="SymbolTableRecordComments",i[i.TextBigFontFile=4]="TextBigFontFile",i[i.Handle=5]="Handle",i[i.DimensionBlock=5]="DimensionBlock",i[i.LinetypeName=6]="LinetypeName",i[i.DimBlk1=6]="DimBlk1",i[i.TextStyleName=7]="TextStyleName",i[i.DimBlk2=7]="DimBlk2",i[i.LayerName=8]="LayerName",i[i.CLShapeText=9]="CLShapeText",i[i.XCoordinate=10]="XCoordinate",i[i.YCoordinate=20]="YCoordinate",i[i.ZCoordinate=30]="ZCoordinate",i[i.Real=40]="Real",i[i.TxtSize=40]="TxtSize",i[i.ViewportHeight=40]="ViewportHeight",i[i.Angle=50]="Angle",i[i.ViewportSnapAngle=50]="ViewportSnapAngle",i[i.Visibility=60]="Visibility",i[i.Int16=70]="Int16",i[i.Int32=90]="Int32",i[i.Int64=160]="Int64",i[i.Int8=280]="Int8",i[i.Thickness=39]="Thickness",i[i.Elevation=38]="Elevation",i[i.LinetypeScale=48]="LinetypeScale",i[i.DashLength=49]="DashLength",i[i.MlineOffset=49]="MlineOffset",i[i.LinetypeElement=49]="LinetypeElement",i[i.NormalX=210]="NormalX",i[i.NormalY=220]="NormalY",i[i.NormalZ=230]="NormalZ",i[i.UcsOrg=110]="UcsOrg",i[i.UcsOrientationX=111]="UcsOrientationX",i[i.UcsOrientationY=112]="UcsOrientationY",i[i.ViewHeight=45]="ViewHeight",i[i.ViewWidth=41]="ViewWidth",i[i.ViewLensLength=42]="ViewLensLength",i[i.ViewFrontClip=43]="ViewFrontClip",i[i.ViewBackClip=44]="ViewBackClip",i[i.ViewBrightness=141]="ViewBrightness",i[i.ViewContrast=142]="ViewContrast",i[i.ViewMode=71]="ViewMode",i[i.ViewportActive=68]="ViewportActive",i[i.ViewportAspect=41]="ViewportAspect",i[i.ViewportGrid=76]="ViewportGrid",i[i.ViewportIcon=74]="ViewportIcon",i[i.ViewportNumber=69]="ViewportNumber",i[i.ViewportSnap=75]="ViewportSnap",i[i.ViewportSnapPair=78]="ViewportSnapPair",i[i.ViewportSnapStyle=77]="ViewportSnapStyle",i[i.ViewportTwist=51]="ViewportTwist",i[i.ViewportVisibility=67]="ViewportVisibility",i[i.ViewportZoom=73]="ViewportZoom",i[i.Color=62]="Color",i[i.ColorRgb=420]="ColorRgb",i[i.ColorName=430]="ColorName",i[i.LineWeight=370]="LineWeight",i[i.PlotStyleNameType=380]="PlotStyleNameType",i[i.PlotStyleNameId=390]="PlotStyleNameId",i[i.GradientObjType=450]="GradientObjType",i[i.GradientAngle=460]="GradientAngle",i[i.GradientName=470]="GradientName",i[i.GradientColCount=453]="GradientColCount",i[i.GradientPatType=451]="GradientPatType",i[i.GradientTintType=452]="GradientTintType",i[i.GradientShift=461]="GradientShift",i[i.GradientColVal=463]="GradientColVal",i[i.GradientTintVal=462]="GradientTintVal",i[i.SoftPointerId=330]="SoftPointerId",i[i.HardPointerId=340]="HardPointerId",i[i.SoftOwnershipId=350]="SoftOwnershipId",i[i.HardOwnershipId=360]="HardOwnershipId",i[i.ArbitraryHandle=320]="ArbitraryHandle",i[i.ExtendedDataAsciiString=1e3]="ExtendedDataAsciiString",i[i.ExtendedDataRegAppName=1001]="ExtendedDataRegAppName",i[i.ExtendedDataControlString=1002]="ExtendedDataControlString",i[i.ExtendedDataLayerName=1003]="ExtendedDataLayerName",i[i.ExtendedDataBinaryChunk=1004]="ExtendedDataBinaryChunk",i[i.ExtendedDataHandle=1005]="ExtendedDataHandle",i[i.ExtendedDataXCoordinate=1010]="ExtendedDataXCoordinate",i[i.ExtendedDataWorldXCoordinate=1011]="ExtendedDataWorldXCoordinate",i[i.ExtendedDataWorldXDisp=1012]="ExtendedDataWorldXDisp",i[i.ExtendedDataWorldXDir=1013]="ExtendedDataWorldXDir",i[i.ExtendedDataYCoordinate=1020]="ExtendedDataYCoordinate",i[i.ExtendedDataWorldYCoordinate=1021]="ExtendedDataWorldYCoordinate",i[i.ExtendedDataWorldYDisp=1022]="ExtendedDataWorldYDisp",i[i.ExtendedDataWorldYDir=1023]="ExtendedDataWorldYDir",i[i.ExtendedDataZCoordinate=1030]="ExtendedDataZCoordinate",i[i.ExtendedDataWorldZCoordinate=1031]="ExtendedDataWorldZCoordinate",i[i.ExtendedDataWorldZDisp=1032]="ExtendedDataWorldZDisp",i[i.ExtendedDataWorldZDir=1033]="ExtendedDataWorldZDir",i[i.ExtendedDataReal=1040]="ExtendedDataReal",i[i.ExtendedDataDist=1041]="ExtendedDataDist",i[i.ExtendedDataScale=1042]="ExtendedDataScale",i[i.ExtendedDataInteger16=1070]="ExtendedDataInteger16",i[i.ExtendedDataInteger32=1071]="ExtendedDataInteger32",i[i.XTextString=300]="XTextString",i[i.XReal=140]="XReal",i[i.XInt16=170]="XInt16",i[i.XXInt16=270]="XXInt16",i[i.Subclass=100]="Subclass",i[i.ControlString=102]="ControlString",i[i.EmbeddedObjectStart=101]="EmbeddedObjectStart",i[i.End=-1]="End",i[i.FirstEntityId=-2]="FirstEntityId",i[i.HeaderId=-2]="HeaderId",i[i.XDataStart=-3]="XDataStart",i[i.Operator=-4]="Operator",i[i.PReactors=-5]="PReactors",i[i.XDictionary=-6]="XDictionary",i))(Fn||{});const qr=[{name:"AC1.2",value:1},{name:"AC1.40",value:2},{name:"AC1.50",value:3},{name:"AC2.20",value:4},{name:"AC2.10",value:5},{name:"AC2.21",value:6},{name:"AC2.22",value:7},{name:"AC1001",value:8},{name:"AC1002",value:9},{name:"AC1003",value:10},{name:"AC1004",value:11},{name:"AC1005",value:12},{name:"AC1006",value:13},{name:"AC1007",value:14},{name:"AC1008",value:15},{name:"AC1009",value:16},{name:"AC1010",value:17},{name:"AC1011",value:18},{name:"AC1012",value:19},{name:"AC1013",value:20},{name:"AC1014",value:21},{name:"AC1500",value:22},{name:"AC1015",value:23},{name:"AC1800a",value:24},{name:"AC1018",value:25},{name:"AC2100a",value:26},{name:"AC1021",value:27},{name:"AC2400a",value:28},{name:"AC1024",value:29},{name:"AC1027",value:31},{name:"AC3200a",value:32},{name:"AC1032",value:33}];class vt{constructor(t){if(typeof t=="string"){const e=qr.find(s=>s.name===t);if(!e)throw new Error(`Unknown DWG version name: ${t}`);this.name=e.name,this.value=e.value;return}if(typeof t=="number"){const e=qr.find(s=>s.value===t);if(!e)throw new Error(`Unknown DWG version value: ${t}`);this.name=e.name,this.value=e.value;return}throw new Error("Invalid constructor argument for AcDbDwgVersion")}}class ba{constructor(t={}){this._database=t.database,this._precision=Math.max(0,Math.min(16,t.precision??16)),this._version=t.version instanceof vt?t.version:t.version!=null?new vt(t.version):void 0,this._lines=[],this._handleMap=new Map,this._nextHandle=1}get database(){return this._database}set database(t){this._database=t}get precision(){return this._precision}setPrecision(t){return this._precision=Math.max(0,Math.min(16,t)),this}get version(){return this._version}get nextHandle(){return this._nextHandle}setVersion(t){return this._version=t instanceof vt?t:new vt(t),this}toString(){return this._lines.join(`
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var Qn=(i=>(i[i.Invalid=-9999]="Invalid",i[i.Start=0]="Start",i[i.Text=1]="Text",i[i.AttributeTag=2]="AttributeTag",i[i.BlockName=2]="BlockName",i[i.ShapeName=2]="ShapeName",i[i.SymbolTableName=2]="SymbolTableName",i[i.SymbolTableRecordName=2]="SymbolTableRecordName",i[i.MlineStyleName=2]="MlineStyleName",i[i.AttributePrompt=3]="AttributePrompt",i[i.Description=3]="Description",i[i.DimPostString=3]="DimPostString",i[i.DimStyleName=3]="DimStyleName",i[i.LinetypeProse=3]="LinetypeProse",i[i.TextFontFile=3]="TextFontFile",i[i.CLShapeName=4]="CLShapeName",i[i.DimensionAlternativePrefixSuffix=4]="DimensionAlternativePrefixSuffix",i[i.SymbolTableRecordComments=4]="SymbolTableRecordComments",i[i.TextBigFontFile=4]="TextBigFontFile",i[i.Handle=5]="Handle",i[i.DimensionBlock=5]="DimensionBlock",i[i.LinetypeName=6]="LinetypeName",i[i.DimBlk1=6]="DimBlk1",i[i.TextStyleName=7]="TextStyleName",i[i.DimBlk2=7]="DimBlk2",i[i.LayerName=8]="LayerName",i[i.CLShapeText=9]="CLShapeText",i[i.XCoordinate=10]="XCoordinate",i[i.YCoordinate=20]="YCoordinate",i[i.ZCoordinate=30]="ZCoordinate",i[i.Real=40]="Real",i[i.TxtSize=40]="TxtSize",i[i.ViewportHeight=40]="ViewportHeight",i[i.Angle=50]="Angle",i[i.ViewportSnapAngle=50]="ViewportSnapAngle",i[i.Visibility=60]="Visibility",i[i.Int16=70]="Int16",i[i.Int32=90]="Int32",i[i.Int64=160]="Int64",i[i.Int8=280]="Int8",i[i.Thickness=39]="Thickness",i[i.Elevation=38]="Elevation",i[i.LinetypeScale=48]="LinetypeScale",i[i.DashLength=49]="DashLength",i[i.MlineOffset=49]="MlineOffset",i[i.LinetypeElement=49]="LinetypeElement",i[i.NormalX=210]="NormalX",i[i.NormalY=220]="NormalY",i[i.NormalZ=230]="NormalZ",i[i.UcsOrg=110]="UcsOrg",i[i.UcsOrientationX=111]="UcsOrientationX",i[i.UcsOrientationY=112]="UcsOrientationY",i[i.ViewHeight=45]="ViewHeight",i[i.ViewWidth=41]="ViewWidth",i[i.ViewLensLength=42]="ViewLensLength",i[i.ViewFrontClip=43]="ViewFrontClip",i[i.ViewBackClip=44]="ViewBackClip",i[i.ViewBrightness=141]="ViewBrightness",i[i.ViewContrast=142]="ViewContrast",i[i.ViewMode=71]="ViewMode",i[i.ViewportActive=68]="ViewportActive",i[i.ViewportAspect=41]="ViewportAspect",i[i.ViewportGrid=76]="ViewportGrid",i[i.ViewportIcon=74]="ViewportIcon",i[i.ViewportNumber=69]="ViewportNumber",i[i.ViewportSnap=75]="ViewportSnap",i[i.ViewportSnapPair=78]="ViewportSnapPair",i[i.ViewportSnapStyle=77]="ViewportSnapStyle",i[i.ViewportTwist=51]="ViewportTwist",i[i.ViewportVisibility=67]="ViewportVisibility",i[i.ViewportZoom=73]="ViewportZoom",i[i.Color=62]="Color",i[i.ColorRgb=420]="ColorRgb",i[i.ColorName=430]="ColorName",i[i.LineWeight=370]="LineWeight",i[i.PlotStyleNameType=380]="PlotStyleNameType",i[i.PlotStyleNameId=390]="PlotStyleNameId",i[i.GradientObjType=450]="GradientObjType",i[i.GradientAngle=460]="GradientAngle",i[i.GradientName=470]="GradientName",i[i.GradientColCount=453]="GradientColCount",i[i.GradientPatType=451]="GradientPatType",i[i.GradientTintType=452]="GradientTintType",i[i.GradientShift=461]="GradientShift",i[i.GradientColVal=463]="GradientColVal",i[i.GradientTintVal=462]="GradientTintVal",i[i.SoftPointerId=330]="SoftPointerId",i[i.HardPointerId=340]="HardPointerId",i[i.SoftOwnershipId=350]="SoftOwnershipId",i[i.HardOwnershipId=360]="HardOwnershipId",i[i.ArbitraryHandle=320]="ArbitraryHandle",i[i.ExtendedDataAsciiString=1e3]="ExtendedDataAsciiString",i[i.ExtendedDataRegAppName=1001]="ExtendedDataRegAppName",i[i.ExtendedDataControlString=1002]="ExtendedDataControlString",i[i.ExtendedDataLayerName=1003]="ExtendedDataLayerName",i[i.ExtendedDataBinaryChunk=1004]="ExtendedDataBinaryChunk",i[i.ExtendedDataHandle=1005]="ExtendedDataHandle",i[i.ExtendedDataXCoordinate=1010]="ExtendedDataXCoordinate",i[i.ExtendedDataWorldXCoordinate=1011]="ExtendedDataWorldXCoordinate",i[i.ExtendedDataWorldXDisp=1012]="ExtendedDataWorldXDisp",i[i.ExtendedDataWorldXDir=1013]="ExtendedDataWorldXDir",i[i.ExtendedDataYCoordinate=1020]="ExtendedDataYCoordinate",i[i.ExtendedDataWorldYCoordinate=1021]="ExtendedDataWorldYCoordinate",i[i.ExtendedDataWorldYDisp=1022]="ExtendedDataWorldYDisp",i[i.ExtendedDataWorldYDir=1023]="ExtendedDataWorldYDir",i[i.ExtendedDataZCoordinate=1030]="ExtendedDataZCoordinate",i[i.ExtendedDataWorldZCoordinate=1031]="ExtendedDataWorldZCoordinate",i[i.ExtendedDataWorldZDisp=1032]="ExtendedDataWorldZDisp",i[i.ExtendedDataWorldZDir=1033]="ExtendedDataWorldZDir",i[i.ExtendedDataReal=1040]="ExtendedDataReal",i[i.ExtendedDataDist=1041]="ExtendedDataDist",i[i.ExtendedDataScale=1042]="ExtendedDataScale",i[i.ExtendedDataInteger16=1070]="ExtendedDataInteger16",i[i.ExtendedDataInteger32=1071]="ExtendedDataInteger32",i[i.XTextString=300]="XTextString",i[i.XReal=140]="XReal",i[i.XInt16=170]="XInt16",i[i.XXInt16=270]="XXInt16",i[i.Subclass=100]="Subclass",i[i.ControlString=102]="ControlString",i[i.EmbeddedObjectStart=101]="EmbeddedObjectStart",i[i.End=-1]="End",i[i.FirstEntityId=-2]="FirstEntityId",i[i.HeaderId=-2]="HeaderId",i[i.XDataStart=-3]="XDataStart",i[i.Operator=-4]="Operator",i[i.PReactors=-5]="PReactors",i[i.XDictionary=-6]="XDictionary",i))(Qn||{});const xo=[{name:"AC1.2",value:1},{name:"AC1.40",value:2},{name:"AC1.50",value:3},{name:"AC2.20",value:4},{name:"AC2.10",value:5},{name:"AC2.21",value:6},{name:"AC2.22",value:7},{name:"AC1001",value:8},{name:"AC1002",value:9},{name:"AC1003",value:10},{name:"AC1004",value:11},{name:"AC1005",value:12},{name:"AC1006",value:13},{name:"AC1007",value:14},{name:"AC1008",value:15},{name:"AC1009",value:16},{name:"AC1010",value:17},{name:"AC1011",value:18},{name:"AC1012",value:19},{name:"AC1013",value:20},{name:"AC1014",value:21},{name:"AC1500",value:22},{name:"AC1015",value:23},{name:"AC1800a",value:24},{name:"AC1018",value:25},{name:"AC2100a",value:26},{name:"AC1021",value:27},{name:"AC2400a",value:28},{name:"AC1024",value:29},{name:"AC1027",value:31},{name:"AC3200a",value:32},{name:"AC1032",value:33}];class kt{constructor(t){if(typeof t=="string"){const e=xo.find(s=>s.name===t);if(!e)throw new Error(`Unknown DWG version name: ${t}`);this.name=e.name,this.value=e.value;return}if(typeof t=="number"){const e=xo.find(s=>s.value===t);if(!e)throw new Error(`Unknown DWG version value: ${t}`);this.name=e.name,this.value=e.value;return}throw new Error("Invalid constructor argument for AcDbDwgVersion")}}class Ho{constructor(t={}){this._database=t.database,this._precision=Math.max(0,Math.min(16,t.precision??16)),this._version=t.version instanceof kt?t.version:t.version!=null?new kt(t.version):void 0,this._lines=[],this._handleMap=new Map,this._nextHandle=1}get database(){return this._database}set database(t){this._database=t}get precision(){return this._precision}setPrecision(t){return this._precision=Math.max(0,Math.min(16,t)),this}get version(){return this._version}get nextHandle(){return this._nextHandle}setVersion(t){return this._version=t instanceof kt?t:new kt(t),this}toString(){return this._lines.join(`
2
2
  `)+`
3
- `}registerHandle(t){return this._handleMap.has(t)||(/^[0-9A-F]+$/i.test(t)?this._handleMap.set(t,t.toUpperCase()):(this._handleMap.set(t,this._nextHandle.toString(16).toUpperCase()),this._nextHandle+=1)),this._handleMap.get(t)}resolveHandle(t){if(t)return this.registerHandle(t)}writeGroup(t,e){if(e==null)return this;this._lines.push(String(Math.trunc(t)));const s=this.formatValue(e);return this._lines.push(s===""?"0":s),this}writeStart(t){return this.writeString(0,t)}writeSubclassMarker(t){return this.writeString(100,t)}writeString(t,e){return!e&&e!==""?this:this.writeGroup(t,e)}writeInt8(t,e){return e==null?this:this.writeGroup(t,Math.trunc(e))}writeInt16(t,e){return e==null?this:this.writeGroup(t,Math.trunc(e))}writeInt32(t,e){return e==null?this:this.writeGroup(t,Math.trunc(e))}writeInt64(t,e){return e==null?this:this.writeGroup(t,Math.trunc(e))}writeUInt16(t,e){return e==null?this:this.writeGroup(t,Math.max(0,e))}writeUInt32(t,e){return e==null?this:this.writeGroup(t,Math.max(0,e))}writeBoolean(t,e){return e==null?this:this.writeGroup(t,e?1:0)}writeBool(t,e){return this.writeBoolean(t,e)}writeDouble(t,e){return e==null||!Number.isFinite(e)?this:this.writeGroup(t,e)}writeAngle(t,e){return e==null||!Number.isFinite(e)?this:this.writeDouble(t,e*180/Math.PI)}writeHandle(t,e){const s=this.resolveHandle(e);return s?this.writeString(t,s):this}writeObjectId(t,e){return this.writeHandle(t,e)}writePoint2d(t,e){return e?(this.writeDouble(t,e.x),this.writeDouble(t+10,e.y),this):this}writePoint3d(t,e){return e?(this.writeDouble(t,e.x),this.writeDouble(t+10,e.y),this.writeDouble(t+20,e.z??0),this):this}writeVector3d(t,e){return e?(this.writeDouble(t,e.x),this.writeDouble(t+10,e.y),this.writeDouble(t+20,e.z??0),this):this}writeCmColor(t,e=62,s=420){if(!t)return this;const n=t.colorIndex;n!=null&&this.writeInt16(e,n);const r=t.RGB;return r!=null&&t.colorIndex==null&&this.writeInt32(s,r),this}writeTransparency(t,e=440){return t?this.writeInt32(e,t.serialize()):this}writeResultBuffer(t){if(!t)return this;for(const e of t)this.writeGroup(e.code,e.value);return this}startSection(t){return this.writeStart("SECTION"),this.writeString(2,t),this}endSection(){return this.writeStart("ENDSEC"),this}startTable(t){return this.writeStart("TABLE"),this.writeString(2,t),this}endTable(){return this.writeStart("ENDTAB"),this}formatValue(t){if(typeof t=="string")return this.sanitizeStringForDxfLine(t);if(typeof t=="boolean")return t?"1":"0";if(typeof t=="number"){if(!Number.isFinite(t))return"0";if(Number.isInteger(t))return String(t);const s=t.toFixed(this._precision).replace(/\.?0+$/,"");return s===""||s==="-"?"0":s}return String(t)}sanitizeStringForDxfLine(t){return t.replace(/\r\n|\r|\n/g," ").replace(/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]/g,"")}}function Al(i,t){for(var e=0;e<t.length;e++){const s=t[e];if(typeof s!="string"&&!Array.isArray(s)){for(const n in s)if(n!=="default"&&!(n in i)){const r=Object.getOwnPropertyDescriptor(s,n);r&&Object.defineProperty(i,n,r.get?r:{enumerable:!0,get:()=>s[n]})}}}return Object.freeze(Object.defineProperty(i,Symbol.toStringTag,{value:"Module"}))}var E=(i=>(i[i.ByColor=1]="ByColor",i[i.ByACI=2]="ByACI",i[i.ByLayer=3]="ByLayer",i[i.ByBlock=4]="ByBlock",i[i.None=0]="None",i))(E||{});const Zr={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074},nn=[0,16711680,16776960,65280,65535,255,16711935,16777215,8421504,12632256,16711680,16744319,13369344,13395558,10027008,10046540,8323072,8339263,4980736,4990502,16727808,16752511,13382400,13401958,10036736,10051404,8331008,8343359,4985600,4992806,16744192,16760703,13395456,13408614,10046464,10056268,8339200,8347455,4990464,4995366,16760576,16768895,13408512,13415014,10056192,10061132,8347392,8351551,4995328,4997670,16776960,16777087,13421568,13421670,10000384,10000460,8355584,8355647,5000192,5000230,12582656,14679935,10079232,11717734,7510016,8755276,6258432,7307071,3755008,4344870,8388352,12582783,6736896,10079334,5019648,7510092,4161280,6258495,2509824,3755046,4194048,10485631,3394560,8375398,2529280,6264908,2064128,5209919,1264640,3099686,65280,8388479,52224,6736998,38912,5019724,32512,4161343,19456,2509862,65343,8388511,52275,6737023,38950,5019743,32543,4161359,19475,2509871,65407,8388543,52326,6737049,38988,5019762,32575,4161375,19494,2509881,65471,8388575,52377,6737074,39026,5019781,32607,4161391,19513,2509890,65535,8388607,52428,6737100,39064,5019800,32639,4161407,19532,2509900,49151,8380415,39372,6730444,29336,5014936,24447,4157311,14668,2507340,32767,8372223,26316,6724044,19608,5010072,16255,4153215,9804,2505036,16383,8364031,13260,6717388,9880,5005208,8063,4149119,4940,2502476,255,8355839,204,6710988,152,5000344,127,4145023,76,2500172,4129023,10452991,3342540,8349388,2490520,6245528,2031743,5193599,1245260,3089996,8323327,12550143,6684876,10053324,4980888,7490712,4128895,6242175,2490444,3745356,12517631,14647295,10027212,11691724,7471256,8735896,6226047,7290751,3735628,4335180,16711935,16744447,13369548,13395660,9961624,9981080,8323199,8339327,4980812,4990540,16711871,16744415,13369497,13395634,9961586,9981061,8323167,8339311,4980793,4990530,16711807,16744383,13369446,13395609,9961548,9981042,8323135,8339295,4980774,4990521,16711743,16744351,13369395,13395583,9961510,9981023,8323103,8339279,4980755,4990511,3355443,5987163,8684676,11382189,14079702,16777215,0];let ue=class{static getColorByIndex(t){return nn[t]}static getIndexByColor(t){const e=nn.length-1;for(let s=1;s<e;++s)if(nn[s]===t)return s}static getColorByName(t){return Zr[t.toLowerCase()]}static getNameByColor(t){for(const[e,s]of Object.entries(Zr))if(s===t)return e}static getNameByIndex(t){const e=this.getColorByIndex(t);return this.getNameByColor(e)}},Q=class ne{constructor(t=E.ByLayer,e){this._colorMethod=t,this._colorMethod==E.ByColor&&e==null?this._value=16777215:this._colorMethod==E.ByACI?e==null?this._value=8:e===0?this._colorMethod=E.ByBlock:e===256?this._colorMethod=E.ByLayer:this._value=Math.max(0,Math.min(e,256)):this._value=e}get colorMethod(){return this._colorMethod}set colorMethod(t){this._colorMethod=t}get red(){const t=this.RGB;return t!=null?t>>16&255:void 0}get green(){const t=this.RGB;return t!=null?t>>8&255:void 0}get blue(){const t=this.RGB;return t!=null?t&255:void 0}get RGB(){switch(this._colorMethod){case E.ByColor:case E.ByBlock:case E.ByLayer:return this._value;case E.ByACI:return this._value?ue.getColorByIndex(this._value):this._value;default:return}}setRGB(t,e,s){const n=Math.max(0,Math.min(255,Math.round(t))),r=Math.max(0,Math.min(255,Math.round(e))),a=Math.max(0,Math.min(255,Math.round(s)));return this._value=n<<16|r<<8|a,this._colorMethod=E.ByColor,this}setRGBValue(t){return t==null||!Number.isFinite(t)?this:(this._value=t&16777215,this._colorMethod=E.ByColor,this)}setRGBFromCss(t){if(!t)return this;const e=t.trim().toLowerCase();if(e.startsWith("#")){let r=0,a=0,o=0;if(e.length===7)r=parseInt(e.substr(1,2),16),a=parseInt(e.substr(3,2),16),o=parseInt(e.substr(5,2),16);else if(e.length===4)r=parseInt(e[1]+e[1],16),a=parseInt(e[2]+e[2],16),o=parseInt(e[3]+e[3],16);else return this;return this.setRGB(r,a,o)}const s=e.match(/^rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)/);if(s){const r=parseInt(s[1],10),a=parseInt(s[2],10),o=parseInt(s[3],10);return this.setRGB(r,a,o)}const n=ue.getColorByName(t);return n!==void 0?this.setRGBValue(n):this}setScalar(t){return this.setRGB(t,t,t)}get hexColor(){const t=this.RGB;return t==null?void 0:"0x"+t.toString(16).padStart(6,"0").toUpperCase()}get cssColor(){const t=this.RGB;if(t!=null)return`rgb(${t>>16&255},${t>>8&255},${t&255})`}cssColorAlpha(t){const e=this.RGB;if(e!=null)return`rgba(${e>>16&255},${e>>8&255},${e&255},${t})`}get colorIndex(){return this._colorMethod===E.ByACI?this._value:this._colorMethod===E.ByLayer?256:this._colorMethod===E.ByBlock?0:void 0}set colorIndex(t){if(t==null)return;const e=Math.max(0,Math.min(256,Math.round(t)));e===0?(this._colorMethod=E.ByBlock,this._value=void 0):e===256?(this._colorMethod=E.ByLayer,this._value=void 0):(this._colorMethod=E.ByACI,this._value=e)}get isByColor(){return this._colorMethod===E.ByColor}get isByACI(){return this._colorMethod===E.ByACI}get isForeground(){return this._colorMethod===E.ByACI&&this._value===7}setForeground(){return this._colorMethod=E.ByACI,this._value=7,this}get isByLayer(){return this._colorMethod===E.ByLayer}setByLayer(t){return this._colorMethod=E.ByLayer,t==null?this._value=256:this._value=t,this}get isByBlock(){return this._colorMethod===E.ByBlock}setByBlock(t){return this._colorMethod=E.ByBlock,t==null?this._value=0:this._value=t,this}get colorName(){switch(this._colorMethod){case E.ByLayer:return"ByLayer";case E.ByBlock:return"ByBlock";case E.ByColor:return this._value?ue.getNameByColor(this._value):"";case E.ByACI:return this._value?ue.getNameByIndex(this._value):"";default:return}}set colorName(t){if(!t)return;const e=ue.getColorByName(t);e!==void 0&&(this._value=e,this._colorMethod=E.ByColor)}clone(){const t=new ne;return t._colorMethod=this._colorMethod,t._value=this._value,t}copy(t){return this._colorMethod=t._colorMethod,this._value=t._value,this}equals(t){return this._colorMethod===t._colorMethod&&this._value===t._value}toString(){switch(this._colorMethod){case E.ByLayer:return"ByLayer";case E.ByBlock:return"ByBlock";case E.ByACI:return this._value!==void 0?String(this._value):"";case E.ByColor:return this._value?`${this.red},${this.green},${this.blue}`:"";default:return""}}static fromString(t){if(!t)return;const e=t.trim();if(/^bylayer$/i.test(e))return new ne(E.ByLayer);if(/^byblock$/i.test(e))return new ne(E.ByBlock);const s=e.match(/^rgb\s*:\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})$/i);if(s){const r=Number(s[1]),a=Number(s[2]),o=Number(s[3]),l=new ne(E.ByColor);return l.setRGB(r,a,o),l}if(/^\d{1,3},\d{1,3},\d{1,3}$/.test(e)){const[r,a,o]=e.split(",").map(Number),l=new ne(E.ByColor);return l.setRGB(r,a,o),l}if(/^\d+$/.test(e)){const r=parseInt(e,10);return new ne(E.ByACI,r)}if(/^book\$/i.test(e)){const r=e.substring(e.indexOf("$")+1),a=ue.getColorByName(r);return a!=null?new ne(E.ByColor,a):void 0}const n=ue.getColorByName(e);if(n!=null)return new ne(E.ByColor,n)}};class Tl{constructor(t=E.ByColor,e=0){this._colorMethod=t,this._value=e}get colorMethd(){return this._colorMethod}get red(){return this._value>>16&255}set red(t){this._colorMethod=E.ByColor,this._value=this._value&65535|(t&255)<<16}get green(){return this._value>>8&255}set green(t){this._colorMethod=E.ByColor,this._value=this._value&16711935|(t&255)<<8}get blue(){return this._value&255}set blue(t){this._colorMethod=E.ByColor,this._value=this._value&16776960|t&255}setRGB(t,e,s){this._colorMethod=E.ByColor,this._value=(t&255)<<16|(e&255)<<8|s&255}get colorIndex(){return this._value}set colorIndex(t){this._colorMethod=E.ByACI,this._value=t}get layerIndex(){return this._value}set layerIndex(t){this._colorMethod=E.ByLayer,this._value=t}isByColor(){return this._colorMethod===E.ByColor}isByLayer(){return this._colorMethod===E.ByLayer}isByBlock(){return this._colorMethod===E.ByBlock}isByACI(){return this._colorMethod===E.ByACI}isNone(){return this._colorMethod===E.None}get rawValue(){return this._value}set rawValue(t){this._value=t}}const yt={get ILLEGAL_PARAMETERS(){return new ReferenceError("Illegal Parameters")},get ZERO_DIVISION(){return new Error("Zero division")},get UNRESOLVED_BOUNDARY_CONFLICT(){return new Error("Unresolved boundary conflict in boolean operation")},get INFINITE_LOOP(){return new Error("Infinite loop")},get CANNOT_INVOKE_ABSTRACT_METHOD(){return new Error("Abstract method cannot be invoked")},get OPERATION_IS_NOT_SUPPORTED(){return new Error("Operation is not supported")},get NOT_IMPLEMENTED(){return new Error("Not implemented yet")}};let Ml=class{constructor(){this._listeners={}}addEventListener(t,e){this._listeners===void 0&&(this._listeners={});const s=this._listeners;s[t]===void 0&&(s[t]=[]),s[t].indexOf(e)===-1&&s[t].push(e)}hasEventListener(t,e){if(this._listeners===void 0)return!1;const s=this._listeners;return s[t]!==void 0&&s[t].indexOf(e)!==-1}removeEventListener(t,e){if(this._listeners===void 0)return;const s=this._listeners[t];if(s!==void 0){const n=s.indexOf(e);n!==-1&&s.splice(n,1)}}dispatchEvent(t){if(this._listeners===void 0)return;const e=this._listeners[t.type];if(e!==void 0){t.target=this;const s=e.slice(0);for(let n=0,r=s.length;n<r;n++)s[n].call(this,t)}}},Z=class{constructor(){this.listeners=[]}addEventListener(t){this.listeners.push(t)}removeEventListener(t){this.listeners=this.listeners.filter(e=>e!==t)}replaceEventListener(t){this.removeEventListener(t),this.addEventListener(t)}dispatch(t,...e){for(const s of this.listeners)s.call(null,t,...e)}};function bs(i){return i===null||typeof i!="object"?i:Array.isArray(i)?[...i]:{...i}}function xn(i){if(i===null||typeof i!="object")return i;if(i instanceof Date)return new Date(i.getTime());if(i instanceof RegExp)return new RegExp(i.source,i.flags);if(Array.isArray(i))return i.map(xn);const t={};for(const e in i)Object.prototype.hasOwnProperty.call(i,e)&&(t[e]=xn(i[e]));return t}function Hs(i,...t){for(const e of t)if(e)for(const s in e)Object.prototype.hasOwnProperty.call(e,s)&&i[s]===void 0&&(i[s]=e[s]);return i}function Ia(i,t){return i!=null&&Object.prototype.hasOwnProperty.call(i,t)}function Pa(i){return i==null?!0:Array.isArray(i)||typeof i=="string"?i.length===0:i instanceof Map||i instanceof Set?i.size===0:typeof i=="object"?Object.keys(i).length===0:!1}function Ze(i,t){if(i===t)return!0;if(i==null||t==null)return i===t;if(typeof i!=typeof t)return!1;if(typeof i!="object")return i===t;if(Array.isArray(i)!==Array.isArray(t))return!1;if(Array.isArray(i)){if(i.length!==t.length)return!1;for(let n=0;n<i.length;n++)if(!Ze(i[n],t[n]))return!1;return!0}const e=Object.keys(i),s=Object.keys(t);if(e.length!==s.length)return!1;for(const n of e)if(!Object.prototype.hasOwnProperty.call(t,n)||!Ze(i[n],t[n]))return!1;return!0}var vl=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function kl(i){return i&&i.__esModule&&Object.prototype.hasOwnProperty.call(i,"default")?i.default:i}var Sa={exports:{}};(function(i){(function(t,e){i.exports?i.exports=e():t.log=e()})(vl,function(){var t=function(){},e="undefined",s=typeof window!==e&&typeof window.navigator!==e&&/Trident\/|MSIE /.test(window.navigator.userAgent),n=["trace","debug","info","warn","error"],r={},a=null;function o(y,x){var f=y[x];if(typeof f.bind=="function")return f.bind(y);try{return Function.prototype.bind.call(f,y)}catch{return function(){return Function.prototype.apply.apply(f,[y,arguments])}}}function l(){console.log&&(console.log.apply||Function.prototype.apply.apply(console.log,[console,arguments]))}function c(y){return y==="debug"&&(y="log"),typeof console===e?!1:y==="trace"&&s?l:console[y]!==void 0?o(console,y):console.log!==void 0?o(console,"log"):t}function u(){for(var y=this.getLevel(),x=0;x<n.length;x++){var f=n[x];this[f]=x<y?t:this.methodFactory(f,y,this.name)}if(this.log=this.debug,typeof console===e&&y<this.levels.SILENT)return"No console available for logging"}function d(y){return function(){typeof console!==e&&(u.call(this),this[y].apply(this,arguments))}}function g(y,x,f){return c(y)||d.apply(this,arguments)}function p(y,x){var f=this,P,I,M,A="loglevel";typeof y=="string"?A+=":"+y:typeof y=="symbol"&&(A=void 0);function j(F){var U=(n[F]||"silent").toUpperCase();if(!(typeof window===e||!A)){try{window.localStorage[A]=U;return}catch{}try{window.document.cookie=encodeURIComponent(A)+"="+U+";"}catch{}}}function T(){var F;if(!(typeof window===e||!A)){try{F=window.localStorage[A]}catch{}if(typeof F===e)try{var U=window.document.cookie,fe=encodeURIComponent(A),be=U.indexOf(fe+"=");be!==-1&&(F=/^([^;]+)/.exec(U.slice(be+fe.length+1))[1])}catch{}return f.levels[F]===void 0&&(F=void 0),F}}function X(){if(!(typeof window===e||!A)){try{window.localStorage.removeItem(A)}catch{}try{window.document.cookie=encodeURIComponent(A)+"=; expires=Thu, 01 Jan 1970 00:00:00 UTC"}catch{}}}function B(F){var U=F;if(typeof U=="string"&&f.levels[U.toUpperCase()]!==void 0&&(U=f.levels[U.toUpperCase()]),typeof U=="number"&&U>=0&&U<=f.levels.SILENT)return U;throw new TypeError("log.setLevel() called with invalid level: "+F)}f.name=y,f.levels={TRACE:0,DEBUG:1,INFO:2,WARN:3,ERROR:4,SILENT:5},f.methodFactory=x||g,f.getLevel=function(){return M??I??P},f.setLevel=function(F,U){return M=B(F),U!==!1&&j(M),u.call(f)},f.setDefaultLevel=function(F){I=B(F),T()||f.setLevel(F,!1)},f.resetLevel=function(){M=null,X(),u.call(f)},f.enableAll=function(F){f.setLevel(f.levels.TRACE,F)},f.disableAll=function(F){f.setLevel(f.levels.SILENT,F)},f.rebuild=function(){if(a!==f&&(P=B(a.getLevel())),u.call(f),a===f)for(var F in r)r[F].rebuild()},P=B(a?a.getLevel():"WARN");var et=T();et!=null&&(M=B(et)),u.call(f)}a=new p,a.getLogger=function(y){if(typeof y!="symbol"&&typeof y!="string"||y==="")throw new TypeError("You must supply a name when creating a logger.");var x=r[y];return x||(x=r[y]=new p(y,a.methodFactory)),x};var m=typeof window!==e?window.log:void 0;return a.noConflict=function(){return typeof window!==e&&window.log===a&&(window.log=m),a},a.getLoggers=function(){return r},a.default=a,a})})(Sa);var Ea=Sa.exports;const Ll=kl(Ea),Ol=Al({__proto__:null,default:Ll},[Ea]),Nl=!0,Ss=Ol;Ss.setLevel("debug");const Cl=i=>{try{Ss.setLevel(i)}catch(t){Ss.setLevel("error"),Ss.error(t)}};let Aa=class Ta{constructor(t,e){this.events={attrChanged:new Z,modelChanged:new Z},this._changing=!1,this._previousAttributes={},this._pending=!1;const s=t||{};e&&Hs(s,e),this.attributes=s,this.changed={}}get(t){return this.attributes[t]}set(t,e,s){if(t==null)return this;let n;typeof t=="object"?(n=t,s=e):(n={},n[t]=e),s||(s={});const r=s.unset,a=s.silent,o=[],l=this._changing;this._changing=!0,l||(this._previousAttributes=bs(this.attributes),this.changed={});const c=this.attributes,u=this.changed,d=this._previousAttributes;for(const g in n)e=n[g],Ze(c[g],e)||o.push(g),Ze(d[g],e)?delete u[g]:u[g]=e,r?delete c[g]:c[g]=e;if(!a){o.length&&(this._pending=s);for(let g=0;g<o.length;g++)this.events.attrChanged.dispatch({object:this,attrName:o[g],attrValue:c[o[g]],options:s})}if(l)return this;if(!a)for(;this._pending;)s=this._pending,this._pending=!1,this.events.modelChanged.dispatch({object:this,options:s});return this._pending=!1,this._changing=!1,this}has(t){return this.get(t)!=null}hasChanged(t){return t==null?!Pa(this.changed):Ia(this.changed,t)}changedAttributes(t){if(!t)return this.hasChanged()?bs(this.changed):{};const e=this._changing?this._previousAttributes:this.attributes,s={};for(const n in t){const r=t[n];Ze(e[n],r)||(s[n]=r)}return s}previous(t){return t==null||!this._previousAttributes?null:this._previousAttributes[t]}previousAttributes(){return bs(this._previousAttributes)}clone(){const t=bs(this.attributes);return new Ta(t)}},Rn=class Is{constructor(){this.entries=new Map}static getInstance(){return Is.instance||(Is.instance=new Is),Is.instance}collect(t){this.entries.set(t.name,t)}printAll(){for(const[t,e]of this.entries);}clear(){this.entries.clear()}getAll(){return Array.from(this.entries.values())}getEntry(t){return this.entries.get(t)}remove(t){return this.entries.delete(t)}};class Bl{static formatBytes(t,e=2){if(t===0)return"0 B";const s=1024,n=Math.max(0,e),r=["B","KB","MB","GB","TB"],a=Math.floor(Math.log(t)/Math.log(s)),o=t/Math.pow(s,a);return`${parseFloat(o.toFixed(n))} ${r[a]}`}}var ut=(i=>(i[i.ByLayer=0]="ByLayer",i[i.ByBlock=1]="ByBlock",i[i.ByAlpha=2]="ByAlpha",i[i.ErrorValue=3]="ErrorValue",i))(ut||{});let Qi=class Ft{constructor(t){t!==void 0?(this._method=ut.ByAlpha,this._alpha=Ft.clampAlpha(t)):(this._method=ut.ByLayer,this._alpha=255)}get method(){return this._method}set method(t){this._method=t}get alpha(){return this._alpha}set alpha(t){this._alpha=Ft.clampAlpha(t),this._method=ut.ByAlpha}get percentage(){if(this._method===ut.ByAlpha)return Math.round((1-this._alpha/255)*100)}set percentage(t){const e=Math.max(0,Math.min(100,t)),s=Math.round(255*(1-e/100));this.alpha=s}static clampAlpha(t){return Math.max(0,Math.min(255,Math.floor(t)))}get isByAlpha(){return this._method===ut.ByAlpha}get isByBlock(){return this._method===ut.ByBlock}get isByLayer(){return this._method===ut.ByLayer}get isClear(){return this.isByAlpha&&this._alpha===0}get isSolid(){return this.isByAlpha&&this._alpha===255}get isInvalid(){return this._method===ut.ErrorValue}serialize(){return this._method<<24|this._alpha}clone(){const t=new Ft;return t._method=this._method,t._alpha=this._alpha,t}equals(t){return this._method===t._method&&this._alpha===t._alpha}toString(){return this.isByLayer?"ByLayer":this.isByBlock?"ByBlock":this._alpha.toString()}static fromString(t){const e=t.trim();if(/^bylayer$/i.test(e)){const r=new Ft;return r._method=ut.ByLayer,r}if(/^byblock$/i.test(e)){const r=new Ft;return r._method=ut.ByBlock,r}const s=Number(e);if(Number.isInteger(s)&&s>=0&&s<=255)return new Ft(s);const n=new Ft;return n._method=ut.ErrorValue,n}static deserialize(t){const e=t>>>24&255,s=t&255,n=Object.values(ut)[e]??ut.ErrorValue,r=new Ft;return r._method=n,r._alpha=Ft.clampAlpha(s),r}};class Ma{constructor(t){this.name=t}run(t){throw new Error("run() must be implemented by subclass")}}class va{constructor(){this.tasks=[],this.onProgress=()=>{},this.onComplete=()=>{},this.onError=()=>!1}scheduleTask(t){return new Promise((e,s)=>{const n=()=>{Promise.resolve(t()).then(e).catch(s)};typeof window<"u"&&typeof window.requestAnimationFrame=="function"?window.requestAnimationFrame(n):setTimeout(n,0)})}addTask(t){this.tasks.push(t)}setProgressCallback(t){this.onProgress=t}setCompleteCallback(t){this.onComplete=t}setErrorCallback(t){this.onError=t}async run(t){const e=this.tasks.length;let s=t;for(let n=0;n<e;n++){const r=this.tasks[n];try{s=await this.scheduleTask(async()=>{const a=await r.run(s);return this.onProgress((n+1)/e,r),a})}catch(a){if(this.onError({error:a,taskIndex:n,task:r}))return Promise.reject(a)}}this.onComplete(s)}}let ka=class{constructor(t,e,s){this.isLoading=!1,this.itemsLoaded=0,this.itemsTotal=0,this.urlModifier=void 0,this.handlers=[],this.onStart=void 0,this.onLoad=t,this.onProgress=e,this.onError=s}itemStart(t){this.itemsTotal++,this.isLoading===!1&&this.onStart!==void 0&&this.onStart(t,this.itemsLoaded,this.itemsTotal),this.isLoading=!0}itemEnd(t){this.itemsLoaded++,this.onProgress!==void 0&&this.onProgress(t,this.itemsLoaded,this.itemsTotal),this.itemsLoaded===this.itemsTotal&&(this.isLoading=!1,this.onLoad!==void 0&&this.onLoad())}itemError(t){this.onError!==void 0&&this.onError(t)}resolveURL(t){return this.urlModifier?this.urlModifier(t):t}setURLModifier(t){return this.urlModifier=t,this}addHandler(t,e){return this.handlers.push(t,e),this}removeHandler(t){const e=this.handlers.indexOf(t);return e!==-1&&this.handlers.splice(e,2),this}getHandler(t){for(let e=0,s=this.handlers.length;e<s;e+=2){const n=this.handlers[e],r=this.handlers[e+1];if(n.global&&(n.lastIndex=0),n.test(t))return r}return null}};const La=new ka;class Fl{constructor(t){this.manager=t!==void 0?t:La,this.crossOrigin="anonymous",this.withCredentials=!1,this.path="",this.resourcePath="",this.requestHeader={}}loadAsync(t,e){return new Promise((s,n)=>{this.load(t,s,e,n)})}parse(t){}setCrossOrigin(t){return this.crossOrigin=t,this}setWithCredentials(t){return this.withCredentials=t,this}setPath(t){return this.path=t,this}setResourcePath(t){return this.resourcePath=t,this}setRequestHeader(t){return this.requestHeader=t,this}}var De=256,Oa=[],Kr=256,ri;for(;De--;)Oa[De]=(De+256).toString(16).substring(1);function Rl(i){var t=0,e=11;if(!ri||De+e>Kr*2)for(ri="",De=0;t<Kr;t++)ri+=Oa[Math.random()*256|0];return ri.substring(De,De+++e)}const pi="TEMP_";let fn;function Na(i){fn=i}class he{constructor(t,e){if(t=t||{},this._attrs=new Aa(t,e),this._xDataMap=new Map,!this._attrs.get("objectId"))try{this._attrs.set("objectId",this.database.generateHandle())}catch{this._attrs.set("objectId",this.generateTemporaryHandle())}}generateTemporaryHandle(){return pi+Rl()}get attrs(){return this._attrs}getAttr(t){const e=this._attrs.get(t);if(e===void 0)throw new Error(`[AcDbObject] Attribute name '${t}' does't exist in this object!`);return e}getAttrWithoutException(t){return this._attrs.get(t)}setAttr(t,e){this._attrs.set(t,e)}get objectId(){return this.getAttr("objectId")}set objectId(t){this._attrs.set("objectId",t),t&&!t.startsWith(pi)&&this.database.updateMaxHandle(t)}get isTemp(){const t=this.getAttrWithoutException("objectId");return!!t&&t.startsWith(pi)}get ownerId(){return this.getAttr("ownerId")}set ownerId(t){this._attrs.set("ownerId",t)}get extensionDictionary(){return this.getAttrWithoutException("extensionDictionary")}set extensionDictionary(t){this._attrs.set("extensionDictionary",t)}get database(){if(this._database)return this._database;if(fn)return fn().workingDatabase;throw new Error("The current working database must be set before using it!")}set database(t){this._database=t}getXData(t){return this._xDataMap.get(t)}setXData(t){for(const e of t)e.code===Fn.ExtendedDataRegAppName&&this._xDataMap.set(e.value,t)}removeXData(t){this._xDataMap.delete(t)}createExtensionDictionary(){}close(){}clone(){const t=Object.create(Object.getPrototypeOf(this)),e=this,s=t;for(const n of Object.keys(e))n!=="_database"&&(s[n]=this.cloneValue(e[n]));return t.objectId=this.generateTemporaryHandle(),t}cloneValue(t){if(t==null||typeof t!="object")return t;if(t instanceof Date)return new Date(t.getTime());if(t instanceof RegExp)return new RegExp(t.source,t.flags);if(Array.isArray(t))return t.map(n=>this.cloneValue(n));if(t instanceof Map){const n=new Map;for(const[r,a]of t.entries())n.set(this.cloneValue(r),this.cloneValue(a));return n}if(t instanceof Set){const n=new Set;for(const r of t.values())n.add(this.cloneValue(r));return n}if(ArrayBuffer.isView(t)){if(t instanceof DataView)return new DataView(t.buffer.slice(0));const n=t.constructor;return new n(t)}if(t instanceof ArrayBuffer)return t.slice(0);if("clone"in t&&typeof t.clone=="function")return t.clone();const e=Object.create(Object.getPrototypeOf(t)),s=t;for(const n of Object.keys(s))e[n]=this.cloneValue(s[n]);return e}dxfOut(...t){const[e,s=!1]=t;if(e.writeHandle(5,this.objectId),e.writeObjectId(330,this.ownerId),e.writeObjectId(360,this.extensionDictionary),this.dxfOutFields(e),s)for(const n of this._xDataMap.values())e.writeResultBuffer(n);return this}dxfOutFields(t){return this}}let bn;function Ca(i){bn=i}function zn(){return Ii.instance}const qi=class qi{constructor(){this._workingDatabase=null}get workingDatabase(){if(this._workingDatabase==null)throw new Error("The current working database must be set before using it!");return this._workingDatabase}set workingDatabase(t){this._workingDatabase=t}get layoutManager(){if(!this._layoutManager){if(!bn)throw new Error("The layout manager factory must be registered before using it!");this._layoutManager=bn()}return this._layoutManager}};qi.instance=new qi;let Ii=qi;Na(zn);var Ba=(i=>(i.kForRead="kForRead",i.kForWrite="kForWrite",i))(Ba||{});class Vn{constructor(t){if(this._values=[],t)for(const e of t)this._values.push({...e})}get length(){return this._values.length}at(t){return this._values[t]}add(t){this._values.push(t)}addRange(t){for(const e of t)this._values.push(e)}clear(){this._values.length=0}toArray(){return this._values.map(t=>({...t}))}clone(){return new Vn(this._values)}[Symbol.iterator](){return this._values[Symbol.iterator]()}}class Dn{constructor(t,e,s){this._chunkSize=-1,this._minimumChunkSize=50,this._count=t,this._numerOfChunk=e<1?1:e,this._minimumChunkSize=s,this.calculateChunkSize()}get count(){return this._count}get numerOfChunk(){return this._numerOfChunk}get minimumChunkSize(){return this._minimumChunkSize}set minimumChunkSize(t){this._minimumChunkSize=t,this.calculateChunkSize()}get chunkSize(){return this._chunkSize}calculateChunkSize(){let t=this._count/this._numerOfChunk;t<this._minimumChunkSize&&(t=Math.min(this._minimumChunkSize,this._count)),this._chunkSize=t<1?this._count:Math.floor(t)}scheduleTask(t){return new Promise((e,s)=>{const n=()=>{Promise.resolve(t()).then(e).catch(s)};typeof window<"u"&&typeof window.requestAnimationFrame=="function"?window.requestAnimationFrame(n):setTimeout(n,0)})}async processChunk(t,e){if(this._count<=0){await(e==null?void 0:e());return}let s=0;const n=async()=>{const r=s,a=Math.min(s+this._chunkSize,this._count);await t(r,a),s=a,s<this._count&&await this.scheduleTask(n)};await n(),await(e==null?void 0:e())}}var Es=(i=>(i.DXF="dxf",i.DWG="dwg",i))(Es||{});class Rt{constructor(){this.events={registered:new Z,unregistered:new Z},this._converters=new Map,this.register("dxf",new Sl)}static createInstance(){return Rt._instance==null&&(Rt._instance=new Rt),this._instance}static get instance(){return Rt._instance||(Rt._instance=new Rt),Rt._instance}get fileTypes(){return this._converters.keys()}register(t,e){this._converters.set(t,e),this.events.registered.dispatch({fileType:t,converter:e})}get(t){return this._converters.get(t)}unregister(t){const e=this._converters.get(t);e&&(this._converters.delete(t),this.events.unregistered.dispatch({fileType:t,converter:e}))}}var jn=(i=>(i[i.DecimalDegrees=0]="DecimalDegrees",i[i.DegreesMinutesSeconds=1]="DegreesMinutesSeconds",i[i.Gradians=2]="Gradians",i[i.Radians=3]="Radians",i[i.SurveyorsUnits=4]="SurveyorsUnits",i))(jn||{});class ss{static get instance(){return this._instance||(this._instance=new ss),this._instance}constructor(){this._blocks=new Map}createKey(t,e){return`${t}_${e}`}set(t,e){return e=e.fastDeepClone(),this._blocks.set(t,e),e}get(t){let e=this._blocks.get(t);return e&&(e=e.fastDeepClone()),e}has(t){return this._blocks.has(t)}clear(){this._blocks.clear()}draw(t,e,s,n=[],r=!0,a,o){const l=[];if(e!=null){const c=this.createKey(e.name,s);let u;if(this.has(c))u=this.get(c);else{const d=e.newIterator();for(const g of d)g.color.isByBlock&&s?(Qr.copy(g.color),g.color.setRGBValue(s),this.addEntity(g,l,t),g.color.copy(Qr)):this.addEntity(g,l,t);u=t.group(l),u&&r&&K.name&&!K.name.startsWith("*U")&&this.set(c,u)}return u&&a&&(u.applyMatrix(a),o&&(o.x!=0||o.y!=0||o.z!=1)&&(a.setFromExtrusionDirection(o),u.applyMatrix(a))),u&&n&&n.length>0&&(u.bakeTransformToChildren(),n.forEach(d=>u.addChild(d))),u}else return t.group(l)}addEntity(t,e,s){const n=t.worldDraw(s);n&&(this.attachEntityInfo(n,t),e.push(n))}attachEntityInfo(t,e){t.objectId=e.objectId,t.ownerId=e.ownerId,t.layerName=e.layer,t.visible=e.visibility}}const Qr=new Q;var Wn=(i=>(i[i.UTF8=0]="UTF8",i[i.US_ASCII=1]="US_ASCII",i[i.ISO_8859_1=2]="ISO_8859_1",i[i.ISO_8859_2=3]="ISO_8859_2",i[i.ISO_8859_3=4]="ISO_8859_3",i[i.ISO_8859_4=5]="ISO_8859_4",i[i.ISO_8859_5=6]="ISO_8859_5",i[i.ISO_8859_6=7]="ISO_8859_6",i[i.ISO_8859_7=8]="ISO_8859_7",i[i.ISO_8859_8=9]="ISO_8859_8",i[i.ISO_8859_9=10]="ISO_8859_9",i[i.CP437=11]="CP437",i[i.CP850=12]="CP850",i[i.CP852=13]="CP852",i[i.CP855=14]="CP855",i[i.CP857=15]="CP857",i[i.CP860=16]="CP860",i[i.CP861=17]="CP861",i[i.CP863=18]="CP863",i[i.CP864=19]="CP864",i[i.CP865=20]="CP865",i[i.CP869=21]="CP869",i[i.CP932=22]="CP932",i[i.MACINTOSH=23]="MACINTOSH",i[i.BIG5=24]="BIG5",i[i.CP949=25]="CP949",i[i.JOHAB=26]="JOHAB",i[i.CP866=27]="CP866",i[i.ANSI_1250=28]="ANSI_1250",i[i.ANSI_1251=29]="ANSI_1251",i[i.ANSI_1252=30]="ANSI_1252",i[i.GB2312=31]="GB2312",i[i.ANSI_1253=32]="ANSI_1253",i[i.ANSI_1254=33]="ANSI_1254",i[i.ANSI_1255=34]="ANSI_1255",i[i.ANSI_1256=35]="ANSI_1256",i[i.ANSI_1257=36]="ANSI_1257",i[i.ANSI_874=37]="ANSI_874",i[i.ANSI_932=38]="ANSI_932",i[i.ANSI_936=39]="ANSI_936",i[i.ANSI_949=40]="ANSI_949",i[i.ANSI_950=41]="ANSI_950",i[i.ANSI_1361=42]="ANSI_1361",i[i.UTF16=43]="UTF16",i[i.ANSI_1258=44]="ANSI_1258",i[i.UNDEFINED=255]="UNDEFINED",i))(Wn||{});const zl=["utf-8","utf-8","iso-8859-1","iso-8859-2","iso-8859-3","iso-8859-4","iso-8859-5","iso-8859-6","iso-8859-7","iso-8859-8","iso-8859-9","utf-8","utf-8","utf-8","utf-8","utf-8","utf-8","utf-8","utf-8","utf-8","utf-8","utf-8","shift-jis","macintosh","big5","utf-8","utf-8","ibm866","windows-1250","windows-1251","windows-1252","gbk","windows-1253","windows-1254","windows-1255","windows-1256","windows-1257","windows-874","shift-jis","gbk","euc-kr","big5","utf-8","utf-16le","windows-1258"],Fa=i=>zl[i],Ke="Continuous",tt="Standard",At="ByLayer",Qe="ByBlock",In="mlightcad",Pn="ACAD",at=["00","01","02","03","04","05","06","07","08","09","0a","0b","0c","0d","0e","0f","10","11","12","13","14","15","16","17","18","19","1a","1b","1c","1d","1e","1f","20","21","22","23","24","25","26","27","28","29","2a","2b","2c","2d","2e","2f","30","31","32","33","34","35","36","37","38","39","3a","3b","3c","3d","3e","3f","40","41","42","43","44","45","46","47","48","49","4a","4b","4c","4d","4e","4f","50","51","52","53","54","55","56","57","58","59","5a","5b","5c","5d","5e","5f","60","61","62","63","64","65","66","67","68","69","6a","6b","6c","6d","6e","6f","70","71","72","73","74","75","76","77","78","79","7a","7b","7c","7d","7e","7f","80","81","82","83","84","85","86","87","88","89","8a","8b","8c","8d","8e","8f","90","91","92","93","94","95","96","97","98","99","9a","9b","9c","9d","9e","9f","a0","a1","a2","a3","a4","a5","a6","a7","a8","a9","aa","ab","ac","ad","ae","af","b0","b1","b2","b3","b4","b5","b6","b7","b8","b9","ba","bb","bc","bd","be","bf","c0","c1","c2","c3","c4","c5","c6","c7","c8","c9","ca","cb","cc","cd","ce","cf","d0","d1","d2","d3","d4","d5","d6","d7","d8","d9","da","db","dc","dd","de","df","e0","e1","e2","e3","e4","e5","e6","e7","e8","e9","ea","eb","ec","ed","ee","ef","f0","f1","f2","f3","f4","f5","f6","f7","f8","f9","fa","fb","fc","fd","fe","ff"];let Jr=1234567;const Gn=Math.PI/180,Hn=180/Math.PI;function Ra(){const i=Math.random()*4294967295|0,t=Math.random()*4294967295|0,e=Math.random()*4294967295|0,s=Math.random()*4294967295|0;return(at[i&255]+at[i>>8&255]+at[i>>16&255]+at[i>>24&255]+"-"+at[t&255]+at[t>>8&255]+"-"+at[t>>16&15|64]+at[t>>24&255]+"-"+at[e&63|128]+at[e>>8&255]+"-"+at[e>>16&255]+at[e>>24&255]+at[s&255]+at[s>>8&255]+at[s>>16&255]+at[s>>24&255]).toLowerCase()}function re(i,t,e){return Math.max(t,Math.min(e,i))}function Un(i,t){return(i%t+t)%t}function za(i,t,e,s,n){return s+(i-t)*(n-s)/(e-t)}function Va(i,t,e){return i!==t?(e-i)/(t-i):0}function Xn(i,t,e){return(1-e)*i+e*t}function Da(i,t,e,s){return Xn(i,t,1-Math.exp(-e*s))}function ja(i,t=1){return t-Math.abs(Un(i,t*2)-t)}function Wa(i,t,e){return i<=t?0:i>=e?1:(i=(i-t)/(e-t),i*i*(3-2*i))}function Ga(i,t,e){return i<=t?0:i>=e?1:(i=(i-t)/(e-t),i*i*i*(i*(i*6-15)+10))}function Ha(i,t){return i+Math.floor(Math.random()*(t-i+1))}function Ua(i,t){return i+Math.random()*(t-i)}function Xa(i){return i*(.5-Math.random())}function Ya(i){i!==void 0&&(Jr=i);let t=Jr+=1831565813;return t=Math.imul(t^t>>>15,t|1),t^=t+Math.imul(t^t>>>7,t|61),((t^t>>>14)>>>0)/4294967296}function $a(i){return i*Gn}function qa(i){return i*Hn}function Za(i){return(i&i-1)===0&&i!==0}function Ka(i){return Math.pow(2,Math.ceil(Math.log(i)/Math.LN2))}function Qa(i){return Math.pow(2,Math.floor(Math.log(i)/Math.LN2))}function As(i){const t=Math.PI*2;return(i%t+t)%t}function Ja(i,t,e){return i>t&&i<e||i>e&&i<t}function to(i,t,e,s=!1){return i=As(i),t=As(t),e=As(e),s?t>e?i<=t&&i>=e:i<=t||i>=e:t<e?i>=t&&i<=e:i>=t||i<=e}function Yn(i){return i=Math.abs(i),i<1?0:Math.ceil(Math.log10(Math.abs(i)+1))}function eo(i,t=1e-7){const e=Yn(i);return Math.max(Math.pow(10,e)*t,t)}const v={DEG2RAD:Gn,RAD2DEG:Hn,generateUUID:Ra,clamp:re,euclideanModulo:Un,mapLinear:za,inverseLerp:Va,lerp:Xn,damp:Da,pingpong:ja,smoothstep:Wa,smootherstep:Ga,randInt:Ha,randFloat:Ua,randFloatSpread:Xa,seededRandom:Ya,degToRad:$a,radToDeg:qa,isPowerOfTwo:Za,ceilPowerOfTwo:Ka,floorPowerOfTwo:Qa,normalizeAngle:As,isBetween:Ja,isBetweenAngle:to,intPartLength:Yn,relativeEps:eo},Sn=class so{constructor(t,e){this.x=0,this.y=0;const s=+(t!==void 0)+ +(e!==void 0);if(s!==0){if(s===1&&t instanceof Array){this.x=t[0],this.y=t[1];return}if(s===1){const{x:n,y:r}=t;this.x=n,this.y=r;return}if(s===2){this.x=t,this.y=e;return}throw yt.ILLEGAL_PARAMETERS}}get width(){return this.x}set width(t){this.x=t}get height(){return this.y}set height(t){this.y=t}set(t,e){return this.x=t,this.y=e,this}setScalar(t){return this.x=t,this.y=t,this}setX(t){return this.x=t,this}setY(t){return this.y=t,this}setComponent(t,e){switch(t){case 0:this.x=e;break;case 1:this.y=e;break;default:throw new Error("index is out of range: "+t)}return this}getComponent(t){switch(t){case 0:return this.x;case 1:return this.y;default:throw new Error("index is out of range: "+t)}}clone(){return new so(this.x,this.y)}copy(t){return this.x=t.x,this.y=t.y,this}add(t){return this.x+=t.x,this.y+=t.y,this}addScalar(t){return this.x+=t,this.y+=t,this}addVectors(t,e){return this.x=t.x+e.x,this.y=t.y+e.y,this}addScaledVector(t,e){return this.x+=t.x*e,this.y+=t.y*e,this}sub(t){return this.x-=t.x,this.y-=t.y,this}subScalar(t){return this.x-=t,this.y-=t,this}subVectors(t,e){return this.x=t.x-e.x,this.y=t.y-e.y,this}multiply(t){return this.x*=t.x,this.y*=t.y,this}multiplyScalar(t){return this.x*=t,this.y*=t,this}divide(t){return this.x/=t.x,this.y/=t.y,this}divideScalar(t){return this.multiplyScalar(1/t)}applyMatrix2d(t){const e=this.x,s=this.y,n=t.elements;return this.x=n[0]*e+n[3]*s+n[6],this.y=n[1]*e+n[4]*s+n[7],this}min(t){return this.x=Math.min(this.x,t.x),this.y=Math.min(this.y,t.y),this}max(t){return this.x=Math.max(this.x,t.x),this.y=Math.max(this.y,t.y),this}clamp(t,e){return this.x=Math.max(t.x,Math.min(e.x,this.x)),this.y=Math.max(t.y,Math.min(e.y,this.y)),this}clampScalar(t,e){return this.x=Math.max(t,Math.min(e,this.x)),this.y=Math.max(t,Math.min(e,this.y)),this}clampLength(t,e){const s=this.length();return this.divideScalar(s||1).multiplyScalar(Math.max(t,Math.min(e,s)))}floor(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this}ceil(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this}round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this}roundToZero(){return this.x=Math.trunc(this.x),this.y=Math.trunc(this.y),this}negate(){return this.x=-this.x,this.y=-this.y,this}dot(t){return this.x*t.x+this.y*t.y}cross(t){return this.x*t.y-this.y*t.x}lengthSq(){return this.x*this.x+this.y*this.y}length(){return Math.sqrt(this.x*this.x+this.y*this.y)}manhattanLength(){return Math.abs(this.x)+Math.abs(this.y)}normalize(){return this.divideScalar(this.length()||1)}angle(){return Math.atan2(-this.y,-this.x)+Math.PI}angleTo(t){const e=Math.sqrt(this.lengthSq()*t.lengthSq());if(e===0)return Math.PI/2;const s=this.dot(t)/e;return Math.acos(Math.max(-1,Math.min(1,s)))}distanceTo(t){return Math.sqrt(this.distanceToSquared(t))}distanceToSquared(t){const e=this.x-t.x,s=this.y-t.y;return e*e+s*s}manhattanDistanceTo(t){return Math.abs(this.x-t.x)+Math.abs(this.y-t.y)}setLength(t){return this.normalize().multiplyScalar(t)}lerp(t,e){return this.x+=(t.x-this.x)*e,this.y+=(t.y-this.y)*e,this}lerpVectors(t,e,s){return this.x=t.x+(e.x-t.x)*s,this.y=t.y+(e.y-t.y)*s,this}equals(t){return t.x===this.x&&t.y===this.y}fromArray(t,e=0){return this.x=t[e],this.y=t[e+1],this}toArray(t=[],e=0){return t[e]=this.x,t[e+1]=this.y,t}rotateAround(t,e){const s=Math.cos(e),n=Math.sin(e),r=this.x-t.x,a=this.y-t.y;return this.x=r*s-a*n+t.x,this.y=r*n+a*s+t.y,this}random(){return this.x=Math.random(),this.y=Math.random(),this}relativeEps(t=1e-7){return Math.min(v.relativeEps(this.x,t),v.relativeEps(this.y,t))}*[Symbol.iterator](){yield this.x,yield this.y}};Sn.EMPTY=Object.freeze(new Sn(0,0));let Y=Sn;const En=class io{constructor(t,e,s,n,r,a,o,l,c){this.elements=[1,0,0,0,1,0,0,0,1],t!=null&&e!=null&&s!=null&&n!=null&&r!=null&&a!=null&&o!=null&&l!=null&&c!=null&&this.set(t,e,s,n,r,a,o,l,c)}set(t,e,s,n,r,a,o,l,c){const u=this.elements;return u[0]=t,u[1]=n,u[2]=o,u[3]=e,u[4]=r,u[5]=l,u[6]=s,u[7]=a,u[8]=c,this}identity(){return this.set(1,0,0,0,1,0,0,0,1),this}copy(t){const e=this.elements,s=t.elements;return e[0]=s[0],e[1]=s[1],e[2]=s[2],e[3]=s[3],e[4]=s[4],e[5]=s[5],e[6]=s[6],e[7]=s[7],e[8]=s[8],this}extractBasis(t,e,s){return t.setFromMatrix3Column(this,0),e.setFromMatrix3Column(this,1),s.setFromMatrix3Column(this,2),this}setFromMatrix4(t){const e=t.elements;return this.set(e[0],e[4],e[8],e[1],e[5],e[9],e[2],e[6],e[10]),this}multiply(t){return this.multiplyMatrices(this,t)}premultiply(t){return this.multiplyMatrices(t,this)}multiplyMatrices(t,e){const s=t.elements,n=e.elements,r=this.elements,a=s[0],o=s[3],l=s[6],c=s[1],u=s[4],d=s[7],g=s[2],p=s[5],m=s[8],y=n[0],x=n[3],f=n[6],P=n[1],I=n[4],M=n[7],A=n[2],j=n[5],T=n[8];return r[0]=a*y+o*P+l*A,r[3]=a*x+o*I+l*j,r[6]=a*f+o*M+l*T,r[1]=c*y+u*P+d*A,r[4]=c*x+u*I+d*j,r[7]=c*f+u*M+d*T,r[2]=g*y+p*P+m*A,r[5]=g*x+p*I+m*j,r[8]=g*f+p*M+m*T,this}multiplyScalar(t){const e=this.elements;return e[0]*=t,e[3]*=t,e[6]*=t,e[1]*=t,e[4]*=t,e[7]*=t,e[2]*=t,e[5]*=t,e[8]*=t,this}determinant(){const t=this.elements,e=t[0],s=t[1],n=t[2],r=t[3],a=t[4],o=t[5],l=t[6],c=t[7],u=t[8];return e*a*u-e*o*c-s*r*u+s*o*l+n*r*c-n*a*l}invert(){const t=this.elements,e=t[0],s=t[1],n=t[2],r=t[3],a=t[4],o=t[5],l=t[6],c=t[7],u=t[8],d=u*a-o*c,g=o*l-u*r,p=c*r-a*l,m=e*d+s*g+n*p;if(m===0)return this.set(0,0,0,0,0,0,0,0,0);const y=1/m;return t[0]=d*y,t[1]=(n*c-u*s)*y,t[2]=(o*s-n*a)*y,t[3]=g*y,t[4]=(u*e-n*l)*y,t[5]=(n*r-o*e)*y,t[6]=p*y,t[7]=(s*l-c*e)*y,t[8]=(a*e-s*r)*y,this}transpose(){let t;const e=this.elements;return t=e[1],e[1]=e[3],e[3]=t,t=e[2],e[2]=e[6],e[6]=t,t=e[5],e[5]=e[7],e[7]=t,this}getNormalMatrix(t){return this.setFromMatrix4(t).invert().transpose()}transposeIntoArray(t){const e=this.elements;return t.elements[0]=e[0],t.elements[1]=e[3],t.elements[2]=e[6],t.elements[3]=e[1],t.elements[4]=e[4],t.elements[5]=e[7],t.elements[6]=e[2],t.elements[7]=e[5],t.elements[8]=e[8],this}setUvTransform(t,e,s,n,r,a,o){const l=Math.cos(r),c=Math.sin(r);return this.set(s*l,s*c,-s*(l*a+c*o)+a+t,-n*c,n*l,-n*(-c*a+l*o)+o+e,0,0,1),this}scale(t,e){return this.premultiply(rn.makeScale(t,e)),this}rotate(t){return this.premultiply(rn.makeRotation(-t)),this}translate(t,e){return this.premultiply(rn.makeTranslation(t,e)),this}makeTranslation(t,e){return t instanceof Y?this.set(1,0,t.x,0,1,t.y,0,0,1):this.set(1,0,t,0,1,e,0,0,1),this}makeRotation(t){const e=Math.cos(t),s=Math.sin(t);return this.set(e,-s,0,s,e,0,0,0,1),this}makeScale(t,e){return this.set(t,0,0,0,e,0,0,0,1),this}equals(t){const e=this.elements,s=t.elements;for(let n=0;n<9;n++)if(e[n]!==s[n])return!1;return!0}fromArray(t,e=0){for(let s=0;s<9;s++)this.elements[s]=t[s+e];return this}toArray(t=[],e=0){const s=this.elements;return t[e]=s[0],t[e+1]=s[1],t[e+2]=s[2],t[e+3]=s[3],t[e+4]=s[4],t[e+5]=s[5],t[e+6]=s[6],t[e+7]=s[7],t[e+8]=s[8],t}clone(){return new io().fromArray(this.elements)}};En.IDENTITY=Object.freeze(new En);let Us=En;const rn=new Us,Ve=1e-6,W=2*Math.PI,Vl={x:0,y:0},$n={x:0,y:0,z:0};class Xs{constructor(){this.equalPointTol=Ve,this.equalVectorTol=Ve}clone(){const t=new Xs;return t.equalPointTol=this.equalPointTol,t.equalVectorTol=this.equalVectorTol,t}equalPoint2d(t,e){return new Y(t).sub(e).length()<this.equalPointTol}equalPoint3d(t,e){return new b(t).sub(e).length()<this.equalPointTol}static equalToZero(t,e=Ve){return t<e&&t>-e}static equal(t,e,s=Ve){return Math.abs(t-e)<s}static great(t,e,s=Ve){return t-e>s}static less(t,e,s=Ve){return t-e<s}}const qn=new Xs;class Ue{constructor(t=0,e=0,s=0,n=1){this._x=t,this._y=e,this._z=s,this._w=n}static slerpFlat(t,e,s,n,r,a,o){let l=s[n+0],c=s[n+1],u=s[n+2],d=s[n+3];const g=r[a+0],p=r[a+1],m=r[a+2],y=r[a+3];if(o===0){t[e+0]=l,t[e+1]=c,t[e+2]=u,t[e+3]=d;return}if(o===1){t[e+0]=g,t[e+1]=p,t[e+2]=m,t[e+3]=y;return}if(d!==y||l!==g||c!==p||u!==m){let x=1-o;const f=l*g+c*p+u*m+d*y,P=f>=0?1:-1,I=1-f*f;if(I>Number.EPSILON){const A=Math.sqrt(I),j=Math.atan2(A,f*P);x=Math.sin(x*j)/A,o=Math.sin(o*j)/A}const M=o*P;if(l=l*x+g*M,c=c*x+p*M,u=u*x+m*M,d=d*x+y*M,x===1-o){const A=1/Math.sqrt(l*l+c*c+u*u+d*d);l*=A,c*=A,u*=A,d*=A}}t[e]=l,t[e+1]=c,t[e+2]=u,t[e+3]=d}static multiplyQuaternionsFlat(t,e,s,n,r,a){const o=s[n],l=s[n+1],c=s[n+2],u=s[n+3],d=r[a],g=r[a+1],p=r[a+2],m=r[a+3];return t[e]=o*m+u*d+l*p-c*g,t[e+1]=l*m+u*g+c*d-o*p,t[e+2]=c*m+u*p+o*g-l*d,t[e+3]=u*m-o*d-l*g-c*p,t}get x(){return this._x}set x(t){this._x=t,this._onChangeCallback()}get y(){return this._y}set y(t){this._y=t,this._onChangeCallback()}get z(){return this._z}set z(t){this._z=t,this._onChangeCallback()}get w(){return this._w}set w(t){this._w=t,this._onChangeCallback()}set(t,e,s,n){return this._x=t,this._y=e,this._z=s,this._w=n,this._onChangeCallback(),this}clone(){return new Ue(this._x,this._y,this._z,this._w)}copy(t){return this._x=t.x,this._y=t.y,this._z=t.z,this._w=t.w,this._onChangeCallback(),this}setFromEuler(t,e=!0){const s=t.x,n=t.y,r=t.z,a=t.order,o=Math.cos,l=Math.sin,c=o(s/2),u=o(n/2),d=o(r/2),g=l(s/2),p=l(n/2),m=l(r/2);switch(a){case"XYZ":this._x=g*u*d+c*p*m,this._y=c*p*d-g*u*m,this._z=c*u*m+g*p*d,this._w=c*u*d-g*p*m;break;case"YXZ":this._x=g*u*d+c*p*m,this._y=c*p*d-g*u*m,this._z=c*u*m-g*p*d,this._w=c*u*d+g*p*m;break;case"ZXY":this._x=g*u*d-c*p*m,this._y=c*p*d+g*u*m,this._z=c*u*m+g*p*d,this._w=c*u*d-g*p*m;break;case"ZYX":this._x=g*u*d-c*p*m,this._y=c*p*d+g*u*m,this._z=c*u*m-g*p*d,this._w=c*u*d+g*p*m;break;case"YZX":this._x=g*u*d+c*p*m,this._y=c*p*d+g*u*m,this._z=c*u*m-g*p*d,this._w=c*u*d-g*p*m;break;case"XZY":this._x=g*u*d-c*p*m,this._y=c*p*d-g*u*m,this._z=c*u*m+g*p*d,this._w=c*u*d+g*p*m;break}return e===!0&&this._onChangeCallback(),this}setFromAxisAngle(t,e){const s=e/2,n=Math.sin(s);return this._x=t.x*n,this._y=t.y*n,this._z=t.z*n,this._w=Math.cos(s),this._onChangeCallback(),this}setFromRotationMatrix(t){const e=t.elements,s=e[0],n=e[4],r=e[8],a=e[1],o=e[5],l=e[9],c=e[2],u=e[6],d=e[10],g=s+o+d;if(g>0){const p=.5/Math.sqrt(g+1);this._w=.25/p,this._x=(u-l)*p,this._y=(r-c)*p,this._z=(a-n)*p}else if(s>o&&s>d){const p=2*Math.sqrt(1+s-o-d);this._w=(u-l)/p,this._x=.25*p,this._y=(n+a)/p,this._z=(r+c)/p}else if(o>d){const p=2*Math.sqrt(1+o-s-d);this._w=(r-c)/p,this._x=(n+a)/p,this._y=.25*p,this._z=(l+u)/p}else{const p=2*Math.sqrt(1+d-s-o);this._w=(a-n)/p,this._x=(r+c)/p,this._y=(l+u)/p,this._z=.25*p}return this._onChangeCallback(),this}setFromUnitVectors(t,e){let s=t.dot(e)+1;return s<Number.EPSILON?(s=0,Math.abs(t.x)>Math.abs(t.z)?(this._x=-t.y,this._y=t.x,this._z=0,this._w=s):(this._x=0,this._y=-t.z,this._z=t.y,this._w=s)):(this._x=t.y*e.z-t.z*e.y,this._y=t.z*e.x-t.x*e.z,this._z=t.x*e.y-t.y*e.x,this._w=s),this.normalize()}angleTo(t){return 2*Math.acos(Math.abs(re(this.dot(t),-1,1)))}rotateTowards(t,e){const s=this.angleTo(t);if(s===0)return this;const n=Math.min(1,e/s);return this.slerp(t,n),this}identity(){return this.set(0,0,0,1)}invert(){return this.conjugate()}conjugate(){return this._x*=-1,this._y*=-1,this._z*=-1,this._onChangeCallback(),this}dot(t){return this._x*t._x+this._y*t._y+this._z*t._z+this._w*t._w}lengthSq(){return this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w}length(){return Math.sqrt(this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w)}normalize(){let t=this.length();return t===0?(this._x=0,this._y=0,this._z=0,this._w=1):(t=1/t,this._x=this._x*t,this._y=this._y*t,this._z=this._z*t,this._w=this._w*t),this._onChangeCallback(),this}multiply(t){return this.multiplyQuaternions(this,t)}premultiply(t){return this.multiplyQuaternions(t,this)}multiplyQuaternions(t,e){const s=t._x,n=t._y,r=t._z,a=t._w,o=e._x,l=e._y,c=e._z,u=e._w;return this._x=s*u+a*o+n*c-r*l,this._y=n*u+a*l+r*o-s*c,this._z=r*u+a*c+s*l-n*o,this._w=a*u-s*o-n*l-r*c,this._onChangeCallback(),this}slerp(t,e){if(e===0)return this;if(e===1)return this.copy(t);const s=this._x,n=this._y,r=this._z,a=this._w;let o=a*t._w+s*t._x+n*t._y+r*t._z;if(o<0?(this._w=-t._w,this._x=-t._x,this._y=-t._y,this._z=-t._z,o=-o):this.copy(t),o>=1)return this._w=a,this._x=s,this._y=n,this._z=r,this;const l=1-o*o;if(l<=Number.EPSILON){const p=1-e;return this._w=p*a+e*this._w,this._x=p*s+e*this._x,this._y=p*n+e*this._y,this._z=p*r+e*this._z,this.normalize(),this}const c=Math.sqrt(l),u=Math.atan2(c,o),d=Math.sin((1-e)*u)/c,g=Math.sin(e*u)/c;return this._w=a*d+this._w*g,this._x=s*d+this._x*g,this._y=n*d+this._y*g,this._z=r*d+this._z*g,this._onChangeCallback(),this}slerpQuaternions(t,e,s){return this.copy(t).slerp(e,s)}random(){const t=2*Math.PI*Math.random(),e=2*Math.PI*Math.random(),s=Math.random(),n=Math.sqrt(1-s),r=Math.sqrt(s);return this.set(n*Math.sin(t),n*Math.cos(t),r*Math.sin(e),r*Math.cos(e))}equals(t){return t._x===this._x&&t._y===this._y&&t._z===this._z&&t._w===this._w}fromArray(t,e=0){return this._x=t[e],this._y=t[e+1],this._z=t[e+2],this._w=t[e+3],this._onChangeCallback(),this}toArray(t=[],e=0){return t[e]=this._x,t[e+1]=this._y,t[e+2]=this._z,t[e+3]=this._w,t}toJSON(){return this.toArray()}_onChange(t){return this._onChangeCallback=t,this}_onChangeCallback(){}*[Symbol.iterator](){yield this._x,yield this._y,yield this._z,yield this._w}}const dt=class no{constructor(t,e,s){this.x=0,this.y=0,this.z=0;const n=+(t!==void 0)+ +(e!==void 0)+ +(s!==void 0);if(n!==0){if(n===1&&t instanceof Array){this.x=t[0],this.y=t[1],this.z=t[2];return}if(n===1){const{x:r,y:a,z:o}=t;this.x=r,this.y=a,this.z=o||0;return}if(n===3){this.x=t,this.y=e,this.z=s;return}throw yt.ILLEGAL_PARAMETERS}}set(t,e,s){return s===void 0&&(s=this.z),this.x=t,this.y=e,this.z=s,this}setScalar(t){return this.x=t,this.y=t,this.z=t,this}setX(t){return this.x=t,this}setY(t){return this.y=t,this}setZ(t){return this.z=t,this}setComponent(t,e){switch(t){case 0:this.x=e;break;case 1:this.y=e;break;case 2:this.z=e;break;default:throw new Error("index is out of range: "+t)}return this}getComponent(t){switch(t){case 0:return this.x;case 1:return this.y;case 2:return this.z;default:throw new Error("index is out of range: "+t)}}clone(){return new no(this.x,this.y,this.z)}copy(t){return this.x=t.x,this.y=t.y,this.z=t.z||0,this}add(t){return this.x+=t.x,this.y+=t.y,this.z+=t.z||0,this}addScalar(t){return this.x+=t,this.y+=t,this.z+=t,this}addVectors(t,e){return this.x=t.x+e.x,this.y=t.y+e.y,this.z=t.z+e.z,this}addScaledVector(t,e){return this.x+=t.x*e,this.y+=t.y*e,this.z+=t.z*e,this}sub(t){return this.x-=t.x,this.y-=t.y,this.z-=t.z,this}subScalar(t){return this.x-=t,this.y-=t,this.z-=t,this}subVectors(t,e){return this.x=t.x-e.x,this.y=t.y-e.y,this.z=t.z-e.z,this}multiply(t){return this.x*=t.x,this.y*=t.y,this.z*=t.z,this}multiplyScalar(t){return this.x*=t,this.y*=t,this.z*=t,this}multiplyVectors(t,e){return this.x=t.x*e.x,this.y=t.y*e.y,this.z=t.z*e.z,this}applyEuler(t){return this.applyQuaternion(ta.setFromEuler(t))}applyAxisAngle(t,e){return this.applyQuaternion(ta.setFromAxisAngle(t,e))}applyMatrix3(t){const e=this.x,s=this.y,n=this.z,r=t.elements;return this.x=r[0]*e+r[3]*s+r[6]*n,this.y=r[1]*e+r[4]*s+r[7]*n,this.z=r[2]*e+r[5]*s+r[8]*n,this}applyNormalMatrix(t){return this.applyMatrix3(t).normalize()}applyMatrix4(t){const e=this.x,s=this.y,n=this.z,r=t.elements,a=1/(r[3]*e+r[7]*s+r[11]*n+r[15]);return this.x=(r[0]*e+r[4]*s+r[8]*n+r[12])*a,this.y=(r[1]*e+r[5]*s+r[9]*n+r[13])*a,this.z=(r[2]*e+r[6]*s+r[10]*n+r[14])*a,this}applyQuaternion(t){const e=this.x,s=this.y,n=this.z,r=t.x,a=t.y,o=t.z,l=t.w,c=2*(a*n-o*s),u=2*(o*e-r*n),d=2*(r*s-a*e);return this.x=e+l*c+a*d-o*u,this.y=s+l*u+o*c-r*d,this.z=n+l*d+r*u-a*c,this}transformDirection(t){const e=this.x,s=this.y,n=this.z,r=t.elements;return this.x=r[0]*e+r[4]*s+r[8]*n,this.y=r[1]*e+r[5]*s+r[9]*n,this.z=r[2]*e+r[6]*s+r[10]*n,this.normalize()}divide(t){return this.x/=t.x,this.y/=t.y,this.z/=t.z,this}divideScalar(t){return this.multiplyScalar(1/t)}min(t){return this.x=Math.min(this.x,t.x),this.y=Math.min(this.y,t.y),this.z=Math.min(this.z,t.z),this}max(t){return this.x=Math.max(this.x,t.x),this.y=Math.max(this.y,t.y),this.z=Math.max(this.z,t.z),this}clamp(t,e){return this.x=Math.max(t.x,Math.min(e.x,this.x)),this.y=Math.max(t.y,Math.min(e.y,this.y)),this.z=Math.max(t.z,Math.min(e.z,this.z)),this}clampScalar(t,e){return this.x=Math.max(t,Math.min(e,this.x)),this.y=Math.max(t,Math.min(e,this.y)),this.z=Math.max(t,Math.min(e,this.z)),this}clampLength(t,e){const s=this.length();return this.divideScalar(s||1).multiplyScalar(Math.max(t,Math.min(e,s)))}floor(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this.z=Math.floor(this.z),this}ceil(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this.z=Math.ceil(this.z),this}round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this.z=Math.round(this.z),this}roundToZero(){return this.x=Math.trunc(this.x),this.y=Math.trunc(this.y),this.z=Math.trunc(this.z),this}negate(){return this.x=-this.x,this.y=-this.y,this.z=-this.z,this}dot(t){return this.x*t.x+this.y*t.y+this.z*t.z}isParallelTo(t){const e=this.dot(t),s=this.length(),n=t.length();return Math.abs(e)===s*n}lengthSq(){return this.x*this.x+this.y*this.y+this.z*this.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}manhattanLength(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z)}normalize(){return this.divideScalar(this.length()||1)}setLength(t){return this.normalize().multiplyScalar(t)}lerp(t,e){return this.x+=(t.x-this.x)*e,this.y+=(t.y-this.y)*e,this.z+=(t.z-this.z)*e,this}lerpVectors(t,e,s){return this.x=t.x+(e.x-t.x)*s,this.y=t.y+(e.y-t.y)*s,this.z=t.z+(e.z-t.z)*s,this}cross(t){return this.crossVectors(this,t)}crossVectors(t,e){const s=t.x,n=t.y,r=t.z,a=e.x,o=e.y,l=e.z;return this.x=n*l-r*o,this.y=r*a-s*l,this.z=s*o-n*a,this}projectOnVector(t){const e=t.lengthSq();if(e===0)return this.set(0,0,0);const s=t.dot(this)/e;return this.copy(t).multiplyScalar(s)}projectOnPlane(t){return an.copy(this).projectOnVector(t),this.sub(an)}reflect(t){return this.sub(an.copy(t).multiplyScalar(2*this.dot(t)))}angleTo(t){const e=Math.sqrt(this.lengthSq()*t.lengthSq());if(e===0)return Math.PI/2;const s=this.dot(t)/e;return Math.acos(Math.max(-1,Math.min(1,s)))}distanceTo(t){return Math.sqrt(this.distanceToSquared(t))}distanceToSquared(t){const e=this.x-t.x,s=this.y-t.y,n=this.z-t.z;return e*e+s*s+n*n}manhattanDistanceTo(t){return Math.abs(this.x-t.x)+Math.abs(this.y-t.y)+Math.abs(this.z-t.z)}setFromMatrixPosition(t){const e=t.elements;return this.x=e[12],this.y=e[13],this.z=e[14],this}setFromMatrixScale(t){const e=this.setFromMatrixColumn(t,0).length(),s=this.setFromMatrixColumn(t,1).length(),n=this.setFromMatrixColumn(t,2).length();return this.x=e,this.y=s,this.z=n,this}setFromMatrixColumn(t,e){return this.fromArray(t.elements,e*4)}setFromMatrix3Column(t,e){return this.fromArray(t.elements,e*3)}equals(t){return t.x===this.x&&t.y===this.y&&t.z===this.z}fromArray(t,e=0){return this.x=t[e],this.y=t[e+1],this.z=t[e+2],this}toArray(t=[],e=0){return t[e]=this.x,t[e+1]=this.y,t[e+2]=this.z,t}random(){return this.x=Math.random(),this.y=Math.random(),this.z=Math.random(),this}randomDirection(){const t=Math.random()*Math.PI*2,e=Math.random()*2-1,s=Math.sqrt(1-e*e);return this.x=s*Math.cos(t),this.y=e,this.z=s*Math.sin(t),this}*[Symbol.iterator](){yield this.x,yield this.y,yield this.z}};dt.ORIGIN=Object.freeze(new dt(0,0,0)),dt.X_AXIS=Object.freeze(new dt(1,0,0)),dt.NEGATIVE_X_AXIS=Object.freeze(new dt(-1,0,0)),dt.Y_AXIS=Object.freeze(new dt(0,1,0)),dt.NEGATIVE_Y_AXIS=Object.freeze(new dt(0,-1,0)),dt.Z_AXIS=Object.freeze(new dt(0,0,1)),dt.NEGATIVE_Z_AXIS=Object.freeze(new dt(0,0,-1));let b=dt;const an=new b,ta=new Ue,An=class ro{constructor(t,e,s,n,r,a,o,l,c,u,d,g,p,m,y,x){this.elements=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1],t!=null&&e!=null&&s!=null&&n!=null&&r!=null&&a!=null&&o!=null&&l!=null&&c!=null&&u!=null&&d!=null&&g!=null&&p!=null&&m!=null&&y!=null&&x!=null&&this.set(t,e,s,n,r,a,o,l,c,u,d,g,p,m,y,x)}set(t,e,s,n,r,a,o,l,c,u,d,g,p,m,y,x){const f=this.elements;return f[0]=t,f[4]=e,f[8]=s,f[12]=n,f[1]=r,f[5]=a,f[9]=o,f[13]=l,f[2]=c,f[6]=u,f[10]=d,f[14]=g,f[3]=p,f[7]=m,f[11]=y,f[15]=x,this}identity(){return this.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1),this}clone(){return new ro().fromArray(this.elements)}copy(t){const e=this.elements,s=t.elements;return e[0]=s[0],e[1]=s[1],e[2]=s[2],e[3]=s[3],e[4]=s[4],e[5]=s[5],e[6]=s[6],e[7]=s[7],e[8]=s[8],e[9]=s[9],e[10]=s[10],e[11]=s[11],e[12]=s[12],e[13]=s[13],e[14]=s[14],e[15]=s[15],this}copyPosition(t){const e=this.elements,s=t.elements;return e[12]=s[12],e[13]=s[13],e[14]=s[14],this}setFromMatrix3(t){const e=t.elements;return this.set(e[0],e[3],e[6],0,e[1],e[4],e[7],0,e[2],e[5],e[8],0,0,0,0,1),this}setFromExtrusionDirection(t){if(qn.equalPoint3d(t,b.Z_AXIS))this.identity();else{const e=new b(1,0,0);Math.abs(t.x)<1/64&&Math.abs(t.y)<1/64?e.crossVectors(b.Y_AXIS,t).normalize():e.crossVectors(b.Z_AXIS,t).normalize();const s=t.clone().cross(e).normalize();this.set(e.x,e.y,e.z,0,s.x,s.y,s.z,0,t.x,t.y,t.z,0,0,0,0,1)}return this}extractBasis(t,e,s){return t.setFromMatrixColumn(this,0),e.setFromMatrixColumn(this,1),s.setFromMatrixColumn(this,2),this}makeBasis(t,e,s){return this.set(t.x,e.x,s.x,0,t.y,e.y,s.y,0,t.z,e.z,s.z,0,0,0,0,1),this}extractRotation(t){const e=this.elements,s=t.elements,n=1/Xe.setFromMatrixColumn(t,0).length(),r=1/Xe.setFromMatrixColumn(t,1).length(),a=1/Xe.setFromMatrixColumn(t,2).length();return e[0]=s[0]*n,e[1]=s[1]*n,e[2]=s[2]*n,e[3]=0,e[4]=s[4]*r,e[5]=s[5]*r,e[6]=s[6]*r,e[7]=0,e[8]=s[8]*a,e[9]=s[9]*a,e[10]=s[10]*a,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,this}makeRotationFromQuaternion(t){return this.compose(Dl,t,jl)}lookAt(t,e,s){const n=this.elements;return _t.subVectors(t,e),_t.lengthSq()===0&&(_t.z=1),_t.normalize(),de.crossVectors(s,_t),de.lengthSq()===0&&(Math.abs(s.z)===1?_t.x+=1e-4:_t.z+=1e-4,_t.normalize(),de.crossVectors(s,_t)),de.normalize(),ai.crossVectors(_t,de),n[0]=de.x,n[4]=ai.x,n[8]=_t.x,n[1]=de.y,n[5]=ai.y,n[9]=_t.y,n[2]=de.z,n[6]=ai.z,n[10]=_t.z,this}multiply(t){return this.multiplyMatrices(this,t)}premultiply(t){return this.multiplyMatrices(t,this)}multiplyMatrices(t,e){const s=t.elements,n=e.elements,r=this.elements,a=s[0],o=s[4],l=s[8],c=s[12],u=s[1],d=s[5],g=s[9],p=s[13],m=s[2],y=s[6],x=s[10],f=s[14],P=s[3],I=s[7],M=s[11],A=s[15],j=n[0],T=n[4],X=n[8],B=n[12],et=n[1],F=n[5],U=n[9],fe=n[13],be=n[2],Qs=n[6],Js=n[10],ti=n[14],ei=n[3],si=n[7],ii=n[11],ni=n[15];return r[0]=a*j+o*et+l*be+c*ei,r[4]=a*T+o*F+l*Qs+c*si,r[8]=a*X+o*U+l*Js+c*ii,r[12]=a*B+o*fe+l*ti+c*ni,r[1]=u*j+d*et+g*be+p*ei,r[5]=u*T+d*F+g*Qs+p*si,r[9]=u*X+d*U+g*Js+p*ii,r[13]=u*B+d*fe+g*ti+p*ni,r[2]=m*j+y*et+x*be+f*ei,r[6]=m*T+y*F+x*Qs+f*si,r[10]=m*X+y*U+x*Js+f*ii,r[14]=m*B+y*fe+x*ti+f*ni,r[3]=P*j+I*et+M*be+A*ei,r[7]=P*T+I*F+M*Qs+A*si,r[11]=P*X+I*U+M*Js+A*ii,r[15]=P*B+I*fe+M*ti+A*ni,this}multiplyScalar(t){const e=this.elements;return e[0]*=t,e[4]*=t,e[8]*=t,e[12]*=t,e[1]*=t,e[5]*=t,e[9]*=t,e[13]*=t,e[2]*=t,e[6]*=t,e[10]*=t,e[14]*=t,e[3]*=t,e[7]*=t,e[11]*=t,e[15]*=t,this}determinant(){const t=this.elements,e=t[0],s=t[4],n=t[8],r=t[12],a=t[1],o=t[5],l=t[9],c=t[13],u=t[2],d=t[6],g=t[10],p=t[14],m=t[3],y=t[7],x=t[11],f=t[15];return m*(+r*l*d-n*c*d-r*o*g+s*c*g+n*o*p-s*l*p)+y*(+e*l*p-e*c*g+r*a*g-n*a*p+n*c*u-r*l*u)+x*(+e*c*d-e*o*p-r*a*d+s*a*p+r*o*u-s*c*u)+f*(-n*o*u-e*l*d+e*o*g+n*a*d-s*a*g+s*l*u)}transpose(){const t=this.elements;let e;return e=t[1],t[1]=t[4],t[4]=e,e=t[2],t[2]=t[8],t[8]=e,e=t[6],t[6]=t[9],t[9]=e,e=t[3],t[3]=t[12],t[12]=e,e=t[7],t[7]=t[13],t[13]=e,e=t[11],t[11]=t[14],t[14]=e,this}setPosition(t,e,s){const n=this.elements;return t instanceof b?(n[12]=t.x,n[13]=t.y,n[14]=t.z):(n[12]=t,n[13]=e,n[14]=s),this}invert(){const t=this.elements,e=t[0],s=t[1],n=t[2],r=t[3],a=t[4],o=t[5],l=t[6],c=t[7],u=t[8],d=t[9],g=t[10],p=t[11],m=t[12],y=t[13],x=t[14],f=t[15],P=d*x*c-y*g*c+y*l*p-o*x*p-d*l*f+o*g*f,I=m*g*c-u*x*c-m*l*p+a*x*p+u*l*f-a*g*f,M=u*y*c-m*d*c+m*o*p-a*y*p-u*o*f+a*d*f,A=m*d*l-u*y*l-m*o*g+a*y*g+u*o*x-a*d*x,j=e*P+s*I+n*M+r*A;if(j===0)return this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0);const T=1/j;return t[0]=P*T,t[1]=(y*g*r-d*x*r-y*n*p+s*x*p+d*n*f-s*g*f)*T,t[2]=(o*x*r-y*l*r+y*n*c-s*x*c-o*n*f+s*l*f)*T,t[3]=(d*l*r-o*g*r-d*n*c+s*g*c+o*n*p-s*l*p)*T,t[4]=I*T,t[5]=(u*x*r-m*g*r+m*n*p-e*x*p-u*n*f+e*g*f)*T,t[6]=(m*l*r-a*x*r-m*n*c+e*x*c+a*n*f-e*l*f)*T,t[7]=(a*g*r-u*l*r+u*n*c-e*g*c-a*n*p+e*l*p)*T,t[8]=M*T,t[9]=(m*d*r-u*y*r-m*s*p+e*y*p+u*s*f-e*d*f)*T,t[10]=(a*y*r-m*o*r+m*s*c-e*y*c-a*s*f+e*o*f)*T,t[11]=(u*o*r-a*d*r-u*s*c+e*d*c+a*s*p-e*o*p)*T,t[12]=A*T,t[13]=(u*y*n-m*d*n+m*s*g-e*y*g-u*s*x+e*d*x)*T,t[14]=(m*o*n-a*y*n-m*s*l+e*y*l+a*s*x-e*o*x)*T,t[15]=(a*d*n-u*o*n+u*s*l-e*d*l-a*s*g+e*o*g)*T,this}scale(t){const e=this.elements,s=t.x,n=t.y,r=t.z;return e[0]*=s,e[4]*=n,e[8]*=r,e[1]*=s,e[5]*=n,e[9]*=r,e[2]*=s,e[6]*=n,e[10]*=r,e[3]*=s,e[7]*=n,e[11]*=r,this}getMaxScaleOnAxis(){const t=this.elements,e=t[0]*t[0]+t[1]*t[1]+t[2]*t[2],s=t[4]*t[4]+t[5]*t[5]+t[6]*t[6],n=t[8]*t[8]+t[9]*t[9]+t[10]*t[10];return Math.sqrt(Math.max(e,s,n))}makeTranslation(t,e,s){return t instanceof b?this.set(1,0,0,t.x,0,1,0,t.y,0,0,1,t.z,0,0,0,1):this.set(1,0,0,t,0,1,0,e,0,0,1,s,0,0,0,1),this}makeRotationX(t){const e=Math.cos(t),s=Math.sin(t);return this.set(1,0,0,0,0,e,-s,0,0,s,e,0,0,0,0,1),this}makeRotationY(t){const e=Math.cos(t),s=Math.sin(t);return this.set(e,0,s,0,0,1,0,0,-s,0,e,0,0,0,0,1),this}makeRotationZ(t){const e=Math.cos(t),s=Math.sin(t);return this.set(e,-s,0,0,s,e,0,0,0,0,1,0,0,0,0,1),this}makeRotationAxis(t,e){const s=Math.cos(e),n=Math.sin(e),r=1-s,a=t.x,o=t.y,l=t.z,c=r*a,u=r*o;return this.set(c*a+s,c*o-n*l,c*l+n*o,0,c*o+n*l,u*o+s,u*l-n*a,0,c*l-n*o,u*l+n*a,r*l*l+s,0,0,0,0,1),this}makeScale(t,e,s){return this.set(t,0,0,0,0,e,0,0,0,0,s,0,0,0,0,1),this}makeShear(t,e,s,n,r,a){return this.set(1,s,r,0,t,1,a,0,e,n,1,0,0,0,0,1),this}compose(t,e,s){const n=this.elements,r=e.x,a=e.y,o=e.z,l=e.w,c=r+r,u=a+a,d=o+o,g=r*c,p=r*u,m=r*d,y=a*u,x=a*d,f=o*d,P=l*c,I=l*u,M=l*d,A=s.x,j=s.y,T=s.z;return n[0]=(1-(y+f))*A,n[1]=(p+M)*A,n[2]=(m-I)*A,n[3]=0,n[4]=(p-M)*j,n[5]=(1-(g+f))*j,n[6]=(x+P)*j,n[7]=0,n[8]=(m+I)*T,n[9]=(x-P)*T,n[10]=(1-(g+y))*T,n[11]=0,n[12]=t.x,n[13]=t.y,n[14]=t.z,n[15]=1,this}decompose(t,e,s){const n=this.elements;let r=Xe.set(n[0],n[1],n[2]).length();const a=Xe.set(n[4],n[5],n[6]).length(),o=Xe.set(n[8],n[9],n[10]).length();this.determinant()<0&&(r=-r),t.x=n[12],t.y=n[13],t.z=n[14],kt.copy(this);const l=1/r,c=1/a,u=1/o;return kt.elements[0]*=l,kt.elements[1]*=l,kt.elements[2]*=l,kt.elements[4]*=c,kt.elements[5]*=c,kt.elements[6]*=c,kt.elements[8]*=u,kt.elements[9]*=u,kt.elements[10]*=u,e.setFromRotationMatrix(kt),s.x=r,s.y=a,s.z=o,this}equals(t){const e=this.elements,s=t.elements;for(let n=0;n<16;n++)if(e[n]!==s[n])return!1;return!0}fromArray(t,e=0){for(let s=0;s<16;s++)this.elements[s]=t[s+e];return this}toArray(t=[],e=0){const s=this.elements;return t[e]=s[0],t[e+1]=s[1],t[e+2]=s[2],t[e+3]=s[3],t[e+4]=s[4],t[e+5]=s[5],t[e+6]=s[6],t[e+7]=s[7],t[e+8]=s[8],t[e+9]=s[9],t[e+10]=s[10],t[e+11]=s[11],t[e+12]=s[12],t[e+13]=s[13],t[e+14]=s[14],t[e+15]=s[15],t}};An.IDENTITY=Object.freeze(new An);let G=An;const Xe=new b,kt=new G,Dl=new b(0,0,0),jl=new b(1,1,1),de=new b,ai=new b,_t=new b;let C=class ao{constructor(t=void 0,e=void 0){this.min=t==null?new b(1/0,1/0,1/0):new b(t.x,t.y,t.z),this.max=e==null?new b(-1/0,-1/0,-1/0):new b(e.x,e.y,e.z)}set(t,e){return this.min.copy(t),this.max.copy(e),this}setFromArray(t){this.makeEmpty();for(let e=0,s=t.length;e<s;e+=3)this.expandByPoint(on.fromArray(t,e));return this}setFromPoints(t){this.makeEmpty();for(let e=0,s=t.length;e<s;e++)this.expandByPoint(t[e]);return this}setFromCenterAndSize(t,e){const s=on.copy(e).multiplyScalar(.5);return this.min.copy(t).sub(s),this.max.copy(t).add(s),this}clone(){return new ao().copy(this)}copy(t){return this.min.copy(t.min),this.max.copy(t.max),this}makeEmpty(){return this.min.x=this.min.y=this.min.z=1/0,this.max.x=this.max.y=this.max.z=-1/0,this}isEmpty(){return this.max.x<this.min.x||this.max.y<this.min.y||this.max.z<this.min.z}getCenter(t){return this.isEmpty()?t.set(0,0,0):t.addVectors(this.min,this.max).multiplyScalar(.5)}getSize(t){return this.isEmpty()?t.set(0,0,0):t.subVectors(this.max,this.min)}get center(){return this.isEmpty()?new b(0,0,0):new b(0,0,0).addVectors(this.min,this.max).multiplyScalar(.5)}get size(){return this.isEmpty()?new b(0,0,0):new b(0,0,0).subVectors(this.max,this.min)}expandByPoint(t){return this.min.min(t),this.max.max(t),this}expandByVector(t){return this.min.sub(t),this.max.add(t),this}expandByScalar(t){return this.min.addScalar(-t),this.max.addScalar(t),this}containsPoint(t){return!(t.x<this.min.x||t.x>this.max.x||t.y<this.min.y||t.y>this.max.y||t.z<this.min.z||t.z>this.max.z)}containsBox(t){return this.min.x<=t.min.x&&t.max.x<=this.max.x&&this.min.y<=t.min.y&&t.max.y<=this.max.y&&this.min.z<=t.min.z&&t.max.z<=this.max.z}getParameter(t,e){return e.set((t.x-this.min.x)/(this.max.x-this.min.x),(t.y-this.min.y)/(this.max.y-this.min.y),(t.z-this.min.z)/(this.max.z-this.min.z))}intersectsBox(t){return!(t.max.x<this.min.x||t.min.x>this.max.x||t.max.y<this.min.y||t.min.y>this.max.y||t.max.z<this.min.z||t.min.z>this.max.z)}intersectsPlane(t){let e,s;return t.normal.x>0?(e=t.normal.x*this.min.x,s=t.normal.x*this.max.x):(e=t.normal.x*this.max.x,s=t.normal.x*this.min.x),t.normal.y>0?(e+=t.normal.y*this.min.y,s+=t.normal.y*this.max.y):(e+=t.normal.y*this.max.y,s+=t.normal.y*this.min.y),t.normal.z>0?(e+=t.normal.z*this.min.z,s+=t.normal.z*this.max.z):(e+=t.normal.z*this.max.z,s+=t.normal.z*this.min.z),e<=-t.constant&&s>=-t.constant}clampPoint(t,e){return e.copy(t).clamp(this.min,this.max)}distanceToPoint(t){return this.clampPoint(t,on).distanceTo(t)}intersect(t){return this.min.max(t.min),this.max.min(t.max),this.isEmpty()&&this.makeEmpty(),this}union(t){return this.min.min(t.min),this.max.max(t.max),this}applyMatrix4(t){return this.isEmpty()?this:(Wt[0].set(this.min.x,this.min.y,this.min.z).applyMatrix4(t),Wt[1].set(this.min.x,this.min.y,this.max.z).applyMatrix4(t),Wt[2].set(this.min.x,this.max.y,this.min.z).applyMatrix4(t),Wt[3].set(this.min.x,this.max.y,this.max.z).applyMatrix4(t),Wt[4].set(this.max.x,this.min.y,this.min.z).applyMatrix4(t),Wt[5].set(this.max.x,this.min.y,this.max.z).applyMatrix4(t),Wt[6].set(this.max.x,this.max.y,this.min.z).applyMatrix4(t),Wt[7].set(this.max.x,this.max.y,this.max.z).applyMatrix4(t),this.setFromPoints(Wt),this)}translate(t){return this.min.add(t),this.max.add(t),this}equals(t){return t.min.equals(this.min)&&t.max.equals(this.max)}};const Wt=[new b,new b,new b,new b,new b,new b,new b,new b],on=new b,ea=new Y;let pt=class oo{constructor(t=void 0,e=void 0){this.min=t==null?new Y(1/0,1/0):new Y(t.x,t.y),this.max=e==null?new Y(-1/0,-1/0):new Y(e.x,e.y)}set(t,e){return this.min.copy(t),this.max.copy(e),this}setFromPoints(t){this.makeEmpty();for(let e=0,s=t.length;e<s;e++)this.expandByPoint(t[e]);return this}setFromCenterAndSize(t,e){const s=ea.copy(e).multiplyScalar(.5);return this.min.copy(t).sub(s),this.max.copy(t).add(s),this}clone(){return new oo().copy(this)}copy(t){return this.min.copy(t.min),this.max.copy(t.max),this}makeEmpty(){return this.min.x=this.min.y=1/0,this.max.x=this.max.y=-1/0,this}isEmpty(){return this.max.x<this.min.x||this.max.y<this.min.y}getCenter(t){return this.isEmpty()?t.set(0,0):t.addVectors(this.min,this.max).multiplyScalar(.5)}getSize(t){return this.isEmpty()?t.set(0,0):t.subVectors(this.max,this.min)}get center(){return this.isEmpty()?new Y(0,0):new Y(0,0).addVectors(this.min,this.max).multiplyScalar(.5)}get size(){return this.isEmpty()?new Y(0,0):new Y(0,0).subVectors(this.max,this.min)}expandByPoint(t){return this.min.min(t),this.max.max(t),this}expandByVector(t){return this.min.sub(t),this.max.add(t),this}expandByScalar(t){return this.min.addScalar(-t),this.max.addScalar(t),this}containsPoint(t){return!(t.x<this.min.x||t.x>this.max.x||t.y<this.min.y||t.y>this.max.y)}containsBox(t){return this.min.x<=t.min.x&&t.max.x<=this.max.x&&this.min.y<=t.min.y&&t.max.y<=this.max.y}getParameter(t,e){return e.set((t.x-this.min.x)/(this.max.x-this.min.x),(t.y-this.min.y)/(this.max.y-this.min.y))}intersectsBox(t){return!(t.max.x<this.min.x||t.min.x>this.max.x||t.max.y<this.min.y||t.min.y>this.max.y)}clampPoint(t,e){return e.copy(t).clamp(this.min,this.max)}distanceToPoint(t){return this.clampPoint(t,ea).distanceTo(t)}intersect(t){return this.min.max(t.min),this.max.min(t.max),this.isEmpty()&&this.makeEmpty(),this}union(t){return this.min.min(t.min),this.max.max(t.max),this}translate(t){return this.min.add(t),this.max.add(t),this}equals(t){return t.min.equals(this.min)&&t.max.equals(this.max)}};const sa=new b,Wl=new b,Gl=new Us;class Ys{constructor(t=new b(1,0,0),e=0){this.normal=t,this.constant=e}set(t,e){return this.normal.copy(t),this.constant=e,this}setComponents(t,e,s,n){return this.normal.set(t,e,s),this.constant=n,this}setFromNormalAndCoplanarPoint(t,e){return this.normal.copy(t),this.constant=-e.dot(this.normal),this}setFromCoplanarPoints(t,e,s){const n=sa.subVectors(s,e).cross(Wl.subVectors(t,e)).normalize();return this.setFromNormalAndCoplanarPoint(n,t),this}copy(t){return this.normal.copy(t.normal),this.constant=t.constant,this}normalize(){const t=1/this.normal.length();return this.normal.multiplyScalar(t),this.constant*=t,this}negate(){return this.constant*=-1,this.normal.negate(),this}distanceToPoint(t){return this.normal.dot(t)+this.constant}projectPoint(t,e){return e.copy(t).addScaledVector(this.normal,-this.distanceToPoint(t))}intersectsBox(t){return t.intersectsPlane(this)}coplanarPoint(t){return t.copy(this.normal).multiplyScalar(-this.constant)}applyMatrix4(t,e){const s=e||Gl.getNormalMatrix(t),n=this.coplanarPoint(sa).applyMatrix4(t),r=this.normal.applyMatrix3(s).normalize();return this.constant=-n.dot(r),this}translate(t){return this.constant-=t.dot(this.normal),this}equals(t){return t.normal.equals(this.normal)&&t.constant===this.constant}clone(){return new Ys().copy(this)}}let k=class ho extends Y{clone(){return new ho(this.x,this.y)}static pointArrayToNumberArray(t){const e=new Array(t.length*2);return t.forEach((s,n)=>{s.toArray(e,n*2)}),e}},w=class lo extends b{clone(){return new lo(this.x,this.y,this.z)}static pointArrayToNumberArray(t,e=!0){const s=e?3:2,n=new Array(t.length*s);return t.forEach((r,a)=>{r.toArray(n,a*s)}),n}};const ia=new G,na=new Ue,co=class Tn{constructor(t=0,e=0,s=0,n=Tn.DEFAULT_ORDER){this._x=t,this._y=e,this._z=s,this._order=n}get x(){return this._x}set x(t){this._x=t,this._onChangeCallback()}get y(){return this._y}set y(t){this._y=t,this._onChangeCallback()}get z(){return this._z}set z(t){this._z=t,this._onChangeCallback()}get order(){return this._order}set order(t){this._order=t,this._onChangeCallback()}set(t,e,s,n=this._order){return this._x=t,this._y=e,this._z=s,this._order=n,this._onChangeCallback(),this}clone(){return new Tn(this._x,this._y,this._z,this._order)}copy(t){return this._x=t._x,this._y=t._y,this._z=t._z,this._order=t._order,this._onChangeCallback(),this}setFromRotationMatrix(t,e=this._order,s=!0){const n=t.elements,r=n[0],a=n[4],o=n[8],l=n[1],c=n[5],u=n[9],d=n[2],g=n[6],p=n[10];switch(e){case"XYZ":this._y=Math.asin(re(o,-1,1)),Math.abs(o)<.9999999?(this._x=Math.atan2(-u,p),this._z=Math.atan2(-a,r)):(this._x=Math.atan2(g,c),this._z=0);break;case"YXZ":this._x=Math.asin(-re(u,-1,1)),Math.abs(u)<.9999999?(this._y=Math.atan2(o,p),this._z=Math.atan2(l,c)):(this._y=Math.atan2(-d,r),this._z=0);break;case"ZXY":this._x=Math.asin(re(g,-1,1)),Math.abs(g)<.9999999?(this._y=Math.atan2(-d,p),this._z=Math.atan2(-a,c)):(this._y=0,this._z=Math.atan2(l,r));break;case"ZYX":this._y=Math.asin(-re(d,-1,1)),Math.abs(d)<.9999999?(this._x=Math.atan2(g,p),this._z=Math.atan2(l,r)):(this._x=0,this._z=Math.atan2(-a,c));break;case"YZX":this._z=Math.asin(re(l,-1,1)),Math.abs(l)<.9999999?(this._x=Math.atan2(-u,c),this._y=Math.atan2(-d,r)):(this._x=0,this._y=Math.atan2(o,p));break;case"XZY":this._z=Math.asin(-re(a,-1,1)),Math.abs(a)<.9999999?(this._x=Math.atan2(g,c),this._y=Math.atan2(o,r)):(this._x=Math.atan2(-u,p),this._y=0);break}return this._order=e,s===!0&&this._onChangeCallback(),this}setFromQuaternion(t,e,s=!0){return ia.makeRotationFromQuaternion(t),this.setFromRotationMatrix(ia,e,s)}setFromVector3(t,e=this._order){return this.set(t.x,t.y,t.z,e)}reorder(t){return na.setFromEuler(this),this.setFromQuaternion(na,t)}equals(t){return t._x===this._x&&t._y===this._y&&t._z===this._z&&t._order===this._order}fromArray(t){return this._x=t[0],this._y=t[1],this._z=t[2],t[3]!==void 0&&(this._order=t[3]),this._onChangeCallback(),this}toArray(t=[],e=0){return t[e]=this._x,t[e+1]=this._y,t[e+2]=this._z,t[e+3]=this._order,t}_onChange(t){return this._onChangeCallback=t,this}_onChangeCallback(){}*[Symbol.iterator](){yield this._x,yield this._y,yield this._z,yield this._order}};co.DEFAULT_ORDER="XYZ";let Hl=co;function Zn(i,t,e=!1){const s=i.x,n=i.y;let r=!1;const a=t.length;for(let o=0,l=a-1;o<a;l=o++){const c=t[o].x,u=t[o].y,d=t[l].x,g=t[l].y;let p=u>n!=g>n;e&&(p=u>=n!=g>=n),p&&s<(d-c)*(n-u)/(g-u)+c&&(r=!r)}return r}function uo(i,t){if(i.length===0||t.length===0)return!1;const e=new pt().setFromPoints(i),s=new pt().setFromPoints(t);if(!e.intersectsBox(s))return!1;for(let n=0;n<i.length;){if(Zn(i[n],t,!0))return!0;n<i.length-1&&qn.equalPoint2d(i[n+1],i[n])&&++n,++n}return!1}const po={isPointInPolygon:Zn,isPolygonIntersect:uo};function Ul(i,t){const e=[],s=t-1,n=i;for(let r=0;r<=n;r++)e.push(0);for(let r=1;r<=s-n;r++)e.push(r);for(let r=0;r<=n;r++)e.push(s-n+1);return e}function Xl(i,t){const e=t.length-1,s=i,n=[0];let r=0;for(let o=1;o<=e;o++){const l=t[o][0]-t[o-1][0],c=t[o][1]-t[o-1][1],u=t[o][2]-t[o-1][2],d=Math.sqrt(l*l+c*c+u*u);r+=d,n.push(r)}const a=[];for(let o=0;o<=s;o++)a.push(0);for(let o=1;o<=e-s;o++){const l=n[o]/r;a.push(l*(e-s+1))}for(let o=0;o<=s;o++)a.push(e-s+1);return a}function go(i,t="Uniform"){const e=i.length;if(e===0)return[];if(e===1)return[0];const s=e-1;if(t==="Uniform")return new Array(e).fill(0).map((a,o)=>o/s);const n=[0];let r=0;for(let a=1;a<=s;a++){const o=i[a][0]-i[a-1][0],l=i[a][1]-i[a-1][1],c=i[a][2]-i[a-1][2],u=Math.sqrt(o*o+l*l+c*c),d=t==="SqrtChord"?Math.sqrt(u):u;r+=d,n.push(r)}return r<1e-12?new Array(e).fill(0).map((a,o)=>o/s):n.map(a=>a/r)}function mo(i,t){const e=t.length-1,s=i,n=e+s+1,r=new Array(n+1).fill(0),a=t[t.length-1];for(let o=n-s;o<=n;o++)r[o]=a;for(let o=1;o<=e-s;o++){let l=0;for(let c=o;c<o+s;c++)l+=t[c];r[o+s]=l/s}return r}function Yl(i,t){const e=t.length-1,s=i,n=[0];let r=0;for(let o=1;o<=e;o++){const l=t[o][0]-t[o-1][0],c=t[o][1]-t[o-1][1],u=t[o][2]-t[o-1][2],d=Math.sqrt(l*l+c*c+u*u),g=Math.sqrt(d);r+=g,n.push(r)}const a=[];for(let o=0;o<=s;o++)a.push(0);for(let o=1;o<=e-s;o++){const l=n[o]/r;a.push(l*(e-s+1))}for(let o=0;o<=s;o++)a.push(e-s+1);return a}function hn(i,t){const e=i.length,s=i.map(a=>a.slice()),n=t.slice();for(let a=0;a<e;a++){let o=a,l=Math.abs(s[a][a]);for(let c=a+1;c<e;c++){const u=Math.abs(s[c][a]);u>l&&(l=u,o=c)}if(l<1e-12)throw new Error("Interpolation matrix is singular.");if(o!==a){const c=s[a];s[a]=s[o],s[o]=c;const u=n[a];n[a]=n[o],n[o]=u}for(let c=a+1;c<e;c++){const u=s[c][a]/s[a][a];if(!(Math.abs(u)<1e-14)){for(let d=a;d<e;d++)s[c][d]-=u*s[a][d];n[c]-=u*n[a]}}}const r=new Array(e).fill(0);for(let a=e-1;a>=0;a--){let o=n[a];for(let l=a+1;l<e;l++)o-=s[a][l]*r[l];r[a]=o/s[a][a]}return r}function Kn(i,t,e="Uniform",s,n){if(i.length===0)return{controlPoints:[],knots:[],weights:[]};const r=i.map(B=>[B[0],B[1],B[2]??0]),a=!!s,o=!!n,l=(a?1:0)+(o?1:0),c=r.length-1,u=c+l;if(u<t)throw new Error("Not enough points to interpolate a curve of this degree.");const d=go(r,e),g=d.slice();a&&g.unshift(d[0]),o&&g.push(d[d.length-1]);const p=mo(t,g),m=u+1,y=new Array(m),x=new Array(m),f=new Array(m),P=new Array(m);let I=0;y[I]=new Array(m).fill(0),y[I][0]=1,x[I]=r[0][0],f[I]=r[0][1],P[I]=r[0][2],I++;for(let B=1;B<=c-1;B++){const et=d[B];y[I]=new Array(m).fill(0);for(let F=0;F<=u;F++)y[I][F]=Ns(F,t,et,p);x[I]=r[B][0],f[I]=r[B][1],P[I]=r[B][2],I++}if(y[I]=new Array(m).fill(0),y[I][u]=1,x[I]=r[c][0],f[I]=r[c][1],P[I]=r[c][2],I++,a){const B=p[t+1]-p[0],et=B!==0?t/B:0;y[I]=new Array(m).fill(0),y[I][0]=-et,y[I][1]=et,x[I]=(s==null?void 0:s[0])??0,f[I]=(s==null?void 0:s[1])??0,P[I]=(s==null?void 0:s[2])??0,I++}if(o){const B=p[u+t+1]-p[u],et=B!==0?t/B:0;y[I]=new Array(m).fill(0),y[I][u-1]=-et,y[I][u]=et,x[I]=(n==null?void 0:n[0])??0,f[I]=(n==null?void 0:n[1])??0,P[I]=(n==null?void 0:n[2])??0,I++}const M=hn(y,x),A=hn(y,f),j=hn(y,P),T=new Array(m);for(let B=0;B<m;B++)T[B]=[M[B],A[B],j[B]];const X=new Array(m).fill(1);return{controlPoints:T,knots:p,weights:X}}function Ns(i,t,e,s){if(t===0)return e>=s[i]&&e<s[i+1]?1:0;const n=s[i+t]-s[i],r=s[i+t+1]-s[i+1],a=n>1e-10?(e-s[i])/n:0,o=r>1e-10?(s[i+t+1]-e)/r:0;return a*Ns(i,t-1,e,s)+o*Ns(i+1,t-1,e,s)}function Ts(i,t,e,s,n){const r=s.length-1,a=t;if(i=Math.max(e[a],Math.min(e[r+1],i)),Math.abs(i-e[r+1])<1e-8)return[...s[r]];if(Math.abs(i-e[a])<1e-8)return[...s[0]];const o=[0,0,0];let l=0;for(let c=0;c<=r;c++){const u=Ns(c,a,i,e),d=n[c]*u;o[0]+=s[c][0]*d,o[1]+=s[c][1]*d,o[2]+=s[c][2]*d,l+=d}if(Math.abs(l)<1e-10){const c=e[e.length-a-1];if(Math.abs(i-c)<1e-8)return[...s[r]];if(Math.abs(i-e[a])<1e-8)return[...s[0]]}return Math.abs(l)>=1e-10&&(o[0]/=l,o[1]/=l,o[2]/=l),o}function yo(i,t,e,s){const n=i,r=t[n],a=t[t.length-n-1];let o=0;const l=1e3,c=(a-r)/l;let u=Ts(r,i,t,e,s);for(let y=1;y<=l;y++){const x=r+y*c,f=Ts(x,i,t,e,s),P=f[0]-u[0],I=f[1]-u[1],M=f[2]-u[2];o+=Math.sqrt(P*P+I*I+M*M),u=f}const d=Ts(a,i,t,e,s),g=d[0]-u[0],p=d[1]-u[1],m=d[2]-u[2];return o+=Math.sqrt(g*g+p*p+m*m),o}function $l(i,t=3,e="Uniform",s,n){return i.length===0?[]:Kn(i,t,e,s,n).controlPoints}const ra=new G,aa=new b,ql=new b,Zl=new b,ln=new w;function _o(i){return new G().setFromExtrusionDirection(new b(i.x,i.y,i.z))}function Qn(i){return ra.setFromExtrusionDirection(new b(i.x,i.y,i.z)),ra.extractBasis(aa,ql,Zl),aa.clone()}function Mn(i,t){return new w(i.x,i.y,i.z??0).applyMatrix4(_o(t))}function Cs(i,t){return new w(i.x,i.y,i.z??0).applyMatrix4(_o(t).invert())}function vn(i,t,e){const s=Cs(i,e),n=Cs(t,e);return ln.set(n.x-s.x,n.y-s.y,(n.z??0)-(s.z??0)),v.normalizeAngle(Math.atan2(ln.y,ln.x))}class wo{constructor(){this._boundingBoxNeedsUpdate=!1}get boundingBoxNeedUpdate(){return this._boundingBoxNeedsUpdate}}class Jn extends wo{translate(t){return this.transform(new Us().makeTranslation(t.x,t.y))}get box(){return(this._box==null||this._boundingBoxNeedsUpdate)&&(this._box=this.calculateBoundingBox(),this._boundingBoxNeedsUpdate=!1),this._box}}let ts=class xo extends Jn{constructor(){super(),this._loops=[]}add(t){this._loops.push(t),this._boundingBoxNeedsUpdate=!0}get loops(){return this._loops}get outter(){if(this._loops.length>0)return this._loops[0]}calculateBoundingBox(){const t=this.outter;return t?t.box:new pt}transform(t){return this._loops.forEach(e=>{e.transform(t)}),this._boundingBoxNeedsUpdate=!0,this}clone(){const t=new xo;return this._loops.forEach(e=>{t.add(e.clone())}),t}getPoints(t){const e=[];for(let s=0;s<this.loops.length;++s){const n=this.loops[s].getPoints(t);e.push(n)}return e}buildHierarchy(){var t;const e=this.getPoints(100),s=this.calculateBoundaryBoxes(e),n=this.sortBoundaryBoxesByAreas(s),r=new Map,a=n.length;for(let l=0;l<a;l++)r.set(n[l],{index:n[l],children:[]});const o={index:-1,children:[]};for(let l=0;l<a;l++){const c=n[l],u=e[c],d=s[c];let g=l+1;for(;g<a;g++){const p=n[g],m=e[p];if(s[p].containsBox(d)&&po.isPointInPolygon(u[v.randInt(0,u.length-1)],m)){(t=r.get(p))==null||t.children.push(r.get(c));break}}g===a&&o.children.push(r.get(c))}return o}get area(){if(this._loops.length===0)return 0;let t=0;for(let e=0;e<this._loops.length;e++){const s=this._loops[e].getPoints(128),n=this.polygonArea(s);e===0?t+=Math.abs(n):t-=Math.abs(n)}return t}polygonArea(t){const e=t.length;if(e<3)return 0;let s=0;for(let n=0,r=e-1;n<e;r=n++){const a=t[r],o=t[n];s+=a.x*o.y-o.x*a.y}return s*.5}calculateBoundaryBoxes(t){const e=[];return t.forEach(s=>{e.push(new pt().setFromPoints(s))}),e}sortBoundaryBoxesByAreas(t){const e=[];t.forEach((n,r)=>{const a=n.size,o=a.width*a.height;e.push({area:o,index:r})}),e.sort((n,r)=>n.area-r.area);const s=[];return e.forEach(n=>{s.push(n.index)}),s}},is=class extends Jn{constructor(){super(),this.arcLengthDivisions=100}get startPoint(){return this.getPoint(0)}get endPoint(){return this.getPoint(1)}get length(){return this.getLength()}getPoint(t){throw new Error("AcGeCurve2d: .getPoint() not implemented.")}getPointAt(t){const e=this.getUtoTmapping(t);return this.getPoint(e)}getPoints(t=5){const e=[];for(let s=0;s<=t;s++)e.push(this.getPoint(s/t));return e}getSpacedPoints(t=5){const e=[];for(let s=0;s<=t;s++)e.push(this.getPointAt(s/t));return e}getLength(){const t=this.getLengths();return t[t.length-1]}getLengths(t=this.arcLengthDivisions){const e=[];let s,n=this.getPoint(0),r=0;e.push(0);for(let a=1;a<=t;a++)s=this.getPoint(a/t),r+=s.distanceTo(n),e.push(r),n=s;return e}getUtoTmapping(t,e){const s=this.getLengths();let n=0;const r=s.length;let a;e?a=e:a=t*s[r-1];let o=0,l=r-1,c;for(;o<=l;)if(n=Math.floor(o+(l-o)/2),c=s[n]-a,c<0)o=n+1;else if(c>0)l=n-1;else{l=n;break}if(n=l,s[n]===a)return n/(r-1);const u=s[n],d=s[n+1]-u,g=(a-u)/d;return(n+g)/(r-1)}getTangent(t){let e=t-1e-4,s=t+1e-4;e<0&&(e=0),s>1&&(s=1);const n=this.getPoint(e),r=this.getPoint(s),a=new k;return a.copy(r).sub(n).normalize(),a}getTangentAt(t){const e=this.getUtoTmapping(t);return this.getTangent(e)}},ye=class kn extends is{constructor(t,e,s,n,r){super();const a=+(t!==void 0)+ +(e!==void 0)+ +(s!==void 0)+ +(n!==void 0)+ +(r!==void 0);if(a==3)typeof t=="object"&&typeof e=="object"&&typeof s=="object"?this.createByThreePoints(t,e,s):this.createByStartEndPointsAndBulge(t,e,s);else if(a==5){const o=t;this.center=new k(o.x,o.y),this.radius=e,this._clockwise=r,this._startAngle=this._clockwise?this._mirrorAngle(v.normalizeAngle(s)):v.normalizeAngle(s),this._endAngle=this._clockwise?this._mirrorAngle(v.normalizeAngle(n)):v.normalizeAngle(n)}else throw yt.ILLEGAL_PARAMETERS}createByThreePoints(t,e,s){const n=(T,X)=>({x:(T.x+X.x)/2,y:(T.y+X.y)/2}),r=(T,X)=>(X.y-T.y)/(X.x-T.x),a=T=>-1/T,o=n(t,e),l=n(e,s),c=r(t,e),u=r(e,s),d=a(c),g=a(u),p=(T,X,B,et)=>{const F=(et-X)/(T-B),U=T*F+X;return{x:F,y:U}},m=o.y-d*o.x,y=l.y-g*l.x,x=p(d,m,g,y),f=Math.sqrt(Math.pow(t.x-x.x,2)+Math.pow(t.y-x.y,2)),P=(T,X)=>Math.atan2(T.y-X.y,T.x-X.x),I=P(t,x),M=P(e,x),A=P(s,x),j=A>I&&A<M||I>A&&I<M||M>A&&M<I;this.center=x,this.radius=f,this._clockwise=!j,this._startAngle=I,this._endAngle=A}createByStartEndPointsAndBulge(t,e,s){let n,r,a;s<0?(n=Math.atan(-s)*4,r=new Y(t),a=new Y(e)):(n=Math.atan(s)*4,r=new Y(e),a=new Y(t));const o=new Y().subVectors(a,r),l=o.length(),c=new Y().addVectors(r,o.multiplyScalar(.5)),u=Math.abs(l/2/Math.tan(n/2)),d=o.normalize(),g=s<0?-Math.PI/2:Math.PI/2,p=new Y(d.x*Math.cos(g)-d.y*Math.sin(g),d.y*Math.cos(g)+d.x*Math.sin(g));let m;n<Math.PI?s<0?m=c.add(p.multiplyScalar(u)):m=c.add(p.multiplyScalar(-u)):s<0?m=c.add(p.multiplyScalar(-u)):m=c.add(p.multiplyScalar(u)),s<0?(this._startAngle=Math.atan2(r.y-m.y,r.x-m.x),this._endAngle=Math.atan2(a.y-m.y,a.x-m.x)):(this._startAngle=Math.atan2(a.y-m.y,a.x-m.x),this._endAngle=Math.atan2(r.y-m.y,r.x-m.x)),this._clockwise=s<0,this.center=m,this.radius=a.sub(m).length()}get center(){return this._center}set center(t){this._center=new k(t.x,t.y),this._boundingBoxNeedsUpdate=!0}get radius(){return this._radius}set radius(t){this._radius=t,this._boundingBoxNeedsUpdate=!0}get startAngle(){return this._clockwise?this._mirrorAngle(this._startAngle):this._startAngle}set startAngle(t){this._startAngle=this._clockwise?this._mirrorAngle(v.normalizeAngle(t)):v.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get endAngle(){return this._clockwise?this._mirrorAngle(this._endAngle):this._endAngle}set endAngle(t){const e=this.startAngle==0&&t==W?t:v.normalizeAngle(t);this._endAngle=this._clockwise?this._mirrorAngle(e):e,this._boundingBoxNeedsUpdate=!0}_mirrorAngle(t){return(360-t*180/Math.PI)%360*Math.PI/180}_getInternalAngle(t){return this._clockwise?this._mirrorAngle(t):t}get deltaAngle(){const t=this._getInternalAngle(this.startAngle),e=this._getInternalAngle(this.endAngle);return this.clockwise?v.normalizeAngle(t-e):v.normalizeAngle(e-t)}get clockwise(){return this._clockwise}set clockwise(t){this._clockwise=t,this._boundingBoxNeedsUpdate=!0}get startPoint(){return this.getPointAtAngle(this.startAngle)}get endPoint(){return this.getPointAtAngle(this.endAngle)}get midPoint(){const t=this._getInternalAngle(this.startAngle),e=this._clockwise?v.normalizeAngle(t-this.deltaAngle/2):v.normalizeAngle(t+this.deltaAngle/2),s=this._clockwise?this._mirrorAngle(e):e;return this.getPointAtAngle(s)}get closed(){const t=this._getInternalAngle(this.startAngle),e=this._getInternalAngle(this.endAngle);return Math.abs(e-t)/Math.PI%2==0}calculateBoundingBox(){const t=[this.startPoint,this.endPoint],e=[0,Math.PI/2,Math.PI,3*Math.PI/2];for(const r of e){const a=this._getInternalAngle(r);v.isBetweenAngle(a,this._getInternalAngle(this.startAngle),this._getInternalAngle(this.endAngle),this.clockwise)&&t.push(this.getPointAtAngle(r))}const s=t.map(r=>r.x),n=t.map(r=>r.y);return new pt(new k(Math.min(...s),Math.min(...n)),new k(Math.max(...s),Math.max(...n)))}get length(){return Math.abs(this.deltaAngle*this.radius)}transform(t){const e=t,s=this.center.clone().applyMatrix2d(e),n=this.startPoint.clone().applyMatrix2d(e);if(this.closed)return this.center=s,this.radius=s.distanceTo(n),this._startAngle=Math.atan2(n.y-s.y,n.x-s.x),this._endAngle=this._startAngle,this._clockwise=e.determinant()<0?!this._clockwise:this._clockwise,this._boundingBoxNeedsUpdate=!0,this;const r=this.midPoint.clone().applyMatrix2d(e),a=this.endPoint.clone().applyMatrix2d(e),o=new kn(n,r,a),l=e.determinant()<0?!this.clockwise:this.clockwise,c=u=>{const d=v.normalizeAngle(u);return l?this._mirrorAngle(d):d};return this.center=o.center,this.radius=o.radius,this.clockwise=l,this.startAngle=c(Math.atan2(n.y-o.center.y,n.x-o.center.x)),this.endAngle=c(Math.atan2(a.y-o.center.y,a.x-o.center.x)),this._boundingBoxNeedsUpdate=!0,this}clone(){return new kn(this.center.clone(),this.radius,this._startAngle,this._endAngle,this.clockwise)}getPointAtAngle(t){const e=this._getInternalAngle(t),s=this.center.x+this.radius*Math.cos(e),n=this.center.y+this.radius*Math.sin(e);return new k(s,n)}getPoints(t=100){const e=[];let s=this.deltaAngle,n=this._getInternalAngle(this.startAngle);if(this.closed&&(s=W,n=0),this.clockwise)for(let r=0;r<=t;r++){const a=n-s*(r/t),o=this._clockwise?this._mirrorAngle(a):a,l=this.getPointAtAngle(o);e.push(new k(l.x,l.y))}else for(let r=0;r<=t;r++){const a=n+s*(r/t),o=this._clockwise?this._mirrorAngle(a):a,l=this.getPointAtAngle(o);e.push(new k(l.x,l.y))}return e}};class Kl extends wo{translate(t){return this.transform(new G().makeTranslation(t.x,t.y,t.z))}get box(){return(this._box==null||this._boundingBoxNeedsUpdate)&&(this._box=this.calculateBoundingBox(),this._boundingBoxNeedsUpdate=!1),this._box}}class $s extends Kl{}class _e extends $s{constructor(t,e){super(),this._start=new w(t),this._end=new w(e)}get startPoint(){return this._start}set startPoint(t){this._start.copy(t),this._boundingBoxNeedsUpdate=!0}get endPoint(){return this._end}set endPoint(t){this._end.copy(t),this._boundingBoxNeedsUpdate=!0}get direction(){return new b().subVectors(this.endPoint,this.startPoint).normalize()}get midPoint(){return new w((this._start.x+this._end.x)/2,(this._start.y+this._end.y)/2,(this._start.z+this._end.z)/2)}nearestPoint(t){return this.project(t)}get length(){return this.startPoint.distanceTo(this.endPoint)}isPointOnLine(t){return this.project(t).distanceTo(t)<1e-6}at(t,e){return this.delta(e).multiplyScalar(t).add(this._start)}atLength(t,e=!1){if(e){const s=this.delta(Ie).normalize();return new w(this._start).addScaledVector(s,t)}else{const s=this.delta(Ie).normalize();return new w(this._end).addScaledVector(s,t)}}extend(t,e=!1){if(e){const s=Ie.subVectors(this._start,this._end).normalize();this._start=new w(this._start).addScaledVector(s,t)}else{const s=this.delta(Ie).normalize();this._end=new w(this._end).addScaledVector(s,t)}return this._boundingBoxNeedsUpdate=!0,this}closestPointToPointParameter(t,e){oa.subVectors(t,this._start),oi.subVectors(this.endPoint,this.startPoint);const s=oi.dot(oi);let n=oi.dot(oa)/s;return e&&(n=v.clamp(n,0,1)),n}closestPointToPoint(t,e,s){const n=this.closestPointToPointParameter(t,e);return this.delta(s).multiplyScalar(n).add(this._start)}delta(t){return t.subVectors(this._end,this._start)}distanceSq(){return this._start.distanceToSquared(this._end)}distance(){return this._start.distanceTo(this._end)}project(t){const e=this.direction,s=Ie.subVectors(t,this.startPoint).dot(e);return new w().copy(e).multiplyScalar(s).add(this.startPoint)}perpPoint(t){const e=this.direction,s=this.startPoint,n=Ie.subVectors(t,s).dot(e),r=Ie.copy(e).multiplyScalar(n);return new w().addVectors(s,r)}calculateBoundingBox(){const t=new w(Math.min(this._start.x,this._end.x),Math.min(this._start.y,this._end.y),Math.min(this._start.z,this._end.z)),e=new w(Math.max(this._start.x,this._end.x),Math.max(this._start.y,this._end.y),Math.max(this._start.z,this._end.z));return new C(t,e)}transform(t){return this._start.applyMatrix4(t),this._end.applyMatrix4(t),this._boundingBoxNeedsUpdate=!0,this}get closed(){return!1}copy(t){return this.startPoint=t.startPoint,this.endPoint=t.endPoint,this._boundingBoxNeedsUpdate=!0,this}clone(){return new _e(this._start.clone(),this._end.clone())}}const Ie=new b,oa=new b,oi=new b;class je extends $s{static computeCenterPoint(t,e,s){const n=new b().addVectors(t,e).multiplyScalar(.5),r=new b().addVectors(t,s).multiplyScalar(.5),a=new b().subVectors(e,t),o=new b().subVectors(s,t),l=new b().crossVectors(a,o).normalize();if(l.lengthSq()===0)return null;const c=new b().crossVectors(a,l).normalize(),u=new b().crossVectors(o,l).normalize(),d=c.clone().multiplyScalar(Number.MAX_SAFE_INTEGER),g=u.clone().multiplyScalar(Number.MAX_SAFE_INTEGER),p=new _e(n,n.clone().add(d)),m=new _e(r,r.clone().add(g)),y=new b;return p.closestPointToPoint(m.startPoint,!0,y)?y:null}static createByThreePoints(t,e,s){const n=je.computeCenterPoint(t,e,s);if(n){const r=n.distanceTo(t),a=new b().subVectors(t,n),o=new b().subVectors(e,n),l=Math.atan2(a.y,a.x),c=Math.atan2(o.y,o.x);return new je(n,r,l,c,b.Z_AXIS)}}constructor(t,e,s,n,r,a=b.X_AXIS){super(),this.center=t,this.radius=e,this.startAngle=s,this.endAngle=n,this.normal=r,this.refVec=a,(n-s)%W==0?(this.startAngle=0,this.endAngle=W):(this.startAngle=s,this.endAngle=n)}get center(){return this._center}set center(t){this._center=new w(t.x,t.y,t.z||0),this._boundingBoxNeedsUpdate=!0}get radius(){return this._radius}set radius(t){if(t<0)throw yt.ILLEGAL_PARAMETERS;this._radius=t,this._boundingBoxNeedsUpdate=!0}get startAngle(){return this._startAngle}set startAngle(t){this._startAngle=v.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get endAngle(){return this._endAngle}set endAngle(t){this._endAngle=this.startAngle==0&&t==W?t:v.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get deltaAngle(){return v.normalizeAngle(this.endAngle-this.startAngle)}get isLargeArc(){return Math.abs(this.deltaAngle)>Math.PI?1:0}get clockwise(){return this.deltaAngle<=0}get normal(){return this._normal}set normal(t){this._normal=new b(t.x,t.y,t.z),this._normal.normalize(),this._boundingBoxNeedsUpdate=!0}get refVec(){return this._refVec}set refVec(t){this._refVec=new b(t.x,t.y,t.z),this._refVec.normalize(),this._boundingBoxNeedsUpdate=!0}get startPoint(){return this.getPointAtAngle(this._startAngle)}get endPoint(){return this.getPointAtAngle(this._endAngle)}get midPoint(){let t=this.startAngle,e=this.deltaAngle;this.closed&&(t=0,e=W);const s=t+e*.5;return this.getPointAtAngle(s)}get length(){return this.closed?2*Math.PI*this.radius:Math.abs(this.deltaAngle*this.radius)}get area(){return this.closed?Math.PI*this.radius*this.radius:Math.abs(this.deltaAngle*this.radius*this.radius)}nearestPoint(t){const e=new b(t.x,t.y,t.z||0),s=this.center,n=this.normal,r=e.clone().sub(s).dot(n),a=e.clone().sub(n.clone().multiplyScalar(r)).clone().sub(s);if(a.lengthSq()===0)return this.startPoint.clone();a.normalize().multiplyScalar(this.radius);const o=s.clone().add(a),l=this.getAngle(o.clone()),c=this.startAngle,u=this.deltaAngle;let d=v.normalizeAngle(l-c);d<0&&(d=0),d>u&&(d=u);const g=this.getPointAtAngle(c+d),p=g.distanceTo(e),m=this.startPoint.distanceTo(e),y=this.endPoint.distanceTo(e);return m<p&&m<=y?this.startPoint.clone():y<p&&y<m?this.endPoint.clone():g}tangentPoints(t){const e=[],s=new b(t.x,t.y,t.z||0),n=this.center,r=this.normal,a=this.radius,o=s.clone().sub(n).dot(r),l=s.clone().sub(r.clone().multiplyScalar(o)),c=n.clone(),u=l.clone().sub(c).length();if(u<a)return e;const d=Math.acos(a/u),g=this.getAngle(l.clone()),p=[g+d,g-d];for(const m of p){const y=v.normalizeAngle(m-this.startAngle);y>=0&&y<=this.deltaAngle&&e.push(this.getPointAtAngle(this.startAngle+y))}return e}nearestTangentPoint(t){const e=this.tangentPoints(t);if(e.length===0)return null;const s=new w(t.x,t.y,t.z||0);return e.length===1||e[0].distanceTo(s)<e[1].distanceTo(s)?e[0]:e[1]}calculateBoundingBox(){const t=[this.startAngle,this.endAngle];for(let l=0;l<2*Math.PI;l+=Math.PI/2)v.isBetweenAngle(l,this.startAngle,this.endAngle)&&t.push(l);let e=1/0,s=1/0,n=1/0,r=-1/0,a=-1/0,o=-1/0;for(const l of t){const c=this.getPointAtAngle(l);c.x<e&&(e=c.x),c.y<s&&(s=c.y),c.z<n&&(n=c.z),c.x>r&&(r=c.x),c.y>a&&(a=c.y),c.z>o&&(o=c.z)}return new C({x:e,y:s,z:n},{x:r,y:a,z:o})}get closed(){return Math.abs(this.endAngle-this.startAngle)/Math.PI%2==0}getPoints(t){const e=[];let s=this.deltaAngle,n=this.startAngle;this.closed&&(s=W,n=0);for(let r=0;r<=t;r++){const a=n+s*(r/t),o=this.getPointAtAngle(a);e.push(o)}return e}transform(t){const e=this.center.clone().applyMatrix4(t),s=this.startPoint.clone().applyMatrix4(t),n=this.endPoint.clone().applyMatrix4(t),r=this.getPointAtAngle(this.closed?Math.PI/2:this.startAngle+this.deltaAngle/2).clone().applyMatrix4(t),a=new b(s).sub(e).normalize(),o=e.distanceTo(s);let l=new b().crossVectors(new b(s).sub(e),new b(r).sub(e)).normalize();l.lengthSq()===0&&(l=this.normal.clone().transformDirection(t));const c=u=>{const d=new b(u).sub(e);return Math.atan2(d.dot(ha.crossVectors(l,a)),d.dot(a))};return this.center=e,this.radius=o,this.normal=l,this.refVec=a,this.startAngle=0,this.endAngle=this.closed?W:c(n),this._boundingBoxNeedsUpdate=!0,this}copy(t){return this.center=t.center,this.radius=t.radius,this.startAngle=t.startAngle,this.endAngle=t.endAngle,this.normal=t.normal,this.refVec=t.refVec,this._boundingBoxNeedsUpdate=!0,this}clone(){return new je(this.center.clone(),this.radius,this.startAngle,this.endAngle,this.normal,this.refVec)}getAngle(t){return t.sub(this.center),Math.atan2(t.dot(ha.crossVectors(this.refVec,this.normal)),t.dot(this.refVec))}getPointAtAngle(t){const e=this.normal,s=this.refVec,n={x:e.y*s.z-e.z*s.y,y:e.z*s.x-e.x*s.z,z:e.x*s.y-e.y*s.x},r=this.center,a=this.radius;return new w(r.x+a*(s.x*Math.cos(t)+n.x*Math.sin(t)),r.y+a*(s.y*Math.cos(t)+n.y*Math.sin(t)),r.z+a*(s.z*Math.cos(t)+n.z*Math.sin(t)))}get plane(){const t=new b(this.center).distanceTo($n);return new Ys(this.normal,t)}}const ha=new b;let Bs=class gi extends is{constructor(t,e,s,n=0,r=W,a=!1,o=0){super(),this.center=t,this.majorAxisRadius=e,this.minorAxisRadius=s,(r-n)%W==0?(this.startAngle=0,this.endAngle=W):(this.startAngle=n,this.endAngle=r),this.clockwise=a,this.rotation=o}get center(){return this._center}set center(t){this._center=new w(t.x,t.y,t.z||0),this._boundingBoxNeedsUpdate=!0}get majorAxisRadius(){return this._majorAxisRadius}set majorAxisRadius(t){if(t<0)throw yt.ILLEGAL_PARAMETERS;this._majorAxisRadius=t,this._boundingBoxNeedsUpdate=!0}get minorAxisRadius(){return this._minorAxisRadius}set minorAxisRadius(t){if(t<0)throw yt.ILLEGAL_PARAMETERS;this._minorAxisRadius=t,this._boundingBoxNeedsUpdate=!0}get startAngle(){return this._startAngle}set startAngle(t){this._startAngle=v.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get endAngle(){return this._endAngle}set endAngle(t){this._endAngle=this.startAngle==0&&t==W?t:v.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get clockwise(){return this._clockwise}set clockwise(t){this._clockwise=t,this._boundingBoxNeedsUpdate=!0}get rotation(){return this._rotation}set rotation(t){this._rotation=t,this._boundingBoxNeedsUpdate=!0}get deltaAngle(){return v.normalizeAngle(this.endAngle-this.startAngle)}get isLargeArc(){return Math.abs(this.deltaAngle)>Math.PI?1:0}calculateBoundingBox(){let t=1/0,e=1/0,s=-1/0,n=-1/0;for(let r=0;r<=100;r++){const a=this.getPoint(r/100);t=Math.min(t,a.x),e=Math.min(e,a.y),s=Math.max(s,a.x),n=Math.max(n,a.y)}return new pt({x:t,y:e},{x:s,y:n})}get closed(){return this.deltaAngle==0}getPoint(t){const e=Math.PI*2;let s=this.endAngle-this.startAngle;const n=Math.abs(s)<Number.EPSILON;for(;s<0;)s+=e;for(;s>e;)s-=e;s<Number.EPSILON&&(n?s=0:s=e),this.clockwise===!0&&!n&&(s===e?s=-e:s=s-e);const r=this.startAngle+t*s;let a=this.center.x+this.majorAxisRadius*Math.cos(r),o=this.center.y+this.minorAxisRadius*Math.sin(r);if(this.rotation!==0){const l=Math.cos(this.rotation),c=Math.sin(this.rotation),u=a-this.center.x,d=o-this.center.y;a=u*l-d*c+this.center.x,o=u*c+d*l+this.center.y}return new k(a,o)}transform(t){const e=t,s=new k(this.center).applyMatrix2d(e),n=new w(s.x,s.y,this.center.z),r=this.getPointAtAngle(0).clone().applyMatrix2d(e),a=this.getPointAtAngle(Math.PI/2).clone().applyMatrix2d(e),o=new k(r).sub(s),l=new k(a).sub(s),c=o.length(),u=l.length(),d=Math.atan2(o.y,o.x),g=o.clone().normalize(),p=l.clone().normalize(),m=f=>{const P=new k(f).sub(s),I=P.dot(g),M=P.dot(p);return v.normalizeAngle(Math.atan2(M/u,I/c))},y=e.determinant()<0?!this.clockwise:this.clockwise,x=this.closed?new gi(n,c,u,0,W,y,d):new gi(n,c,u,m(this.startPoint.clone().applyMatrix2d(e)),m(this.endPoint.clone().applyMatrix2d(e)),y,d);return this.center=x.center,this.majorAxisRadius=x.majorAxisRadius,this.minorAxisRadius=x.minorAxisRadius,this._startAngle=x._startAngle,this._endAngle=x._endAngle,this._clockwise=x._clockwise,this.rotation=x.rotation,this._boundingBoxNeedsUpdate=!0,this}getPointAtAngle(t){return this.getPoint(this.closed?t/W:v.normalizeAngle(t-this.startAngle)/this.deltaAngle)}copy(t){return this.center=t.center,this.majorAxisRadius=t.majorAxisRadius,this.minorAxisRadius=t.minorAxisRadius,this.startAngle=t.startAngle,this.endAngle=t.endAngle,this.clockwise=t.clockwise,this.rotation=t.rotation,this}clone(){return new gi(this.center,this.majorAxisRadius,this.minorAxisRadius,this.startAngle,this.endAngle,this.clockwise,this.rotation)}};class Je extends $s{constructor(t,e,s,n,r,a=0,o=W){super(),this.center=t,this.normal=e,this.majorAxis=s,this.majorAxisRadius=n,this.minorAxisRadius=r;const l=Math.abs(o-a);Math.abs(l-W)<1e-10||Math.abs(l-2*W)<1e-10?(this.startAngle=0,this.endAngle=W):(this.startAngle=a,this.endAngle=o)}get center(){return this._center}set center(t){this._center=new w(t.x,t.y,t.z||0),this._boundingBoxNeedsUpdate=!0}get majorAxisRadius(){return this._majorAxisRadius}set majorAxisRadius(t){if(t<0)throw yt.ILLEGAL_PARAMETERS;this._majorAxisRadius=t,this._boundingBoxNeedsUpdate=!0}get minorAxisRadius(){return this._minorAxisRadius}set minorAxisRadius(t){if(t<0)throw yt.ILLEGAL_PARAMETERS;this._minorAxisRadius=t,this._boundingBoxNeedsUpdate=!0}get startAngle(){return this._startAngle}set startAngle(t){this._startAngle=v.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get endAngle(){return this._endAngle}set endAngle(t){this._endAngle=this.startAngle==0&&t==W?t:v.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get deltaAngle(){const t=this.endAngle-this.startAngle;return Math.abs(t-W)<1e-10?W:v.normalizeAngle(t)}get isLargeArc(){return Math.abs(this.deltaAngle)>Math.PI?1:0}get clockwise(){return this.deltaAngle<=0}get normal(){return this._normal}set normal(t){this._normal=new b(t.x,t.y,t.z),this._normal.normalize(),this._boundingBoxNeedsUpdate=!0}get majorAxis(){return this._majorAxis}set majorAxis(t){this._majorAxis=new b(t.x,t.y,t.z),this._majorAxis.normalize(),this._boundingBoxNeedsUpdate=!0}get minorAxis(){return new b().crossVectors(this.normal,this.majorAxis).normalize()}get startPoint(){return this.getPointAtAngle(this._startAngle)}get endPoint(){return this.getPointAtAngle(this._endAngle)}get midPoint(){let t=this.startAngle,e=this.deltaAngle;(this.closed||Math.abs(e-W)<1e-10)&&(t=0,e=W);const s=t+e/2;return this.getPointAtAngle(s)}get isCircular(){return Xs.equal(this.majorAxisRadius,this.minorAxisRadius)}get length(){if(this.isCircular)return this.majorAxisRadius*Math.abs(this.deltaAngle);const t=1e3,e=this.deltaAngle/t;let s=0,n=this.getPointAtAngle(this.startAngle);for(let r=1;r<=t;r++){const a=this.startAngle+r*e,o=this.getPointAtAngle(a),l=o.x-n.x,c=o.y-n.y,u=o.z-n.z;s+=Math.sqrt(l*l+c*c+u*u),n=o}return s}get area(){const t=this.majorAxisRadius,e=this.minorAxisRadius,s=this.startAngle,n=s+this.deltaAngle;if(Math.abs(this.deltaAngle-W)<1e-10)return Math.PI*t*e;const r=t*e/2*(n-s-(Math.sin(n)*Math.cos(n)-Math.sin(s)*Math.cos(s)));return Math.abs(r)}calculateBoundingBox(){if(this.majorAxis.equals(b.X_AXIS)||this.majorAxis.equals(b.Y_AXIS)||this.majorAxis.isParallelTo(b.X_AXIS)||this.majorAxis.isParallelTo(b.Y_AXIS)){const t=[this.startAngle,this.endAngle];for(let l=0;l<2*Math.PI;l+=Math.PI/2)v.isBetweenAngle(l,this.startAngle,this.endAngle)&&t.push(l);let e=1/0,s=1/0,n=1/0,r=-1/0,a=-1/0,o=-1/0;for(const l of t){const c=this.getPointAtAngle(l);c.x<e&&(e=c.x),c.y<s&&(s=c.y),c.z<n&&(n=c.z),c.x>r&&(r=c.x),c.y>a&&(a=c.y),c.z>o&&(o=c.z)}return new C({x:e,y:s,z:n},{x:r,y:a,z:o})}else{let t=1/0,e=1/0,s=1/0,n=-1/0,r=-1/0,a=-1/0;for(let o=0;o<=100;o++){const l=this.startAngle+this.deltaAngle*(o/100),c=this.getPointAtAngle(l);t=Math.min(t,c.x),e=Math.min(e,c.y),s=Math.min(s,c.z),n=Math.max(n,c.x),r=Math.max(r,c.y),a=Math.max(a,c.z)}return new C({x:t,y:e,z:s},{x:n,y:r,z:a})}}get closed(){return this.deltaAngle==0}getPoints(t=100){const e=[];let s=this.deltaAngle,n=this.startAngle;this.closed&&(s=W,n=0);for(let r=0;r<=t;r++){const a=n+s*(r/t),o=this.getPointAtAngle(a);e.push(o)}return e}getPointAtAngle(t){const e=Math.cos(t),s=Math.sin(t),n=this.minorAxis.clone().multiplyScalar(this.minorAxisRadius).multiplyScalar(s),r=this.majorAxis.clone().multiplyScalar(e*this.majorAxisRadius).add(n);return new w(this.center.x+r.x,this.center.y+r.y,this.center.z+r.z)}contains(t){const e=new b(t).sub(this.center),s=e.dot(this.majorAxis),n=e.dot(this.minorAxis),r=s/this.majorAxisRadius,a=n/this.minorAxisRadius;return r*r+a*a<=1}transform(t){const e=t,s=this.center.clone().applyMatrix4(e),n=this.getPointAtAngle(0).clone().applyMatrix4(e),r=this.getPointAtAngle(Math.PI/2).clone().applyMatrix4(e),a=new b(n).sub(s),o=new b(r).sub(s),l=a.length(),c=o.length(),u=a.clone().normalize(),d=new b().crossVectors(a,o).normalize();let g=new b().crossVectors(d,u).normalize();g.dot(o)<0&&(d.negate(),g=new b().crossVectors(d,u).normalize());const p=y=>{const x=new b(y).sub(s),f=x.dot(u),P=x.dot(g);return v.normalizeAngle(Math.atan2(P/c,f/l))},m=this.closed?new Je(s,d,u,l,c,0,W):new Je(s,d,u,l,c,p(this.startPoint.clone().applyMatrix4(e)),p(this.endPoint.clone().applyMatrix4(e)));return this.center=m.center,this.normal=m.normal,this.majorAxis=m.majorAxis,this.majorAxisRadius=m.majorAxisRadius,this.minorAxisRadius=m.minorAxisRadius,this._startAngle=m._startAngle,this._endAngle=m._endAngle,this._boundingBoxNeedsUpdate=!0,this}copy(t){return this.center=t.center,this.normal=t.normal,this.majorAxis=t.majorAxis,this.majorAxisRadius=t.majorAxisRadius,this.minorAxisRadius=t.minorAxisRadius,this.startAngle=t.startAngle,this.endAngle=t.endAngle,this._boundingBoxNeedsUpdate=!0,this}clone(){return new Je(this.center,this.normal,this.majorAxis,this.majorAxisRadius,this.minorAxisRadius,this.startAngle,this.endAngle)}get plane(){const t=new b(this.center).distanceTo($n);return new Ys(this.normal,t)}}class Mt extends is{constructor(t=null,e=!1){super(),this._vertices=t||new Array,this._closed=e}get vertices(){return this._vertices}get numberOfVertices(){return this._vertices.length}get closed(){return this._closed}get startPoint(){if(this.numberOfVertices>0){const t=this._vertices[0];return new k(t.x,t.y)}throw new Error("Start point does not exist in an empty polyline.")}get endPoint(){const t=this.numberOfVertices;if(t>0)if(this.closed){const e=this._vertices[0];return new k(e.x,e.y)}else{const e=this._vertices[t-1];return new k(e.x,e.y)}throw new Error("End point does not exist in an empty polyline.")}get length(){let t=0;const e=this._vertices.length;for(let s=0;s<e;++s){const n=this._vertices[s];let r=null;if(s<e-1?r=this._vertices[s+1]:s==e-1&&this.closed&&(r=this._vertices[0]),r)if(n.bulge){const a=new ye(n,r,n.bulge);t+=a.length}else t+=new k(n.x,n.y).distanceTo(r)}return t}set closed(t){this._closed=t,this._boundingBoxNeedsUpdate=!0}addVertexAt(t,e){t<=0?this._vertices.unshift(e):this._vertices.splice(t,0,e),this._boundingBoxNeedsUpdate=!0}removeVertexAt(t){if(t<0||t>=this._vertices.length)throw new Error(`Index ${t} is out of bounds. Valid range is 0 to ${this._vertices.length-1}.`);this._vertices.splice(t,1),this._boundingBoxNeedsUpdate=!0}reset(t,e){t?e!==void 0&&e>=0&&e<this._vertices.length&&(this._vertices=this._vertices.slice(0,e),this._boundingBoxNeedsUpdate=!0):(this._vertices=new Array,this._boundingBoxNeedsUpdate=!0)}getPointAt(t){const e=this._vertices[t];return new k(e.x,e.y)}calculateBoundingBox(){const t=this.getPoints(100);return new pt().setFromPoints(t)}transform(t){const e=t.determinant()<0;return this._vertices.forEach(s=>{const n=new k(s).applyMatrix2d(t);s.x=n.x,s.y=n.y,e&&s.bulge!=null&&(s.bulge=-s.bulge)}),this._boundingBoxNeedsUpdate=!0,this}clone(){return new Mt(this._vertices.map(t=>({...t})),this._closed)}getPoints3d(t,e){const s=[];return this.getPoints(t).forEach(n=>s.push(new w().set(n.x,n.y,e))),s}getPoints(t){const e=[],s=this._vertices.length;for(let n=0;n<s;++n){const r=this._vertices[n];if(r.bulge){let a=null;if(n<s-1?a=this._vertices[n+1]:n==s-1&&this.closed&&(a=this._vertices[0]),a){const o=new ye(r,a,r.bulge).getPoints(t),l=o.length;for(let c=0;c<l;++c){const u=o[c];e.push(new k(u.x,u.y))}}}else e.push(new k(r.x,r.y)),n==s-1&&this.closed&&e.push(e[0])}return e}}class Vt extends is{constructor(t,e){super(),this._start=new k(t),this._end=new k(e)}get startPoint(){return this._start}set startPoint(t){this._start.copy(t),this._boundingBoxNeedsUpdate=!0}get endPoint(){return this._end}set endPoint(t){this._end.copy(t),this._boundingBoxNeedsUpdate=!0}getPoints(){return[this.startPoint,this.endPoint]}get length(){return this.startPoint.distanceTo(this.endPoint)}calculateBoundingBox(){const t=new k(Math.min(this._start.x,this._end.x),Math.min(this._start.y,this._end.y)),e=new k(Math.max(this._start.x,this._end.x),Math.max(this._start.y,this._end.y));return new pt(t,e)}transform(t){return this._start.applyMatrix2d(t),this._end.applyMatrix2d(t),this._boundingBoxNeedsUpdate=!0,this}get closed(){return!1}copy(t){return this.startPoint=t.startPoint,this.endPoint=t.endPoint,this._boundingBoxNeedsUpdate=!0,this}clone(){return new Vt(this._start.clone(),this._end.clone())}}let Fs=class Ct extends is{constructor(t=[]){super(),this._curves=t}get curves(){return this._curves}static buildFromEdges(t,e=.001){if(t.length===0)return[];const s=[...t],n=[],r=e*e,a=(o,l)=>{const c=o.x-l.x,u=o.y-l.y;return c*c+u*u<=r};for(;s.length>0;){const o=[],l=s.shift();o.push(l);const c=Ct.getEdgeStartPoint(l);let u=Ct.getEdgeEndPoint(l);if(!a(c,u))for(;s.length>0;){const d=Ct.findConnectingEdge(s,u,r);if(d.index<0)break;let g=s.splice(d.index,1)[0];if(d.reverse&&(g=Ct.reverseEdge(g)),o.push(g),u=Ct.getEdgeEndPoint(g),a(u,c))break}n.push(new Ct(o))}return n}add(t){this._curves.push(t),this._boundingBoxNeedsUpdate=!0}get numberOfEdges(){return this._curves.length}get startPoint(){if(this._curves.length>0){const t=this._curves[0].startPoint;return new k(t.x,t.y)}throw new Error("Start point does not exist in an empty loop.")}get endPoint(){return this.startPoint}get length(){let t=0;return this._curves.forEach(e=>{t+=e.length}),t}calculateBoundingBox(){const t=this.getPoints(100),e=new pt;return e.setFromPoints(t),e}transform(t){const e=new G().set(t.elements[0],t.elements[3],0,t.elements[6],t.elements[1],t.elements[4],0,t.elements[7],0,0,1,0,0,0,0,1);return this._curves.forEach(s=>{s instanceof Dt?s.transform(e):s.transform(t)}),this._boundingBoxNeedsUpdate=!0,this}clone(){return new Ct(this._curves.map(t=>t.clone()))}get closed(){return!0}getPoints(t){const e=[];return this.curves.forEach(s=>{s.getPoints(t).forEach(n=>{e.push(new k(n.x,n.y))})}),e}static findConnectingEdge(t,e,s){let n=-1,r=!1,a=Number.POSITIVE_INFINITY;for(let o=0;o<t.length;o++){const l=t[o],c=Ct.getEdgeStartPoint(l),u=Ct.getEdgeEndPoint(l),d=e.x-c.x,g=e.y-c.y,p=d*d+g*g;p<a&&(a=p,n=o,r=!1);const m=e.x-u.x,y=e.y-u.y,x=m*m+y*y;x<a&&(a=x,n=o,r=!0)}return a>s?{index:-1,reverse:!1}:{index:n,reverse:r}}static getEdgeStartPoint(t){const e=t.startPoint;return new k(e.x,e.y)}static getEdgeEndPoint(t){const e=t.endPoint;return new k(e.x,e.y)}static reverseEdge(t){return t instanceof Vt?new Vt(t.endPoint,t.startPoint):t instanceof ye?new ye(t.center,t.radius,t.endAngle,t.startAngle,!t.clockwise):t instanceof Bs?new Bs(t.center,t.majorAxisRadius,t.minorAxisRadius,t.endAngle,t.startAngle,!t.clockwise,t.rotation):t instanceof Dt?Ct.reverseSplineEdge(t):t}static reverseSplineEdge(t){const e=[...t.controlPoints].reverse(),s=t.knots,n=s[0],r=s[s.length-1],a=s.map(c=>n+r-c).reverse(),o=t.weights,l=o.length>0?[...o].reverse():void 0;return new Dt(e,a,l,t.degree,t.closed)}};class cn{constructor(){this.c0=0,this.c1=0,this.c2=0,this.c3=0}init(t,e,s,n){this.c0=t,this.c1=s,this.c2=-3*t+3*e-2*s-n,this.c3=2*t-2*e+s+n}initCatmullRom(t,e,s,n,r){this.init(e,s,r*(s-t),r*(n-e))}initNonuniformCatmullRom(t,e,s,n,r,a,o){let l=(e-t)/r-(s-t)/(r+a)+(s-e)/a,c=(s-e)/a-(n-e)/(a+o)+(n-s)/o;l*=a,c*=a,this.init(e,s,l,c)}calc(t){const e=t*t,s=e*t;return this.c0+this.c1*t+this.c2*e+this.c3*s}}class Ji extends $s{constructor(t=[],e=!1,s="centripetal",n=.5){super(),this.isCatmullRomCurve3d=!0,this.type="CatmullRomCurve3d",this._tmp=new b,this._px=new cn,this._py=new cn,this._pz=new cn,this._points=t.map(r=>new w(r)),this._closed=e,this._curveType=s,this._tension=n}get points(){return this._points}get closed(){return this._closed}get curveType(){return this._curveType}get tension(){return this._tension}get startPoint(){return this._points.length>0?this._points[0]:new w}get endPoint(){return this._points.length>0?this._points[this._points.length-1]:new w}get length(){if(this._points.length<2)return 0;let t=0;for(let e=1;e<this._points.length;e++)t+=this._points[e-1].distanceTo(this._points[e]);return this._closed&&this._points.length>2&&(t+=this._points[this._points.length-1].distanceTo(this._points[0])),t}getPoint(t,e=new w){const s=e,n=this._points,r=n.length;if(r===0)return s.set(0,0,0);if(r===1)return s.copy(n[0]);const a=(r-(this._closed?0:1))*t;let o=Math.floor(a),l=a-o;this._closed?o+=o>0?0:(Math.floor(Math.abs(o)/r)+1)*r:l===0&&o===r-1&&(o=r-2,l=1);let c,u;this._closed||o>0?c=n[(o-1)%r]:(this._tmp.subVectors(n[0],n[1]).add(n[0]),c=new w(this._tmp.x,this._tmp.y,this._tmp.z));const d=n[o%r],g=n[(o+1)%r];if(this._closed||o+2<r?u=n[(o+2)%r]:(this._tmp.subVectors(n[r-1],n[r-2]).add(n[r-1]),u=new w(this._tmp.x,this._tmp.y,this._tmp.z)),this._curveType==="centripetal"||this._curveType==="chordal"){const p=this._curveType==="chordal"?.5:.25;let m=Math.pow(c.distanceToSquared(d),p),y=Math.pow(d.distanceToSquared(g),p),x=Math.pow(g.distanceToSquared(u),p);y<1e-4&&(y=1),m<1e-4&&(m=y),x<1e-4&&(x=y),this._px.initNonuniformCatmullRom(c.x,d.x,g.x,u.x,m,y,x),this._py.initNonuniformCatmullRom(c.y,d.y,g.y,u.y,m,y,x),this._pz.initNonuniformCatmullRom(c.z,d.z,g.z,u.z,m,y,x)}else this._curveType==="catmullrom"&&(this._px.initCatmullRom(c.x,d.x,g.x,u.x,this._tension),this._py.initCatmullRom(c.y,d.y,g.y,u.y,this._tension),this._pz.initCatmullRom(c.z,d.z,g.z,u.z,this._tension));return s.set(this._px.calc(l),this._py.calc(l),this._pz.calc(l)),s}getPoints(t){const e=[];for(let s=0;s<=t;s++)e.push(this.getPoint(s/t));return e}setPoints(t){this._points=t.map(e=>new w(e)),this._boundingBoxNeedsUpdate=!0}setClosed(t){this._closed!==t&&(this._closed=t,this._boundingBoxNeedsUpdate=!0)}setCurveType(t){this._curveType=t}setTension(t){this._tension=t}clone(){return new Ji(this._points.map(t=>t.clone()),this._closed,this._curveType,this._tension)}transform(t){return this._points=this._points.map(e=>{const s=new w;return s.copy(e),s.applyMatrix4(t),s}),this._boundingBoxNeedsUpdate=!0,this}calculateBoundingBox(){if(this._points.length===0)return new C;const t=new C;return this._points.forEach(e=>{t.expandByPoint(e)}),t}}let Bt=class Ps{constructor(t,e,s,n){this._degree=t,this._knots=[...e],this._controlPoints=s.map(r=>({x:r.x,y:r.y,z:r.z})),this._weights=n?[...n]:new Array(s.length).fill(1)}degree(){return this._degree}knots(){return[...this._knots]}controlPoints(){return this._controlPoints.map(t=>({x:t.x,y:t.y,z:t.z}))}weights(){return[...this._weights]}clone(){return new Ps(this._degree,this._knots,this._controlPoints,this._weights)}point(t){const e=this._controlPoints.map(s=>[s.x,s.y,s.z]);return Ts(t,this._degree,this._knots,e,this._weights)}length(){const t=this._controlPoints.map(e=>[e.x,e.y,e.z]);return yo(this._degree,this._knots,t,this._weights)}static byKnotsControlPointsWeights(t,e,s,n){return new Ps(t,e,s,n)}static byPoints(t,e,s="Uniform",n,r){const a=Kn(t,e,s,n,r),o=a.controlPoints.map(l=>({x:l[0],y:l[1],z:l[2]}));return new Ps(e,a.knots,o,a.weights)}getParameterRange(){const t=this._knots[this._degree],e=this._knots[this._knots.length-this._degree-1];return{start:t,end:e}}getPoints(t){const e=[],{start:s,end:n}=this.getParameterRange();for(let r=0;r<=t;r++){const a=s+(n-s)*(r/t);e.push(this.point(a))}return e}isClosed(t=1e-6){const{start:e,end:s}=this.getParameterRange(),n=this.point(e),r=this.point(s),a=n[0]-r[0],o=n[1]-r[1],l=n[2]-r[2];return Math.sqrt(a*a+o*o+l*l)<t}static createFitPointsForClosedCurve(t){if(t.length<4)throw new Error("At least 4 points are required for a closed NURBS curve");const e=new Ji(t,!0,"centripetal"),s=Math.max(50,t.length*2);return e.getPoints(s)}static createClosedCurve(t,e,s="Chord"){const n=this.createFitPointsForClosedCurve(t).map(r=>[r.x,r.y,r.z]);return Ps.byPoints(n,e,s)}},Dt=class mi extends $s{constructor(t,e,s,n,r,a){super();const o=arguments.length;if(this._degree=3,this._closed=!1,Array.isArray(e)){if(o<2||o>5)throw yt.ILLEGAL_PARAMETERS;this._controlPoints=t;let l,c=3,u=!1;if(o>=3&&(Array.isArray(s)?(l=s,o>=4&&(c=n||3),o>=5&&(u=r)):s!==void 0&&(c=s||3,o>=4&&(u=n))),s===void 0&&o>=4&&(c=n||3,o>=5&&(u=r)),this._degree=c,this._closed=u,this._controlPoints.length<this._degree+1)throw yt.ILLEGAL_PARAMETERS;this._nurbsCurve=Bt.byKnotsControlPointsWeights(this._degree,e,this._controlPoints,l)}else{if(o<2||o>6)throw yt.ILLEGAL_PARAMETERS;this._fitPoints=t,this._knotParameterization=e,o>=3&&(this._degree=s||3);const l=typeof n=="boolean";o>=4&&l&&(this._closed=n),l?(o>=5&&(this._startTangent=r),o>=6&&(this._endTangent=a)):(o>=4&&(this._startTangent=n),o>=5&&(this._endTangent=r)),this._closed&&(this._startTangent=void 0,this._endTangent=void 0);const c=(this._startTangent?1:0)+(this._endTangent?1:0);if(this._fitPoints.length+c<this._degree+1)throw yt.ILLEGAL_PARAMETERS;if(this._closed)this._nurbsCurve=Bt.createClosedCurve(this._fitPoints,this._degree,this._knotParameterization);else{const u=this.toNurbsPoints(this._fitPoints);this._nurbsCurve=Bt.byPoints(u,this._degree,this._knotParameterization,this._startTangent?this.toNurbsPoint(this._startTangent):void 0,this._endTangent?this.toNurbsPoint(this._endTangent):void 0)}this._controlPoints=this.toGePoints(this._nurbsCurve.controlPoints().map(u=>[u.x,u.y,u.z||0]))}}buildCurve(){if(this._fitPoints&&this._knotParameterization){if(this._closed){const t=Bt.createFitPointsForClosedCurve(this._fitPoints),e=this.toNurbsPoints(t);this._nurbsCurve=Bt.byPoints(e,this._degree,this._knotParameterization)}else{const t=this.toNurbsPoints(this._fitPoints);this._nurbsCurve=Bt.byPoints(t,this._degree,this._knotParameterization,this._startTangent?this.toNurbsPoint(this._startTangent):void 0,this._endTangent?this.toNurbsPoint(this._endTangent):void 0)}this._controlPoints=this.toGePoints(this._nurbsCurve.controlPoints().map(t=>[t.x,t.y,t.z||0]))}else if(this._controlPoints)if(this._closed){const t=Bt.createFitPointsForClosedCurve(this._controlPoints),e=this.toNurbsPoints(t);this._nurbsCurve=Bt.byPoints(e,this._degree,this._knotParameterization),this._controlPoints=this.toGePoints(this._nurbsCurve.controlPoints().map(s=>[s.x,s.y,s.z||0]))}else{const t=this._nurbsCurve.knots(),e=this._nurbsCurve.weights();this._nurbsCurve=Bt.byKnotsControlPointsWeights(this._degree,t,this._controlPoints,e)}}setClosed(t){this._closed!==t&&(this._closed=t,this._boundingBoxNeedsUpdate=!0,this.buildCurve())}get degree(){return this._degree}get knotParameterization(){return this._knotParameterization}get controlPoints(){return this._controlPoints.map(t=>({x:t.x,y:t.y,z:t.z||0}))}get fitPoints(){var t;return(t=this._fitPoints)==null?void 0:t.map(e=>({x:e.x,y:e.y,z:e.z||0}))}get knots(){return[...this._nurbsCurve.knots()]}get weights(){return[...this._nurbsCurve.weights()]}get startPoint(){const t=this._nurbsCurve.knots(),e=this._nurbsCurve.degree(),s=t[e],n=this._nurbsCurve.point(s);return new w(n[0],n[1],n[2])}get endPoint(){const t=this._nurbsCurve.knots(),e=this._nurbsCurve.degree(),s=t[t.length-e-1],n=this._nurbsCurve.point(s);return new w(n[0],n[1],n[2])}get length(){return this._nurbsCurve.length()}getFitPointAt(t){if(!this._fitPoints)throw new Error("No fit points in this spline");const e=this._fitPoints.length,s=t<0||t>=e?e-1:t,n=this._fitPoints[s];return{x:n.x,y:n.y,z:n.z||0}}getControlPointAt(t){const e=this._controlPoints.length,s=t<0||t>=e?e-1:t;return this._controlPoints[s]}getPoints(t=100){const e=this._nurbsCurve,s=[],n=e.knots(),r=this._nurbsCurve.degree(),a=n[r],o=n[n.length-r-1],l=(o-a)/(t-1);for(let c=0;c<t;c++){const u=c===t-1?o:a+c*l,d=e.point(u);s.push(new w(d[0],d[1],d[2]))}return s}getCurvePoints(t,e){const s=[],n=t.knots(),r=t.degree(),a=n[r],o=(n[n.length-r-1]-a)/(e-1);for(let l=0;l<e;l++){const c=a+l*o;s.push(t.point(c))}return s}calculateBoundingBox(){const t=this.getPoints(100);return new C().setFromPoints(t)}get closed(){return this._closed}set closed(t){this.setClosed(t)}transform(t){if(this._fitPoints&&this._knotParameterization)this._fitPoints=this._fitPoints.map(e=>new w(e).applyMatrix4(t)),this._startTangent&&(this._startTangent=new w(this._startTangent).transformDirection(t)),this._endTangent&&(this._endTangent=new w(this._endTangent).transformDirection(t)),this.buildCurve();else{const e=this._nurbsCurve.knots(),s=this._nurbsCurve.weights();this._controlPoints=this._controlPoints.map(n=>new w(n).applyMatrix4(t)),this._nurbsCurve=Bt.byKnotsControlPointsWeights(this._degree,e,this._controlPoints,s.length>0?s:void 0)}return this._boundingBoxNeedsUpdate=!0,this}clone(){return this._fitPoints&&this._knotParameterization?new mi(this._fitPoints.map(t=>({x:t.x,y:t.y,z:t.z||0})),this._knotParameterization,this._degree,this._closed,this._startTangent?{x:this._startTangent.x,y:this._startTangent.y,z:this._startTangent.z||0}:void 0,this._endTangent?{x:this._endTangent.x,y:this._endTangent.y,z:this._endTangent.z||0}:void 0):new mi(this._controlPoints.map(t=>({x:t.x,y:t.y,z:t.z||0})),this._nurbsCurve.knots(),this._nurbsCurve.weights(),this._degree,this._closed)}toNurbsPoints(t){const e=new Array(t.length);return t.forEach((s,n)=>{e[n]=[s.x,s.y,s.z||0]}),e}toGePoints(t){const e=new Array(t.length);return t.forEach((s,n)=>{e[n]={x:s[0],y:s[1],z:s[2]}}),e}toNurbsPoint(t){return[t.x,t.y,t.z||0]}static createClosedSpline(t,e="Uniform",s=3){if(t.length<s+1)throw new Error(`At least ${s+1} points are required for a degree ${s} closed spline`);return new mi(t,e,s,!0)}};var tr=(i=>(i.ClosedFilled="",i.Dot="_DOT",i.DotSmall="_DOTSMALL",i.DotBlank="_DOTBLANK",i.Origin="_ORIGIN",i.Origin2="_ORIGIN2",i.Open="_OPEN",i.Open90="_OPEN90",i.Open30="_OPEN30",i.Closed="_CLOSED",i.Small="_SMALL",i.None="_NONE",i.Oblique="_OBLIQUE",i.BoxFilled="_BOXFILLED",i.Box="_BOXBLANK",i.ClosedBlank="_CLOSEDBLANK",i.DatumBlank="_DATUMBLANK",i.DatumFilled="_DATUMFILLED",i.Integral="_INTEGRAL",i.ArchTick="_ARCHTICK",i))(tr||{}),We=(i=>(i[i.ByBlock=-2]="ByBlock",i[i.ByDIPs=-4]="ByDIPs",i[i.ByLayer=-1]="ByLayer",i[i.ByLineWeightDefault=-3]="ByLineWeightDefault",i[i.LineWeight000=0]="LineWeight000",i[i.LineWeight005=5]="LineWeight005",i[i.LineWeight009=9]="LineWeight009",i[i.LineWeight013=13]="LineWeight013",i[i.LineWeight015=15]="LineWeight015",i[i.LineWeight018=18]="LineWeight018",i[i.LineWeight020=20]="LineWeight020",i[i.LineWeight025=25]="LineWeight025",i[i.LineWeight030=30]="LineWeight030",i[i.LineWeight035=35]="LineWeight035",i[i.LineWeight040=40]="LineWeight040",i[i.LineWeight050=50]="LineWeight050",i[i.LineWeight053=53]="LineWeight053",i[i.LineWeight060=60]="LineWeight060",i[i.LineWeight070=70]="LineWeight070",i[i.LineWeight080=80]="LineWeight080",i[i.LineWeight090=90]="LineWeight090",i[i.LineWeight100=100]="LineWeight100",i[i.LineWeight106=106]="LineWeight106",i[i.LineWeight120=120]="LineWeight120",i[i.LineWeight140=140]="LineWeight140",i[i.LineWeight158=158]="LineWeight158",i[i.LineWeight200=200]="LineWeight200",i[i.LineWeight211=211]="LineWeight211",i))(We||{}),ae=(i=>(i[i.LEFT_TO_RIGHT=1]="LEFT_TO_RIGHT",i[i.RIGHT_TO_LEFT=2]="RIGHT_TO_LEFT",i[i.TOP_TO_BOTTOM=3]="TOP_TO_BOTTOM",i[i.BOTTOM_TO_TOP=4]="BOTTOM_TO_TOP",i[i.BY_STYLE=5]="BY_STYLE",i))(ae||{}),ot=(i=>(i[i.TopLeft=1]="TopLeft",i[i.TopCenter=2]="TopCenter",i[i.TopRight=3]="TopRight",i[i.MiddleLeft=4]="MiddleLeft",i[i.MiddleCenter=5]="MiddleCenter",i[i.MiddleRight=6]="MiddleRight",i[i.BottomLeft=7]="BottomLeft",i[i.BottomCenter=8]="BottomCenter",i[i.BottomRight=9]="BottomRight",i))(ot||{}),er=(i=>(i[i.OPTIMIZED_2D=0]="OPTIMIZED_2D",i[i.WIREFRAME=1]="WIREFRAME",i[i.HIDDEN_LINE=2]="HIDDEN_LINE",i[i.FLAT_SHADED=3]="FLAT_SHADED",i[i.GOURAUD_SHADED=4]="GOURAUD_SHADED",i[i.FLAT_SHADED_WITH_WIREFRAME=5]="FLAT_SHADED_WITH_WIREFRAME",i[i.GOURAUD_SHADED_WITH_WIREFRAME=6]="GOURAUD_SHADED_WITH_WIREFRAME",i))(er||{}),sr=(i=>(i[i.NON_ORTHOGRAPHIC=0]="NON_ORTHOGRAPHIC",i[i.TOP=1]="TOP",i[i.BOTTOM=2]="BOTTOM",i[i.FRONT=3]="FRONT",i[i.BACK=4]="BACK",i[i.LEFT=5]="LEFT",i[i.RIGHT=6]="RIGHT",i))(sr||{}),ir=(i=>(i[i.ONE_DISTANT_LIGHT=0]="ONE_DISTANT_LIGHT",i[i.TWO_DISTANT_LIGHTS=1]="TWO_DISTANT_LIGHTS",i))(ir||{});let fo=class bo{constructor(){this._number=-1,this._id="",this._groupId="",this._centerPoint=new w,this._height=0,this._width=0,this._viewCenter=new w,this._viewHeight=0}get number(){return this._number}set number(t){this._number=t}get id(){return this._id}set id(t){this._id=t}get groupId(){return this._groupId}set groupId(t){this._groupId=t}get centerPoint(){return this._centerPoint}set centerPoint(t){this._centerPoint.copy(t)}get height(){return this._height}set height(t){this._height=t}get width(){return this._width}set width(t){this._width=t}get box(){const t=new pt;return t.setFromCenterAndSize(this.centerPoint,{x:this.width,y:this.height}),t}get viewCenter(){return this._viewCenter}set viewCenter(t){this._viewCenter.copy(t)}get viewHeight(){return this._viewHeight}set viewHeight(t){this._viewHeight=t}get viewWidth(){return this.viewHeight*(this.width/this.height)}get viewBox(){const t=new pt;return t.setFromCenterAndSize(this.viewCenter,{x:this.viewWidth,y:this.viewHeight}),t}clone(){const t=new bo;return t.id=this.id,t.groupId=this.groupId,t.number=this.number,t.centerPoint.copy(this.centerPoint),t.height=this.height,t.width=this.width,t.viewCenter.copy(this.viewCenter),t.viewHeight=this.viewHeight,t}copy(t){return this.id=t.id,this.groupId=t.groupId,this.number=t.number,this.centerPoint.copy(t.centerPoint),this.height=t.height,this.width=t.width,this.viewCenter.copy(t.viewCenter),this.viewHeight=t.viewHeight,this}};const ur=class ur extends he{constructor(){super(...arguments),this._visibility=!0,this._transparency=new Qi}get type(){return this.constructor.typeName}get layer(){return this._layer==null&&(this._layer=this.database.clayer??"0"),this._layer}set layer(t){this._layer=t}get color(){return this._color==null&&(this._color=new Q,this.database.cecolor&&this._color.copy(this.database.cecolor)),this._color}set color(t){this._color==null&&(this._color=new Q),this._color.copy(t)}get resolvedColor(){var e;let t=this.color;if(t.isByLayer){const s=this.getLayerColor();s&&s.RGB!=null&&(t=s)}else if(t.isByBlock){const s=this.database.cecolor;if(s&&(t=s,t.isByLayer)){const n=this.database.clayer||this.layer,r=this.database.tables.layerTable.getAt(n);((e=r==null?void 0:r.color)==null?void 0:e.RGB)!=null&&(t=r.color)}}return t}get rgbColor(){const e=this.resolvedColor.RGB;return e??16777215}get lineType(){var t;return this._lineType==null&&(this._lineType=((t=this.database)==null?void 0:t.celtype)??At),this._lineType}set lineType(t){t?t.toUpperCase()==="BYLAYER"?this._lineType=At:t.toUpperCase()==="BYBLOCK"?this._lineType=Qe:this._lineType=t:this._lineType=At}get lineWeight(){return this._lineWeight==null&&(this._lineWeight=this.database.celweight??We.ByLayer),this._lineWeight}set lineWeight(t){this._lineWeight=t}get linetypeScale(){return this._linetypeScale==null&&(this._linetypeScale=this.database.celtscale??-1),this._linetypeScale}set linetypeScale(t){this._linetypeScale=t}get visibility(){return this._visibility}set visibility(t){this._visibility=t}get transparency(){return this._transparency}set transparency(t){this._transparency=t.clone()}dxfOutFields(t){t.writeSubclassMarker("AcDbEntity"),t.writeString(8,this.layer),t.writeString(6,this.lineType),t.writeDouble(48,this.linetypeScale),t.writeInt16(60,this.visibility?0:1),t.writeCmColor(this.color),t.writeInt16(370,this.lineWeight),t.writeTransparency(this.transparency);const e=this.database.tables.blockTable.getIdAt(this.ownerId);return e!=null&&e.isPaperSapce&&t.writeInt16(67,1),this}resolveEffectiveProperties(){this._layer==null&&(this._layer=this.database.clayer??"0"),this._color==null&&(this._color=new Q,this.database.cecolor&&this._color.copy(this.database.cecolor)),this._lineType==null&&(this._lineType=this.database.celtype??At),this._linetypeScale==null&&(this._linetypeScale=this.database.celtscale??-1),this._lineWeight==null&&(this._lineWeight=this.database.celweight??We.ByLayer)}get properties(){return{type:this.type,groups:[this.getGeneralProperties()]}}subGetGripPoints(){return new Array}subGetOsnapPoints(t,e,s,n,r,a){}transformBy(t){return this}erase(){return this.database.tables.blockTable.removeEntity(this.objectId)}worldDraw(t,e){const s=t.subEntityTraits;s.color=this.resolvedColor,s.rgbColor=this.rgbColor,s.lineType=this.lineStyle,s.lineTypeScale=this.linetypeScale,s.lineWeight=this.lineWeight,s.transparency=this.transparency,s.layer=this.layer,s.drawOrder=0,"thickness"in this&&(s.thickness=this.thickness);const n=this.subWorldDraw(t,e);return this.attachEntityInfo(n),n}triggerModifiedEvent(){this.database.events.entityModified.dispatch({database:this.database,entity:this})}getGeneralProperties(){return{groupName:"general",properties:[{name:"handle",type:"int",editable:!1,accessor:{get:()=>this.objectId}},{name:"color",type:"color",editable:!0,accessor:{get:()=>this.color,set:t=>{this.color.copy(t)}}},{name:"layer",type:"string",editable:!0,accessor:{get:()=>this.layer,set:t=>{this.layer=t}}},{name:"linetype",type:"linetype",editable:!0,accessor:{get:()=>this.lineType,set:t=>{this.lineType=t}}},{name:"linetypeScale",type:"float",editable:!0,accessor:{get:()=>this.linetypeScale,set:t=>{this.linetypeScale=t}}},{name:"lineWeight",type:"lineweight",editable:!0,accessor:{get:()=>this.lineWeight,set:t=>{this.lineWeight=t}}},{name:"transparency",type:"transparency",editable:!0,accessor:{get:()=>this.transparency,set:t=>{this.transparency=t}}}]}}get lineStyle(){var n;const{type:t,name:e}=this.getLineType(),s=(n=this.database)==null?void 0:n.tables.linetypeTable.getAt(e);return s?{type:t,...s.linetype}:{type:t,name:e,standardFlag:0,description:"",totalPatternLength:0}}getLineType(){if(this.lineType==At){const t=this.database.tables.layerTable.getAt(this.layer);if(t&&t.linetype)return{type:"ByLayer",name:t.linetype}}else return this.lineType==Qe?{type:"ByBlock",name:Ke}:{type:"UserSpecified",name:this.lineType};return{type:"UserSpecified",name:Ke}}getLayerColor(){const t=this.database.tables.layerTable.getAt(this.layer);return t!=null?t.color:null}attachEntityInfo(t){t&&(t.objectId=this.objectId,this.attrs.has("ownerId")&&(t.ownerId=this.ownerId),t.layerName=this.layer,t.visible=this.visibility)}};ur.typeName="Entity";let gt=ur;const pr=class pr extends gt{};pr.typeName="Curve";let rt=pr;var $e=(i=>(i[i.SimplePoly=0]="SimplePoly",i[i.FitCurvePoly=1]="FitCurvePoly",i[i.QuadSplinePoly=2]="QuadSplinePoly",i[i.CubicSplinePoly=3]="CubicSplinePoly",i))($e||{});const gr=class gr extends rt{get dxfTypeName(){return"POLYLINE"}constructor(t,e,s=0,n=!1,r=0,a=0,o=null){super(),this._polyType=t,this._elevation=s;const l=o&&(o==null?void 0:o.length)===e.length,c=e.map((u,d)=>({x:u.x,y:u.y,bulge:l?o[d]:void 0}));this._geo=new Mt(c,n)}get polyType(){return this._polyType}set polyType(t){this._polyType=t}get elevation(){return this._elevation}set elevation(t){this._elevation=t}get closed(){return this._geo.closed}set closed(t){this._geo.closed=t}get numberOfVertices(){return this._geo.numberOfVertices}getPointAt(t){return this._geo.getPointAt(t)}getBulgeAt(t){const e=this._geo.vertices[t];return(e==null?void 0:e.bulge)||0}get geometricExtents(){const t=this._geo.box;return new C({x:t.min.x,y:t.min.y,z:this._elevation},{x:t.max.x,y:t.max.y,z:this._elevation})}subGetGripPoints(){const t=new Array;for(let e=0;e<this._geo.numberOfVertices;++e){const s=this._geo.getPointAt(e);t.push(new w(s.x,s.y,0))}return t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:for(let r=0;r<this._geo.numberOfVertices;++r){const a=this._geo.getPointAt(r);n.push(new w(a.x,a.y,0))}break}}transformBy(t){const e=t.determinant()<0;let s=this._elevation;return this._geo.vertices.forEach(n=>{const r=new w(n.x,n.y,this._elevation).applyMatrix4(t);n.x=r.x,n.y=r.y,s=r.z,e&&n.bulge!=null&&(n.bulge=-n.bulge)}),this._elevation=s,this._geo._boundingBoxNeedsUpdate=!0,this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"vertices",type:"array",editable:!1,itemSchema:{properties:[{name:"x",type:"float",editable:!0},{name:"y",type:"float",editable:!0}]},accessor:{get:()=>this._geo.vertices}},{name:"elevation",type:"float",editable:!0,accessor:{get:()=>this.elevation,set:t=>{this.elevation=t}}},{name:"length",type:"float",editable:!1,accessor:{get:()=>this._geo.length}}]},{groupName:"others",properties:[{name:"closed",type:"float",editable:!0,accessor:{get:()=>this.closed,set:t=>{this.closed=t}}}]}]}}subWorldDraw(t){const e=[];return this._geo.getPoints(100).forEach(n=>e.push(new w().set(n.x,n.y,this.elevation))),t.lines(e)}dxfOut(t,e=!1){super.dxfOut(t,e);for(let s=0;s<this.numberOfVertices;++s)t.writeStart("VERTEX"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDb2dVertex"),t.writePoint3d(10,{x:this.getPointAt(s).x,y:this.getPointAt(s).y,z:this.elevation}),t.writeDouble(42,this.getBulgeAt(s)),t.writeInt16(70,0);return t.writeStart("SEQEND"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),this}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDb2dPolyline");let e=this.closed?1:0;return this.polyType===1&&(e|=2),this.polyType===2&&(e|=4),this.polyType===3&&(e|=8),t.writeInt16(66,this.numberOfVertices>0?1:0),t.writeInt16(70,e),t.writeDouble(10,0),t.writeDouble(20,0),t.writeDouble(30,this.elevation),this}};gr.typeName="2dPolyline";let Pi=gr;var Io=(i=>(i[i.Vertex=0]="Vertex",i[i.CurveFitVertex=1]="CurveFitVertex",i[i.SplineFitVertex=8]="SplineFitVertex",i[i.SplineCtlVertex=9]="SplineCtlVertex",i))(Io||{});const mr=class mr extends gt{get dxfTypeName(){return"VERTEX"}constructor(){super(),this._position=new w,this._bulge=0,this._startWidth=0,this._endWidth=0,this._vertexType=0}get position(){return this._position}set position(t){this._position.copy(t)}get bulge(){return this._bulge}set bulge(t){this._bulge=t}get startWidth(){return this._startWidth}set startWidth(t){this._startWidth=t}get endWidth(){return this._endWidth}set endWidth(t){this._endWidth=t}get vertexType(){return this._vertexType}set vertexType(t){this._vertexType=t}get geometricExtents(){return new C().expandByPoint(this._position)}subGetGripPoints(){const t=new Array;return t.push(this._position),t}subGetOsnapPoints(t,e,s,n){n.push(this._position)}transformBy(t){return this._position.applyMatrix4(t),this}subWorldDraw(t){}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDb2dVertex"),t.writePoint2d(10,this.position),t.writeDouble(40,this.startWidth),t.writeDouble(41,this.endWidth),t.writeDouble(42,this.bulge),t.writeInt16(70,this.vertexType),this}};mr.typeName="2dVertex";let Ln=mr;var Ms=(i=>(i[i.SimplePoly=0]="SimplePoly",i[i.QuadSplinePoly=1]="QuadSplinePoly",i[i.CubicSplinePoly=2]="CubicSplinePoly",i))(Ms||{});const yr=class yr extends rt{get dxfTypeName(){return"POLYLINE"}constructor(t,e,s=!1){super(),this._polyType=t,this._geo=new Mt(e,s)}get polyType(){return this._polyType}set polyType(t){this._polyType=t}get closed(){return this._geo.closed}set closed(t){this._geo.closed=t}get numberOfVertices(){return this._geo.numberOfVertices}getPointAt(t){const e=this._geo.vertices[t];return new w(e.x,e.y,e.z||0)}get geometricExtents(){const t=this._geo.vertices.map(e=>new w(e.x,e.y,e.z||0));return new C().setFromPoints(t)}subGetGripPoints(){const t=new Array;for(let e=0;e<this._geo.numberOfVertices;++e){const s=this._geo.getPointAt(e);t.push(new w(s.x,s.y,0))}return t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:for(let r=0;r<this._geo.numberOfVertices;++r)n.push(this.getPointAt(r));break}}transformBy(t){return this._geo.vertices.forEach(e=>{const s=new w(e.x,e.y,e.z||0).applyMatrix4(t);e.x=s.x,e.y=s.y,e.z=s.z}),this._geo._boundingBoxNeedsUpdate=!0,this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"vertices",type:"array",editable:!1,itemSchema:{properties:[{name:"x",type:"float",editable:!0},{name:"y",type:"float",editable:!0},{name:"z",type:"float",editable:!0}]},accessor:{get:()=>this._geo.vertices}},{name:"length",type:"float",editable:!1,accessor:{get:()=>this._geo.length}}]},{groupName:"others",properties:[{name:"closed",type:"float",editable:!0,accessor:{get:()=>this.closed,set:t=>{this.closed=t}}}]}]}}subWorldDraw(t){const e=this._geo.vertices.map(s=>new w(s.x,s.y,s.z||0));return t.lines(e)}dxfOut(t,e=!1){super.dxfOut(t,e);for(let s=0;s<this.numberOfVertices;++s){const n=this.getPointAt(s);t.writeStart("VERTEX"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDb3dPolylineVertex"),t.writePoint3d(10,{x:n.x,y:n.y,z:n.z}),t.writeInt16(70,32)}return t.writeStart("SEQEND"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),this}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDb3dPolyline");let e=this.closed?1:0;return e|=8,this.polyType===1&&(e|=16),this.polyType===2&&(e|=32),t.writeInt16(66,this.numberOfVertices>0?1:0),t.writeInt16(70,e),this}};yr.typeName="3dPolyline";let Si=yr;var Po=(i=>(i[i.SimpleVertex=0]="SimpleVertex",i[i.ControlVertex=1]="ControlVertex",i[i.FitVertex=2]="FitVertex",i))(Po||{});const _r=class _r extends gt{get dxfTypeName(){return"VERTEX"}constructor(){super(),this._position=new w,this._vertexType=0}get position(){return this._position}set position(t){this._position.copy(t)}get vertexType(){return this._vertexType}set vertexType(t){this._vertexType=t}get geometricExtents(){return new C().expandByPoint(this._position)}subGetGripPoints(){const t=new Array;return t.push(this._position),t}subGetOsnapPoints(t,e,s,n){n.push(this._position)}transformBy(t){return this._position.applyMatrix4(t),this}subWorldDraw(t){}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDb3dPolylineVertex"),t.writePoint3d(10,this.position),t.writeInt16(70,this.vertexType|32),this}};_r.typeName="3dVertex";let On=_r;const wr=class wr extends rt{get dxfTypeName(){return"ARC"}constructor(t,e,s,n,r=b.Z_AXIS){super();const a=Qn(r);this._geo=new je(t,e,s,n,r,a)}get center(){return this._geo.center}set center(t){this._geo.center=t}get radius(){return this._geo.radius}set radius(t){this._geo.radius=t}get startAngle(){return this._geo.startAngle}set startAngle(t){this._geo.startAngle=t}get endAngle(){return this._geo.endAngle}set endAngle(t){this._geo.endAngle=t}get normal(){return this._geo.normal}set normal(t){this._geo.normal=t}get startPoint(){return this._geo.startPoint}get endPoint(){return this._geo.endPoint}get midPoint(){return this._geo.midPoint}get geometricExtents(){return this._geo.box}get closed(){return this._geo.closed}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"centerX",type:"float",editable:!0,accessor:{get:()=>this.center.x,set:t=>{this.center.x=t}}},{name:"centerY",type:"float",editable:!0,accessor:{get:()=>this.center.y,set:t=>{this.center.y=t}}},{name:"centerZ",type:"float",editable:!0,accessor:{get:()=>this.center.z,set:t=>{this.center.z=t}}},{name:"radius",type:"float",editable:!0,accessor:{get:()=>this.radius,set:t=>{this.radius=t}}},{name:"startAngle",type:"float",editable:!0,accessor:{get:()=>this.startAngle,set:t=>{this.startAngle=t}}},{name:"endAngle",type:"float",editable:!0,accessor:{get:()=>this.endAngle,set:t=>{this.endAngle=t}}},{name:"normalX",type:"float",editable:!0,accessor:{get:()=>this.normal.x,set:t=>{this.normal.x=t}}},{name:"normalY",type:"float",editable:!0,accessor:{get:()=>this.normal.y,set:t=>{this.normal.y=t}}},{name:"normalZ",type:"float",editable:!0,accessor:{get:()=>this.normal.z,set:t=>{this.normal.z=t}}},{name:"arcLength",type:"float",editable:!1,accessor:{get:()=>this._geo.length}},{name:"totalAngle",type:"float",editable:!1,accessor:{get:()=>v.radToDeg(Math.abs(this._geo.deltaAngle))}},{name:"area",type:"float",editable:!1,accessor:{get:()=>this._geo.area}}]}]}}subGetGripPoints(){const t=new Array;return t.push(this.center),t.push(this.startPoint),t.push(this.endPoint),t}subGetOsnapPoints(t,e,s,n){const r=this.startPoint,a=this.endPoint;switch(t){case z.EndPoint:n.push(r),n.push(a);break;case z.MidPoint:n.push(this.midPoint);break;case z.Nearest:{const o=this._geo.nearestPoint(e);n.push(o)}break;case z.Perpendicular:break;case z.Tangent:{const o=this._geo.tangentPoints(e);n.push(...o);break}}}transformBy(t){return this._geo.transform(t),this}subWorldDraw(t){return t.circularArc(this._geo)}dxfOutFields(t){super.dxfOutFields(t);const e=Cs(this.center,this.normal);return t.writeSubclassMarker("AcDbArc"),t.writePoint3d(10,e),t.writeDouble(40,this.radius),t.writeAngle(50,vn(this.center,this.startPoint,this.normal)),t.writeAngle(51,vn(this.center,this.endPoint,this.normal)),t.writeVector3d(210,this.normal),this}};wr.typeName="Arc";let Ei=wr;var So=(i=>(i[i.LEFT=0]="LEFT",i[i.CENTER=1]="CENTER",i[i.RIGHT=2]="RIGHT",i[i.ALIGNED=3]="ALIGNED",i[i.MIDDLE=4]="MIDDLE",i[i.FIT=5]="FIT",i))(So||{}),Eo=(i=>(i[i.BASELINE=0]="BASELINE",i[i.BOTTOM=1]="BOTTOM",i[i.MIDDLE=2]="MIDDLE",i[i.TOP=3]="TOP",i))(Eo||{});const xr=class xr extends gt{get dxfTypeName(){return"TEXT"}constructor(){super(),this._textString="",this._height=0,this._thickness=1,this._position=new w,this._rotation=0,this._oblique=0,this._horizontalMode=0,this._verticalModel=2,this._styleName="",this._widthFactor=1}get textString(){return this._textString}set textString(t){this._textString=t}get thickness(){return this._thickness}set thickness(t){this._thickness=t}get height(){return this._height}set height(t){this._height=t}get position(){return this._position}set position(t){this._position.copy(t)}get rotation(){return this._rotation}set rotation(t){this._rotation=t}get oblique(){return this._oblique}set oblique(t){this._oblique=t}get horizontalMode(){return this._horizontalMode}set horizontalMode(t){this._horizontalMode=t}get verticalMode(){return this._verticalModel}set verticalMode(t){this._verticalModel=t}get styleName(){return this._styleName}set styleName(t){this._styleName=t}get widthFactor(){return this._widthFactor}set widthFactor(t){this._widthFactor=t}get geometricExtents(){return new C}subGetOsnapPoints(t,e,s,n){z.Insertion===t&&n.push(this._position)}transformBy(t){const e=this._position.clone(),s=this._position.clone().add(new b(Math.cos(this._rotation),Math.sin(this._rotation),0)),n=this._position.clone().add(new b(-Math.sin(this._rotation),Math.cos(this._rotation),0)),r=this._position.clone().add(new b(0,0,1));e.applyMatrix4(t),s.applyMatrix4(t),n.applyMatrix4(t),r.applyMatrix4(t);const a=new b(s).sub(e),o=new b(n).sub(e),l=new b(r).sub(e),c=o.length(),u=a.length(),d=l.length();return this._position.copy(e),u>0&&(this._rotation=Math.atan2(a.y,a.x)),c>0&&(this._height*=c,u>0&&(this._widthFactor*=u/c)),d>0&&(this._thickness*=d),this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"text",properties:[{name:"contents",type:"string",editable:!0,accessor:{get:()=>this.textString,set:t=>{this.textString=t}}},{name:"styleName",type:"string",editable:!0,accessor:{get:()=>this.styleName,set:t=>{this.styleName=t}}},{name:"textHeight",type:"float",editable:!0,accessor:{get:()=>this.height,set:t=>{this.height=t}}},{name:"rotation",type:"float",editable:!0,accessor:{get:()=>this.rotation,set:t=>{this.rotation=t}}},{name:"widthFactor",type:"float",editable:!0,accessor:{get:()=>this.widthFactor,set:t=>{this.widthFactor=t}}},{name:"oblique",type:"float",editable:!0,accessor:{get:()=>this.oblique,set:t=>{this.oblique=t}}}]},{groupName:"geometry",properties:[{name:"positionX",type:"float",editable:!0,accessor:{get:()=>this.position.x,set:t=>{this.position.x=t}}},{name:"positionY",type:"float",editable:!0,accessor:{get:()=>this.position.y,set:t=>{this.position.y=t}}},{name:"positionZ",type:"float",editable:!0,accessor:{get:()=>this.position.z,set:t=>{this.position.z=t}}}]}]}}getTextStyle(){const t=this.database.tables.textStyleTable,e=t.getAt(this.styleName)??t.getAt(this.database.textstyle)??t.getAt(tt);if(!e)throw new Error("No valid text style found in text style table.");return e.textStyle}subWorldDraw(t,e){const s={text:this.textString,height:this.height,width:1/0,widthFactor:this.widthFactor,position:this.position,rotation:this.rotation,drawingDirection:ae.BOTTOM_TO_TOP,attachmentPoint:ot.BottomLeft};return t.mtext(s,this.getTextStyle(),e)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbText"),t.writePoint3d(10,this.position),t.writeDouble(39,this.thickness),t.writeDouble(40,this.height),t.writeString(1,this.textString),t.writeAngle(50,this.rotation),t.writeDouble(41,this.widthFactor),t.writeAngle(51,this.oblique),t.writeString(7,this.styleName),t.writeInt16(72,this.horizontalMode),t.writeInt16(73,this.verticalMode),t.writePoint3d(11,this.position),this}};xr.typeName="Text";let es=xr;var J=(i=>(i[i.Invisible=1]="Invisible",i[i.Const=2]="Const",i[i.Verifiable=4]="Verifiable",i[i.Preset=8]="Preset",i))(J||{}),zt=(i=>(i[i.MultiLine=2]="MultiLine",i[i.ConstMultiLine=4]="ConstMultiLine",i))(zt||{});const fr=class fr extends es{get dxfTypeName(){return"ATTDEF"}constructor(){super(),this._flags=0,this._prompt="",this._mtextFlag=0,this._tag="",this._fieldLength=0,this._lockPositionInBlock=!1,this._isReallyLocked=!1}get isInvisible(){return(this._flags&1)!==0}set isInvisible(t){t?this._flags|=1:this._flags&=-2}get prompt(){return this._prompt}set prompt(t){this._prompt=t}get isConst(){return(this._flags&2)!==0}set isConst(t){t?this._flags|=2:this._flags&=-3}get isVerifiable(){return(this._flags&4)!==0}set isVerifiable(t){t?this._flags|=4:this._flags&=-5}get isPreset(){return(this._flags&8)!==0}set isPreset(t){t?this._flags|=8:this._flags&=-9}get isMTextAttribute(){return(this._mtextFlag&2)!==0}set isMTextAttribute(t){t?this._mtextFlag|=2:this._mtextFlag&=-3}get isConstMTextAttribute(){return(this._mtextFlag&4)!==0}set isConstMTextAttribute(t){t?this._mtextFlag|=4:this._mtextFlag&=-5}get tag(){return this._tag}set tag(t){this._tag=t}get fieldLength(){return this._fieldLength}set fieldLength(t){this._fieldLength=t}get lockPositionInBlock(){return this._lockPositionInBlock}set lockPositionInBlock(t){this._lockPositionInBlock=t}get isReallyLocked(){return this._isReallyLocked}set isReallyLocked(t){this._isReallyLocked=t}get mtext(){return this._mtext}set mtext(t){this._mtext=t,this.isMTextAttribute=t!=null}subWorldDraw(t){}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbAttributeDefinition"),t.writeString(3,this.prompt),t.writeString(2,this.tag),t.writeInt16(70,this.isInvisible?1:0),t.writeInt16(73,this.fieldLength),t.writeInt16(74,this.isReallyLocked?1:0),this}};fr.typeName="AttDef";let Ai=fr;const br=class br extends es{get dxfTypeName(){return"ATTRIB"}constructor(){super(),this._flags=0,this._mtextFlag=0,this._tag="",this._fieldLength=0,this._lockPositionInBlock=!1,this._isReallyLocked=!1}get isInvisible(){return(this._flags&J.Invisible)!==0}set isInvisible(t){t?this._flags|=J.Invisible:this._flags&=~J.Invisible}get isConst(){return(this._flags&J.Const)!==0}set isConst(t){t?this._flags|=J.Const:this._flags&=~J.Const}get isVerifiable(){return(this._flags&J.Verifiable)!==0}set isVerifiable(t){t?this._flags|=J.Verifiable:this._flags&=~J.Verifiable}get isPreset(){return(this._flags&J.Preset)!==0}set isPreset(t){t?this._flags|=J.Preset:this._flags&=~J.Preset}get isMTextAttribute(){return(this._mtextFlag&zt.MultiLine)!==0}set isMTextAttribute(t){t?this._mtextFlag|=zt.MultiLine:this._mtextFlag&=~zt.MultiLine}get isConstMTextAttribute(){return(this._mtextFlag&zt.ConstMultiLine)!==0}set isConstMTextAttribute(t){t?this._mtextFlag|=zt.ConstMultiLine:this._mtextFlag&=~zt.ConstMultiLine}get tag(){return this._tag}set tag(t){this._tag=t}get fieldLength(){return this._fieldLength}set fieldLength(t){this._fieldLength=t}get lockPositionInBlock(){return this._lockPositionInBlock}set lockPositionInBlock(t){this._lockPositionInBlock=t}get isReallyLocked(){return this._isReallyLocked}set isReallyLocked(t){this._isReallyLocked=t}get mtext(){return this._mtext}set mtext(t){this._mtext=t,this.isMTextAttribute=t!=null}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbAttribute"),t.writeInt16(70,this.isInvisible?1:0),t.writeInt16(73,this.fieldLength),t.writeString(2,this.tag),t.writeInt16(74,this.isReallyLocked?1:0),this.mtext&&t.writeInt16(71,this.isMTextAttribute?1:0),this}};br.typeName="Attrib";let Ti=br;const Os=class Os extends gt{get dxfTypeName(){return"INSERT"}constructor(t){super(),this._blockName=t,this._position=new w,this._rotation=0,this._normal=new b(0,0,1),this._scaleFactors=new w(1,1,1),this._attribs=new Map}get position(){return this._position}set position(t){this._position.copy(t)}get rotation(){return this._rotation}set rotation(t){this._rotation=t}get scaleFactors(){return this._scaleFactors}set scaleFactors(t){this._scaleFactors.copy(t)}get normal(){return this._normal}set normal(t){this._normal.copy(t).normalize()}get blockName(){return this._blockName}get blockTableRecord(){return this.database.tables.blockTable.getAt(this._blockName)}appendAttributes(t){this._attribs.set(t.objectId,t),t.ownerId=this.objectId}attributeIterator(){return new Zs(this._attribs)}get blockTransform(){const t=this.blockTableRecord,e=(t==null?void 0:t.origin)??w.ORIGIN,s=new G().makeTranslation(-e.x,-e.y,-e.z),n=new G().makeScale(this._scaleFactors.x,this._scaleFactors.y,this._scaleFactors.z),r=new Ue().setFromAxisAngle(b.Z_AXIS,this._rotation),a=new G().makeRotationFromQuaternion(r),o=new G().makeTranslation(this._position.x,this._position.y,this._position.z);return new G().multiplyMatrices(o,a).multiply(n).multiply(s)}subGetOsnapPoints(t,e,s,n,r,a){const o=a??new G;z.Insertion===t?n.push(this.getInsertionPoint(o)):r&&this.subEntityGetOsnapPoints(t,e,s,n,r,o)}transformBy(t){const e=new G().setFromExtrusionDirection(this._normal),s=new G().makeRotationZ(this._rotation),n=new G().multiplyMatrices(e,s),r=this._position.clone(),a=new w(this._scaleFactors.x,0,0).applyMatrix4(n).add(r),o=new w(0,this._scaleFactors.y,0).applyMatrix4(n).add(r),l=new w(0,0,this._scaleFactors.z).applyMatrix4(n).add(r);r.applyMatrix4(t),a.applyMatrix4(t),o.applyMatrix4(t),l.applyMatrix4(t);const c=new b(a).sub(r),u=new b(o).sub(r),d=new b(l).sub(r);let g=new b().crossVectors(c,u);g.lengthSq()===0?g=this._normal.clone().transformDirection(t):g.normalize();const m=new G().setFromExtrusionDirection(g).clone().invert(),y=c.clone().applyMatrix4(m);return this._position.copy(r),this._normal.copy(g),this._rotation=Math.atan2(y.y,y.x),this._scaleFactors.set(c.length(),u.length(),d.length()),this._attribs.forEach(x=>x.transformBy(t)),this}get properties(){const t={type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"blockName",type:"float",editable:!1,accessor:{get:()=>this._blockName}},{name:"positionX",type:"float",editable:!0,accessor:{get:()=>this.position.x,set:e=>{this.position.x=e}}},{name:"positionY",type:"float",editable:!0,accessor:{get:()=>this.position.y,set:e=>{this.position.y=e}}},{name:"positionZ",type:"float",editable:!0,accessor:{get:()=>this.position.z,set:e=>{this.position.z=e}}},{name:"rotation",type:"float",editable:!0,accessor:{get:()=>this.rotation,set:e=>{this.rotation=e}}},{name:"scaleFactorsX",type:"float",editable:!0,accessor:{get:()=>this.scaleFactors.x,set:e=>{this.scaleFactors.x=e}}},{name:"scaleFactorsY",type:"float",editable:!0,accessor:{get:()=>this.scaleFactors.y,set:e=>{this.scaleFactors.y=e}}},{name:"scaleFactorsZ",type:"float",editable:!0,accessor:{get:()=>this.scaleFactors.z,set:e=>{this.scaleFactors.z=e}}},{name:"normalX",type:"float",editable:!0,accessor:{get:()=>this.normal.x,set:e=>{this.normal.x=e}}},{name:"normalY",type:"float",editable:!0,accessor:{get:()=>this.normal.y,set:e=>{this.normal.y=e}}},{name:"normalZ",type:"float",editable:!0,accessor:{get:()=>this.normal.z,set:e=>{this.normal.z=e}}}]}]};if(this._attribs.size>0){const e={groupName:"attribute",properties:[]};t.groups.push(e),this._attribs.forEach(s=>{e.properties.push({name:s.tag,type:"string",editable:!s.isConst,skipTranslation:!0,accessor:{get:()=>s.textString,set:n=>{s.textString=n}}})})}return t}get geometricExtents(){const t=new C,e=this.blockTableRecord;if(e!=null){const n=e.newIterator();for(const r of n)t.union(r.geometricExtents)}const s=this.blockTransform;return t.applyMatrix4(s),t}subWorldDraw(t){const e=this.blockTableRecord;if(e!=null){const s=this.blockTransform,n=[];return this._attribs.forEach(a=>{if(!a.isInvisible){const o=a.worldDraw(t);o&&n.push(o)}}),ss.instance.draw(t,e,this.rgbColor,n,!0,s,this._normal)}else return t.group([])}dxfOut(t,e=!1){super.dxfOut(t,e);let s=!1;for(const n of this.attributeIterator())s=!0,t.writeStart("ATTRIB"),n.dxfOut(t);return s&&(t.writeStart("SEQEND"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity")),this}subEntityGetOsnapPoints(t,e,s,n,r,a,o=new Set){if(r===this.objectId||o.has(this.objectId))return!1;o.add(this.objectId);try{const l=this.blockTableRecord;if(l==null)return!1;const c=new G().multiplyMatrices(a,this.getFullInsertionTransform());for(const u of l.newIterator()){if(u.objectId===r){const d=new w(e).applyMatrix4(c.clone().invert()),g=new w(s).applyMatrix4(c.clone().invert()),p=[];return u.subGetOsnapPoints(t,d,g,p,r,c),u instanceof Os?p.forEach(m=>{n.push(m.clone())}):p.forEach(m=>{n.push(new w(m).applyMatrix4(c))}),!0}if(u instanceof Os&&u.subEntityGetOsnapPoints(t,e,s,n,r,c,o))return!0}return!1}finally{o.delete(this.objectId)}}getInsertionPoint(t){var n;const e=((n=this.blockTableRecord)==null?void 0:n.origin)??w.ORIGIN,s=new G().multiplyMatrices(t,this.getFullInsertionTransform());return new w(e).applyMatrix4(s)}getFullInsertionTransform(){const t=new G().setFromExtrusionDirection(this._normal);return new G().multiplyMatrices(t,this.blockTransform)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbBlockReference"),t.writePoint3d(10,this.position),t.writeString(2,this.blockName),t.writeDouble(41,this.scaleFactors.x),t.writeDouble(42,this.scaleFactors.y),t.writeDouble(43,this.scaleFactors.z),t.writeAngle(50,this.rotation),t.writeVector3d(210,this.normal),this}};Os.typeName="BlockReference";let Ge=Os;const Ir=class Ir extends rt{get dxfTypeName(){return"CIRCLE"}constructor(t,e,s=b.Z_AXIS){super();const n=Qn(s);this._geo=new je(t,e,0,W,s,n)}get center(){return this._geo.center}set center(t){this._geo.center=t}get radius(){return this._geo.radius}set radius(t){this._geo.radius=t}get normal(){return this._geo.normal}get geometricExtents(){return this._geo.box}get closed(){return this._geo.closed}subGetOsnapPoints(t,e,s,n){switch(t){case z.Center:case z.Centroid:n.push(this._geo.center);break;case z.Quadrant:n.push(this._geo.getPointAtAngle(0)),n.push(this._geo.getPointAtAngle(Math.PI/2)),n.push(this._geo.getPointAtAngle(Math.PI)),n.push(this._geo.getPointAtAngle(Math.PI/2*3));break;case z.Nearest:{const r=this._geo.nearestPoint(e);n.push(r)}break;case z.Tangent:{const r=this._geo.tangentPoints(e);n.push(...r);break}}}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"centerX",type:"float",editable:!0,accessor:{get:()=>this.center.x,set:t=>{this.center.x=t}}},{name:"centerY",type:"float",editable:!0,accessor:{get:()=>this.center.y,set:t=>{this.center.y=t}}},{name:"centerZ",type:"float",editable:!0,accessor:{get:()=>this.center.z,set:t=>{this.center.z=t}}},{name:"radius",type:"float",editable:!0,accessor:{get:()=>this.radius,set:t=>{this.radius=t}}},{name:"normalX",type:"float",editable:!0,accessor:{get:()=>this.normal.x,set:t=>{this.normal.x=t}}},{name:"normalY",type:"float",editable:!0,accessor:{get:()=>this.normal.y,set:t=>{this.normal.y=t}}},{name:"normalZ",type:"float",editable:!0,accessor:{get:()=>this.normal.z,set:t=>{this.normal.z=t}}},{name:"diameter",type:"float",editable:!1,accessor:{get:()=>this._geo.radius*2}},{name:"perimeter",type:"float",editable:!1,accessor:{get:()=>this._geo.length}},{name:"area",type:"float",editable:!1,accessor:{get:()=>this._geo.area}}]}]}}subGetGripPoints(){const t=new Array;return t.push(this.center),t}transformBy(t){return this._geo.transform(t),this}subWorldDraw(t){return t.circularArc(this._geo)}dxfOutFields(t){super.dxfOutFields(t);const e=Cs(this.center,this.normal);return t.writeSubclassMarker("AcDbCircle"),t.writePoint3d(10,e),t.writeDouble(40,this.radius),t.writeVector3d(210,this.normal),this}};Ir.typeName="Circle";let Mi=Ir;const Pr=class Pr extends rt{get dxfTypeName(){return"ELLIPSE"}constructor(t,e,s,n,r,a,o){super(),this._geo=new Je(t,e,s,n,r,a,o)}get center(){return this._geo.center}set center(t){this._geo.center=t}get majorAxisRadius(){return this._geo.majorAxisRadius}set majorAxisRadius(t){this._geo.majorAxisRadius=t}get minorAxisRadius(){return this._geo.minorAxisRadius}set minorAxisRadius(t){this._geo.minorAxisRadius=t}get startAngle(){return this._geo.startAngle}set startAngle(t){this._geo.startAngle=t}get endAngle(){return this._geo.endAngle}set endAngle(t){this._geo.endAngle=t}get normal(){return this._geo.normal}set normal(t){this._geo.normal=t}get geometricExtents(){return this._geo.box}get closed(){return this._geo.closed}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:this.closed||(n.push(this._geo.startPoint),n.push(this._geo.endPoint));break;case z.MidPoint:this.closed||n.push(this._geo.midPoint);break;case z.Quadrant:this.closed&&(n.push(this._geo.getPointAtAngle(0)),n.push(this._geo.getPointAtAngle(Math.PI/2)),n.push(this._geo.getPointAtAngle(Math.PI)),n.push(this._geo.getPointAtAngle(Math.PI/2*3)));break}}transformBy(t){return this._geo.transform(t),this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"centerX",type:"float",editable:!0,accessor:{get:()=>this.center.x,set:t=>{this.center.x=t}}},{name:"centerY",type:"float",editable:!0,accessor:{get:()=>this.center.y,set:t=>{this.center.y=t}}},{name:"centerZ",type:"float",editable:!0,accessor:{get:()=>this.center.z,set:t=>{this.center.z=t}}},{name:"majorAxisRadius",type:"float",editable:!0,accessor:{get:()=>this.majorAxisRadius,set:t=>{this.center.x=t}}},{name:"minorAxisRadius",type:"float",editable:!0,accessor:{get:()=>this.minorAxisRadius,set:t=>{this.minorAxisRadius=t}}},{name:"startAngle",type:"float",editable:!0,accessor:{get:()=>this.startAngle,set:t=>{this.startAngle=t}}},{name:"endAngle",type:"float",editable:!0,accessor:{get:()=>this.endAngle,set:t=>{this.endAngle=t}}},{name:"normalX",type:"float",editable:!0,accessor:{get:()=>this.normal.x,set:t=>{this.normal.x=t}}},{name:"normalY",type:"float",editable:!0,accessor:{get:()=>this.normal.y,set:t=>{this.normal.y=t}}},{name:"normalZ",type:"float",editable:!0,accessor:{get:()=>this.normal.z,set:t=>{this.normal.z=t}}},{name:"length",type:"float",editable:!1,accessor:{get:()=>this._geo.length}},{name:"area",type:"float",editable:!1,accessor:{get:()=>this._geo.area}}]}]}}subWorldDraw(t){return t.ellipticalArc(this._geo)}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbEllipse"),t.writePoint3d(10,this.center);const e=this._geo.majorAxis,s=this.majorAxisRadius;return t.writePoint3d(11,{x:e.x*s,y:e.y*s,z:e.z*s}),t.writeVector3d(210,this.normal),t.writeDouble(40,this.minorAxisRadius/this.majorAxisRadius),t.writeDouble(41,this.startAngle),t.writeDouble(42,this.endAngle),this}};Pr.typeName="Ellipse";let vi=Pr;const Sr=class Sr extends gt{get dxfTypeName(){return"3DFACE"}constructor(){super(),this._vertices=[new w,new w,new w],this._edgeInvisibilities=0}getVertexAt(t){return t<0?this._vertices[0]:t>this._vertices.length?this._vertices[this._vertices.length-1]:this._vertices[t]}setVertexAt(t,e){if(t<0&&this._vertices[0].copy(e),t>=3)return this._vertices.length===3&&this._vertices.push(new w),this._vertices[3].copy(e);this._vertices[t].copy(e)}setEdgeInvisibilities(t){this._edgeInvisibilities=t}isEdgeVisibleAt(t){if(t<0||t>3)throw new Error("Index out of range");return(this._edgeInvisibilities&1<<t)===0}makeEdgeInvisibleAt(t){if(t<0||t>3)throw new Error("Index out of range");this._edgeInvisibilities=this._edgeInvisibilities|1<<t}get geometricExtents(){return new C().setFromPoints(this._vertices)}subGetGripPoints(){const t=new Array;return t.push(...this._vertices),t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:n.push(...this._vertices);break}}transformBy(t){return this._vertices.forEach(e=>e.applyMatrix4(t)),this}subWorldDraw(t){const e=this._vertices.length,s=new Float32Array(e*3),n=new Uint16Array(e*2);for(let r=0;r<e;r++)s[r*3]=this._vertices[r].x,s[r*3+1]=this._vertices[r].y,s[r*3+2]=this._vertices[r].z,this.isEdgeVisibleAt(r)&&(n[r*2]=r,n[r*2+1]=(r+1)%4);return t.lineSegments(s,3,n)}dxfOutFields(t){super.dxfOutFields(t);const e=this.getVertexAt(0),s=this.getVertexAt(1),n=this.getVertexAt(2),r=this.getVertexAt(3);t.writeSubclassMarker("AcDbFace"),t.writePoint3d(10,e),t.writePoint3d(11,s),t.writePoint3d(12,n),t.writePoint3d(13,r);let a=0;for(let o=0;o<4;++o)this.isEdgeVisibleAt(o)||(a|=1<<o);return t.writeInt16(70,a),this}};Sr.typeName="Face";let ki=Sr;var vs=(i=>(i[i.UserDefined=0]="UserDefined",i[i.Predefined=1]="Predefined",i[i.Custom=2]="Custom",i))(vs||{}),Ao=(i=>(i[i.Normal=0]="Normal",i[i.Outer=1]="Outer",i[i.Ignore=2]="Ignore",i))(Ao||{}),nr=(i=>(i[i.HatchObject=0]="HatchObject",i[i.GradientObject=1]="GradientObject",i))(nr||{}),To=(i=>(i[i.PreDefinedGradient=0]="PreDefinedGradient",i[i.UserDefinedGradient=1]="UserDefinedGradient",i))(To||{});const Er=class Er extends gt{constructor(){super(),this._gradientAngle=0,this._elevation=0,this._geo=new ts,this._isSolidFill=!1,this._definitionLines=[],this._patternName="",this._patternType=1,this._patternAngle=0,this._patternScale=1,this._hatchStyle=0,this._hatchObjectType=0,this._gradientAngle=0,this._gradientShift=0,this._shadeTintValue=0,this._gradientStartColor=void 0,this._gradientEndColor=void 0,this._gradientType=0,this._gradientName="",this._gradientOneColorMode=!1}get dxfTypeName(){return"HATCH"}get isGradient(){return this._hatchObjectType===1}get isHatch(){return this._hatchObjectType===0}get isSolidFill(){return this._isSolidFill||this._patternName.toUpperCase()==="SOLID"}set isSolidFill(t){this._isSolidFill=t}get definitionLines(){return this._definitionLines}get patternName(){return this._patternName}set patternName(t){this._patternName=t}get patternType(){return this._patternType}set patternType(t){this._patternType=t}get patternAngle(){return this._patternAngle}set patternAngle(t){this._patternAngle=t}get patternScale(){return this._patternScale}set patternScale(t){this._patternScale=t}get hatchStyle(){return this._hatchStyle}set hatchStyle(t){this._hatchStyle=t}get elevation(){return this._elevation}set elevation(t){this._elevation=t}get hatchObjectType(){return this._hatchObjectType}set hatchObjectType(t){this._hatchObjectType=t}get gradientAngle(){return this._gradientAngle}set gradientAngle(t){this._gradientAngle=t}get gradientShift(){return this._gradientShift}set gradientShift(t){this._gradientShift=t}get gradientType(){return this._gradientType}set gradientType(t){this._gradientType=t}get gradientName(){return this._gradientName}set gradientName(t){this._gradientName=t}get gradientOneColorMode(){return this._gradientOneColorMode}set gradientOneColorMode(t){this._gradientOneColorMode=t}get shadeTintValue(){return this._shadeTintValue}set shadeTintValue(t){this._shadeTintValue=t}get gradientStartColor(){return this._gradientStartColor}set gradientStartColor(t){this._gradientStartColor=t==null||!Number.isFinite(t)?void 0:t&16777215}get gradientEndColor(){return this._gradientEndColor}set gradientEndColor(t){this._gradientEndColor=t==null||!Number.isFinite(t)?void 0:t&16777215}add(t){this._geo.add(t)}buildAreasFromLoops(){const t=this._geo.loops;if(t.length===0)return[];if(t.length===1)return[this._geo];const e=this._geo.buildHierarchy(),s=[],n=(r,a)=>{if(r.index>=0&&a%2===0){const o=new ts;o.add(t[r.index]),r.children.forEach(l=>{l.index>=0&&o.add(t[l.index])}),s.push(o)}r.children.forEach(o=>n(o,a+1))};return e.children.forEach(r=>n(r,0)),s.length>0?s:[this._geo]}getCalculatedAreaValue(){const t=this.buildAreasFromLoops();return t.length===0?0:t.reduce((e,s)=>e+s.area,0)}get geometricExtents(){const t=this.buildAreasFromLoops();if(t.length===0)return new C;const e=new C;return t.forEach(s=>{const n=s.box;e.union(new C({x:n.min.x,y:n.min.y,z:this._elevation},{x:n.max.x,y:n.max.y,z:this._elevation}))}),e}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"pattern",properties:[{name:"patternType",type:"enum",editable:!0,options:[{label:vs[0],value:0},{label:vs[1],value:1},{label:vs[2],value:2}],accessor:{get:()=>this.patternType,set:t=>{this.patternType=t}}},{name:"patternName",type:"string",editable:!0,accessor:{get:()=>this.patternName,set:t=>{this.patternName=t}}},{name:"patternAngle",type:"float",editable:!0,accessor:{get:()=>this.patternAngle,set:t=>{this.patternAngle=t}}},{name:"patternScale",type:"float",editable:!0,accessor:{get:()=>this.patternScale,set:t=>{this.patternScale=t}}}]},{groupName:"geometry",properties:[{name:"elevation",type:"float",editable:!0,accessor:{get:()=>this.elevation,set:t=>{this.elevation=t}}},{name:"area",type:"float",editable:!1,accessor:{get:()=>this.getCalculatedAreaValue()}}]}]}}subWorldDraw(t){const e=t.subEntityTraits;e.fillType={solidFill:this.isSolidFill,patternAngle:this.patternAngle,definitionLines:this.definitionLines,gradient:this.isGradient?{name:this.gradientName,angle:this.gradientAngle,shift:this.gradientShift,oneColorMode:this.gradientOneColorMode,shadeTintValue:this.shadeTintValue,startColor:this.gradientStartColor,endColor:this.gradientEndColor}:void 0},e.drawOrder=-1;const s=this.buildAreasFromLoops();if(s.length===0)return t.area(this._geo);if(s.length===1)return t.area(s[0]);const n=s.map(r=>t.area(r));return t.group(n)}transformBy(t){const e=t.elements,s=new Us(e[0],e[4],e[12],e[1],e[5],e[13],0,0,1);this._geo.transform(s),this._elevation=new w(0,0,this._elevation).applyMatrix4(t).z;const n=new w(1,0,0).applyMatrix4(t),r=new w().applyMatrix4(t),a=new w(n).sub(r);if(a.length()>0){const o=Math.atan2(a.y,a.x);this._patternAngle+=o,this._gradientAngle+=o,this._patternScale*=a.length()}return this}dxfOutFields(t){super.dxfOutFields(t);const e=this._geo.loops;return t.writeSubclassMarker("AcDbHatch"),t.writePoint3d(10,{x:0,y:0,z:this.elevation}),t.writeVector3d(210,{x:0,y:0,z:1}),t.writeString(2,this.patternName||(this.isSolidFill?"SOLID":"USER")),t.writeInt16(70,this.isSolidFill?1:0),t.writeInt16(71,0),t.writeInt16(91,e.length),e.forEach((s,n)=>{const r=n===0;if(s instanceof Mt){const a=s.vertices,o=a.some(c=>(c.bulge??0)!==0);t.writeInt16(92,2),t.writeInt16(72,o?1:0),t.writeInt16(73,s.closed?1:0),t.writeInt16(93,a.length);for(const c of a)t.writePoint2d(10,c),o&&t.writeDouble(42,c.bulge??0);t.writeInt16(97,0);return}if(s instanceof Fs){const a=r?1:0;t.writeInt16(92,a),t.writeInt16(93,s.numberOfEdges);for(const o of s.curves){if(o instanceof Vt){t.writeInt16(72,1),t.writePoint2d(10,o.startPoint),t.writePoint2d(11,o.endPoint);continue}if(o instanceof ye){t.writeInt16(72,2),t.writePoint2d(10,o.center),t.writeDouble(40,o.radius),t.writeAngle(50,o.startAngle),t.writeAngle(51,o.endAngle),t.writeInt16(73,o.clockwise?0:1);continue}if(o instanceof Bs){t.writeInt16(72,3),t.writePoint2d(10,o.center);const l=new k(o.majorAxisRadius*Math.cos(o.rotation),o.majorAxisRadius*Math.sin(o.rotation));t.writePoint2d(11,l);const c=o.majorAxisRadius===0?0:o.minorAxisRadius/o.majorAxisRadius;t.writeDouble(40,c),t.writeAngle(50,o.startAngle),t.writeAngle(51,o.endAngle),t.writeInt16(73,o.clockwise?0:1);continue}if(o instanceof Dt){const l=o.knots,c=o.controlPoints,u=o.weights,d=o.fitPoints,g=u.some(p=>p!==1);t.writeInt16(72,4),t.writeInt16(94,o.degree),t.writeInt16(73,g?1:0),t.writeInt16(74,o.closed?1:0),t.writeInt16(95,l.length),t.writeInt16(96,c.length),l.forEach(p=>t.writeDouble(40,p)),c.forEach((p,m)=>{t.writePoint2d(10,p),g&&t.writeDouble(42,u[m]??1)}),t.writeInt16(97,(d==null?void 0:d.length)??0),d==null||d.forEach(p=>t.writePoint2d(11,p))}}t.writeInt16(97,0)}}),t.writeInt16(75,this.hatchStyle),t.writeInt16(76,this.patternType),t.writeAngle(52,this.patternAngle),t.writeDouble(41,this.patternScale),t.writeInt16(77,0),t.writeInt16(78,this.definitionLines.length),this.definitionLines.forEach(s=>{t.writeAngle(53,s.angle),t.writePoint2d(43,s.base),t.writePoint2d(45,s.offset),t.writeInt16(79,s.dashLengths.length),s.dashLengths.forEach(n=>t.writeDouble(49,n))}),this.isGradient&&(t.writeInt16(450,this._hatchObjectType),t.writeInt16(451,0),t.writeInt16(452,this._gradientOneColorMode?1:0),t.writeAngle(460,this._gradientAngle),t.writeDouble(461,this._gradientShift),t.writeString(470,this._gradientName)),t.writeInt16(98,0),this}};Er.typeName="Hatch";let Rs=Er;var Mo=(i=>(i[i.MText=0]="MText",i[i.Fcf=1]="Fcf",i[i.BlockReference=2]="BlockReference",i[i.NoAnnotation=3]="NoAnnotation",i))(Mo||{});const Ar=class Ar extends rt{get dxfTypeName(){return"LEADER"}constructor(){super(),this._isSplined=!1,this._updated=!1,this._hasArrowHead=!1,this._vertices=[],this._dimensionStyle="",this._hasHookLine=!1,this._annoType=3}get isSplined(){return this._isSplined}set isSplined(t){this._isSplined=t}get hasArrowHead(){return this._hasArrowHead}set hasArrowHead(t){this._hasArrowHead=t}get hasHookLine(){return this._hasHookLine}set hasHookLine(t){this._hasHookLine=t}get numVertices(){return this._vertices.length}get vertices(){return this._vertices.map(t=>t.clone())}get dimensionStyle(){return this._dimensionStyle}set dimensionStyle(t){this._dimensionStyle=t}get annoType(){return this._annoType}set annoType(t){this._annoType=t}appendVertex(t){this._vertices.push(new w().copy(t)),this._updated=!0}setVertexAt(t,e){throw(t<0||t>=this._vertices.length)&&(this._vertices[t].copy(e),this._updated=!0),new Error("The vertex index is out of range!")}vertexAt(t){throw(t<0||t>=this._vertices.length)&&this._vertices[t],new Error("The vertex index is out of range!")}get geometricExtents(){return this._isSplined&&this.splineGeo?this.splineGeo.calculateBoundingBox():new C().setFromPoints(this._vertices)}get closed(){return!1}set closed(t){}transformBy(t){return this._vertices.forEach(e=>e.applyMatrix4(t)),this._splineGeo?(this._splineGeo.transform(t),this._updated=!1):this._updated=!0,this}subWorldDraw(t){if(this.isSplined&&this.splineGeo){const e=this.splineGeo.getPoints(100);return t.lines(e)}else return t.lines(this._vertices)}get splineGeo(){return this.createSplineIfNeeded(),this._splineGeo}createSplineIfNeeded(){this.isSplined&&this.numVertices>=2&&(this._splineGeo==null||this._updated)&&(this._splineGeo=new Dt(this._vertices,"Uniform"),this._updated=!1)}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbLeader"),t.writeString(3,this.dimensionStyle),t.writeInt16(71,this.hasArrowHead?1:0),t.writeInt16(72,this.annoType),t.writeInt16(73,this.hasHookLine?1:0),t.writeInt16(74,this.isSplined?1:0),t.writeInt16(76,this.numVertices);for(const e of this.vertices)t.writePoint3d(10,e);return this}};Ar.typeName="Leader";let Li=Ar;var z=(i=>(i[i.EndPoint=1]="EndPoint",i[i.MidPoint=2]="MidPoint",i[i.Center=3]="Center",i[i.Node=4]="Node",i[i.Quadrant=5]="Quadrant",i[i.Insertion=7]="Insertion",i[i.Perpendicular=8]="Perpendicular",i[i.Tangent=9]="Tangent",i[i.Nearest=10]="Nearest",i[i.Centroid=11]="Centroid",i))(z||{});function Ql(i){let t=0;for(const e of i)t|=1<<e-1;return t}function Jl(i){const t=[];for(const e of Object.values(z)){if(typeof e!="number")continue;const s=1<<e-1;i&s&&t.push(e)}return t}function tc(i,t){return i^1<<t-1}function ec(i,t){return(i&1<<t-1)!==0}function sc(i,t){return i|1<<t-1}function ic(i,t){return i&~(1<<t-1)}const Tr=class Tr extends rt{get dxfTypeName(){return"LINE"}constructor(t,e){super(),this._geo=new _e(t,e)}get startPoint(){return this._geo.startPoint}set startPoint(t){this._geo.startPoint=t}get endPoint(){return this._geo.endPoint}set endPoint(t){this._geo.endPoint=t}get midPoint(){return this._geo.midPoint}get geometricExtents(){return this._geo.box}get closed(){return!1}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"startX",type:"float",editable:!0,accessor:{get:()=>this.startPoint.x,set:t=>{this.startPoint.x=t}}},{name:"startY",type:"float",editable:!0,accessor:{get:()=>this.startPoint.y,set:t=>{this.startPoint.y=t}}},{name:"startZ",type:"float",editable:!0,accessor:{get:()=>this.startPoint.z,set:t=>{this.startPoint.z=t}}},{name:"endX",type:"float",editable:!0,accessor:{get:()=>this.endPoint.x,set:t=>{this.endPoint.x=t}}},{name:"endY",type:"float",editable:!0,accessor:{get:()=>this.endPoint.y,set:t=>{this.endPoint.y=t}}},{name:"endZ",type:"float",editable:!0,accessor:{get:()=>this.endPoint.z,set:t=>{this.endPoint.z=t}}},{name:"length",type:"float",editable:!1,accessor:{get:()=>this._geo.length}}]}]}}subGetGripPoints(){const t=new Array;return t.push(this.midPoint),t.push(this.startPoint),t.push(this.endPoint),t}subGetOsnapPoints(t,e,s,n){const r=this.startPoint,a=this.endPoint;switch(t){case z.EndPoint:n.push(r),n.push(a);break;case z.MidPoint:n.push(this.midPoint);break;case z.Nearest:{const o=this._geo.project(e);n.push(o)}break;case z.Perpendicular:{const o=this._geo.perpPoint(e);n.push(o)}break;case z.Tangent:break}}transformBy(t){return this._geo.transform(t),this}subWorldDraw(t){const e=this.startPoint,s=this.endPoint,n=[new w(e.x,e.y,0),new w(s.x,s.y,0)];return t.lines(n)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbLine"),t.writePoint3d(10,this.startPoint),t.writePoint3d(11,this.endPoint),this}};Tr.typeName="Line";let zs=Tr;const Mr=class Mr extends gt{get dxfTypeName(){return"MTEXT"}constructor(){super(),this._contents="",this._height=0,this._width=0,this._lineSpacingFactor=.25,this._lineSpacingStyle=0,this._backgroundFill=!1,this._backgroundFillColor=13158600,this._backgroundFillTransparency=1,this._backgroundScaleFactor=1,this._rotation=0,this._styleName="",this._location=new w,this._attachmentPoint=ot.TopLeft,this._direction=new b(1,0,0),this._drawingDirection=ae.LEFT_TO_RIGHT}get contents(){return this._contents}set contents(t){this._contents=t}get height(){return this._height}set height(t){this._height=t}get width(){return this._width}set width(t){this._width=t}get rotation(){return this._rotation}set rotation(t){this._rotation=t}get lineSpacingFactor(){return this._lineSpacingFactor}set lineSpacingFactor(t){this._lineSpacingFactor=t}get lineSpacingStyle(){return this._lineSpacingStyle}set lineSpacingStyle(t){this._lineSpacingStyle=t}get backgroundFill(){return this._backgroundFill}set backgroundFill(t){this._backgroundFill=t,this._backgroundFillColor=13158600}get backgroundFillColor(){return this._backgroundFillColor}set backgroundFillColor(t){this._backgroundFillColor=t}get backgroundFillTransparency(){return this._backgroundFillTransparency}set backgroundFillTransparency(t){this._backgroundFillTransparency=t}get backgroundScaleFactor(){return this._backgroundScaleFactor}set backgroundScaleFactor(t){this._backgroundScaleFactor=t}get styleName(){return this._styleName}set styleName(t){this._styleName=t}get location(){return this._location}set location(t){this._location.copy(t)}get attachmentPoint(){return this._attachmentPoint}set attachmentPoint(t){this._attachmentPoint=t}get direction(){return this._direction}set direction(t){this._direction.copy(t)}get drawingDirection(){return this._drawingDirection}set drawingDirection(t){this._drawingDirection=t}get geometricExtents(){return new C}subGetOsnapPoints(t,e,s,n){z.Insertion===t&&n.push(this._location)}transformBy(t){const e=this._location.clone(),s=this._direction.lengthSq()>0?this._direction.clone().normalize():new b(Math.cos(this._rotation),Math.sin(this._rotation),0),n=new b(-s.y,s.x,s.z);n.lengthSq()===0&&n.set(0,1,0),n.normalize();const r=e.clone().add(s),a=e.clone().add(n);e.applyMatrix4(t),r.applyMatrix4(t),a.applyMatrix4(t);const o=new b(r).sub(e),l=new b(a).sub(e),c=o.length(),u=l.length();return this._location.copy(e),c>0&&(this._direction.copy(o).normalize(),this._rotation=Math.atan2(this._direction.y,this._direction.x),this._width*=c),u>0&&(this._height*=u),this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"text",properties:[{name:"contents",type:"string",editable:!0,accessor:{get:()=>this.contents,set:t=>{this.contents=t}}},{name:"styleName",type:"string",editable:!0,accessor:{get:()=>this.styleName,set:t=>{this.styleName=t}}},{name:"attachmentPoint",type:"enum",editable:!0,options:[{label:ot[1],value:1},{label:ot[2],value:2},{label:ot[3],value:3},{label:ot[4],value:4},{label:ot[5],value:5},{label:ot[6],value:6},{label:ot[7],value:7},{label:ot[8],value:8},{label:ot[9],value:9}],accessor:{get:()=>this.attachmentPoint,set:t=>{this.attachmentPoint=t}}},{name:"drawingDirection",type:"enum",editable:!0,options:[{label:ae[1],value:1},{label:ae[2],value:2},{label:ae[3],value:3},{label:ae[4],value:4},{label:ae[5],value:5}],accessor:{get:()=>this.drawingDirection,set:t=>{this.drawingDirection=t}}},{name:"textHeight",type:"float",editable:!0,accessor:{get:()=>this.height,set:t=>{this.height=t}}},{name:"rotation",type:"float",editable:!0,accessor:{get:()=>this.rotation,set:t=>{this.rotation=t}}},{name:"lineSpacingFactor",type:"float",editable:!0,accessor:{get:()=>this.lineSpacingFactor,set:t=>{this.lineSpacingFactor=t}}},{name:"definedWidth",type:"float",editable:!0,accessor:{get:()=>this.width,set:t=>{this.width=t}}},{name:"directionX",type:"float",editable:!0,accessor:{get:()=>this.direction.x,set:t=>{this.direction.x=t}}},{name:"directionY",type:"float",editable:!0,accessor:{get:()=>this.direction.y,set:t=>{this.direction.y=t}}},{name:"directionZ",type:"float",editable:!0,accessor:{get:()=>this.direction.z,set:t=>{this.direction.z=t}}}]},{groupName:"geometry",properties:[{name:"locationX",type:"float",editable:!0,accessor:{get:()=>this.location.x,set:t=>{this.location.x=t}}},{name:"locationY",type:"float",editable:!0,accessor:{get:()=>this.location.y,set:t=>{this.location.y=t}}},{name:"locationZ",type:"float",editable:!0,accessor:{get:()=>this.location.z,set:t=>{this.location.z=t}}}]}]}}getTextStyle(){const t=this.database.tables.textStyleTable,e=t.getAt(this.styleName)??t.getAt(this.database.textstyle)??t.getAt(tt);if(!e)throw new Error("No valid text style found in text style table.");return e.textStyle}subWorldDraw(t,e){const s={text:this.contents,height:this.height,width:this.width,position:this.location,rotation:this.rotation,directionVector:this.direction,attachmentPoint:this.attachmentPoint,drawingDirection:this.drawingDirection,lineSpaceFactor:this.lineSpacingFactor};return t.mtext(s,this.getTextStyle(),e)}encodeMTextContentsForDxf(t){return t.replace(/\r\n|\r|\n/g,"\\P")}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbMText"),t.writePoint3d(10,this.location),t.writeDouble(40,this.height),t.writeDouble(41,this.width),t.writeString(1,this.encodeMTextContentsForDxf(this.contents)),t.writeString(7,this.styleName),t.writeAngle(50,this.rotation),t.writeVector3d(11,this.direction),t.writeInt16(71,this.attachmentPoint),t.writeInt16(72,this.drawingDirection),t.writeInt16(73,this.lineSpacingStyle),t.writeDouble(44,this.lineSpacingFactor),this.backgroundFill&&(t.writeInt16(90,1),t.writeInt32(63,this.backgroundFillColor),t.writeInt32(441,this.backgroundFillTransparency),t.writeDouble(45,this.backgroundScaleFactor)),this}};Mr.typeName="MText";let Vs=Mr;const vr=class vr extends rt{get dxfTypeName(){return"SPLINE"}constructor(t,e,s,n,r){super(),this.rebuild(t,e,s,n,r)}rebuild(t,e,s,n,r){const a=+(t!==void 0)+ +(e!==void 0)+ +(s!==void 0)+ +(n!==void 0)+ +(r!==void 0);if(a<2||a>5)throw yt.ILLEGAL_PARAMETERS;!Array.isArray(e)?this._geo=new Dt(t,e,s,n):this._geo=new Dt(t,e,s,n,r)}get geometricExtents(){return this._geo.box}get closed(){return this._geo.closed}set closed(t){this._geo.closed=t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:n.push(this._geo.startPoint),n.push(this._geo.endPoint);break}}transformBy(t){return this._geo.transform(t),this}subWorldDraw(t){const e=this._geo.getPoints(100);return t.lines(e)}dxfOutFields(t){var s;const e=this._geo;super.dxfOutFields(t),t.writeSubclassMarker("AcDbSpline"),t.writeInt16(70,this.closed?1:0),t.writeInt16(71,e.degree),t.writeInt16(72,e.knots.length),t.writeInt16(73,e.controlPoints.length),t.writeInt16(74,((s=e.fitPoints)==null?void 0:s.length)??0);for(const n of e.knots)t.writeDouble(40,n);for(const n of e.weights)t.writeDouble(41,n);for(const n of e.controlPoints)t.writePoint3d(10,n);for(const n of e.fitPoints??[])t.writePoint3d(11,n);return this}};vr.typeName="Spline";let Ds=vr;const nc=new b,kr=class kr extends Ge{get dxfTypeName(){return"ACAD_TABLE"}constructor(t,e,s){super(t),this._attachmentPoint=ot.TopLeft,this._numColumns=s,this._numRows=e,this._columnWidth=new Array(s),this._rowHeight=new Array(e),this._cells=new Array(e*s)}get attachmentPoint(){return this._attachmentPoint}set attachmentPoint(t){this._attachmentPoint=t}get numRows(){return this._numRows}set numRows(t){this._numRows=t}get numColumns(){return this._numColumns}set numColumns(t){this._numColumns=t}numContents(t,e){return 1}rowHeight(t){return this._rowHeight[t]}setRowHeight(t,e){this._rowHeight[t]=e}setUniformRowHeight(t){this._rowHeight.fill(t)}columnWidth(t){return this._columnWidth[t]}setUniformColumnWidth(t){this._columnWidth.fill(t)}setColumnWidth(t,e){this._columnWidth[t]=e}cell(t){if(!(t<0||t>=this._cells.length))return this._cells[t]}setCell(t,e){this._cells[t]=e}textString(t,e,s){var r;const n=t*this._numColumns+e;return(r=this._cells[n])==null?void 0:r.text}setTextString(t,e,s){const n=t*this._numColumns+e;if(!this._cells[n]){this._cells[n]={text:s,attachmentPoint:this._attachmentPoint,cellType:1,textHeight:0};return}this._cells[n].text=s}isEmpty(t,e){var n;const s=t*this._numColumns+e;return!((n=this._cells[s])!=null&&n.text)}get geometricExtents(){return new C}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"table",properties:[{name:"numRows",type:"string",editable:!0,accessor:{get:()=>this.numRows,set:t=>{this.numRows=t}}},{name:"numColumns",type:"float",editable:!0,accessor:{get:()=>this.numColumns,set:t=>{this.numColumns=t}}},{name:"tableWidth",type:"float",editable:!1,accessor:{get:()=>this._columnWidth.reduce((t,e)=>t+e,0)}},{name:"tableHeight",type:"float",editable:!1,accessor:{get:()=>this._rowHeight.reduce((t,e)=>t+e,0)}}]},{groupName:"geometry",properties:[{name:"positionX",type:"float",editable:!0,accessor:{get:()=>this.position.x,set:t=>{this.position.x=t}}},{name:"positionY",type:"float",editable:!0,accessor:{get:()=>this.position.y,set:t=>{this.position.y=t}}},{name:"positionZ",type:"float",editable:!0,accessor:{get:()=>this.position.z,set:t=>{this.position.z=t}}}]}]}}subWorldDraw(t){const e=this.blockTableRecord;if(!this.hasRenderableCellContent()&&e&&e.newIterator().count>0){const p=this.drawAnonymousTableBlock(t,e);if(p)return p}let s=0,n=0;const r=new Uint16Array(this.numColumns*this.numRows*8),a=new Float32Array((this.numColumns+1)*(this.numRows+1)*3);let o=0;for(let p=0;p<=this.numRows;p++){s-=p>0?this.rowHeight(p-1):0,n=0;for(let m=0;m<=this.numColumns;m++)n+=m>0?this.columnWidth(m-1):0,a[o++]=n,a[o++]=s,a[o++]=0}const l=[],c=new Array(this.numRows*this.numColumns).fill(!1);n=0,o=0;let u=0;for(let p=0;p<this.numColumns;p++){n+=p>0?this.columnWidth(p-1):0,s=0;for(let m=0;m<this.numRows;m++){s+=m>0?this.rowHeight(m-1):0;const y=this.cell(m*this.numColumns+p);if(u=m*this.numColumns+p,y&&!c[u]){const x=y.borderWidth??1,f=y.borderHeight??1;this.fillVisited(c,u,this.numColumns,x,f),r[o++]=p+m*(this.numColumns+1),r[o++]=p+m*(this.numColumns+1)+x;const P=a[r[o-1]*3]-n,I=p+(m+f)*(this.numColumns+1)+x;p+x==this.numColumns&&(r[o++]=p+m*(this.numColumns+1)+x,r[o++]=I);const M=-a[I*3+1]-s;if(m+f==this.numRows&&(r[o++]=p+(m+f)*(this.numColumns+1)+f,r[o++]=p+(m+f)*(this.numColumns+1)),r[o++]=p+(m+f)*(this.numColumns+1),r[o++]=p+m*(this.numColumns+1),y.text){const A=y.attachmentPoint||this.attachmentPoint||ot.MiddleCenter,j=this.getTableTextOffset(A,P,M),T={text:y.text,height:this.getCellTextHeight(y,M),width:P,position:nc.set(n,-s,0).clone().add(j),rotation:this.rotation,attachmentPoint:A},X=this.getTextStyle(y);l.push(t.mtext(T,X))}}}}l.push(t.lineSegments(a,3,r));const d=t.group(l),g=new Ue;return g.setFromAxisAngle(b.Z_AXIS,this.rotation),hi.compose(this.position,g,this.scaleFactors),d.applyMatrix(hi),d}hasRenderableCellContent(){return this._cells.some(t=>!!t&&(!!t.text||!!t.blockTableRecordId))}drawAnonymousTableBlock(t,e){const s=[],n=e.newIterator();for(const o of n){let l;o.color.isByBlock&&this.rgbColor?(la.copy(o.color),o.color.setRGBValue(this.rgbColor),l=o.worldDraw(t),o.color.copy(la)):l=o.worldDraw(t),l&&(l.objectId=this.objectId,l.ownerId=this.ownerId,l.layerName=this.layer,l.visible=this.visibility&&o.visibility,s.push(l))}const r=t.group(s);r.applyMatrix(this.blockTransform);const a=this.normal;return a&&(a.x!==0||a.y!==0||a.z!==1)&&(hi.setFromExtrusionDirection(a),r.applyMatrix(hi)),r}fillVisited(t,e,s,n,r){if(r==1&&n==1)t[e]=!0;else for(let a=0;a<n;++a)for(let o=0;o<r;++o)t[e+a+o*s]=!0}getTextStyle(t){const e=this.database.tables.textStyleTable,s=(t.textStyle?e.getAt(t.textStyle):void 0)??e.getAt(this.database.textstyle)??e.getAt(tt);if(!s)throw new Error("No valid text style found in text style table.");return s.textStyle}getTableTextOffset(t,e,s){const n=new b;switch(t){case 1:break;case 2:n.setX(e/2);break;case 3:n.setX(e);break;case 4:n.setY(-s/2);break;case 5:n.set(e/2,-s/2,0);break;case 6:n.set(e,-s/2,0);break;case 7:n.setY(-s);break;case 8:n.set(e/2,-s,0);break;case 9:n.set(e,-s,0);break}return n}getCellTextHeight(t,e){return t.textHeight&&t.textHeight>0?t.textHeight:Math.max(e/2,1)}dxfOutFields(t){var r,a,o,l,c,u,d;super.dxfOutFields(t),t.writeSubclassMarker("AcDbTable");const e=t.version??((r=t.database)==null?void 0:r.version)??((a=this.database)==null?void 0:a.version),s=(e==null?void 0:e.value)!=null?e.value>=27:!1;t.writeInt16(280,this.tableDataVersion),t.writeObjectId(342,this.tableStyleId),t.writeObjectId(343,this.owningBlockRecordId),t.writeVector3d(11,this.horizontalDirection),t.writeUInt32(90,this.tableValueFlag),t.writeUInt32(93,this.tableOverrideFlag),t.writeUInt32(94,this.borderColorOverrideFlag),t.writeUInt32(95,this.borderLineweightOverrideFlag),t.writeUInt32(96,this.borderVisibilityOverrideFlag),t.writeInt16(71,this.attachmentPoint),t.writeInt32(91,this.numRows),t.writeInt32(92,this.numColumns);for(let g=0;g<this.numRows;++g)t.writeDouble(141,this.rowHeight(g));for(let g=0;g<this.numColumns;++g)t.writeDouble(142,this.columnWidth(g));const n=this._cells.length>0?this._cells.length:this.numRows*this.numColumns;for(let g=0;g<n;g++){const p=this._cells[g],m=(p==null?void 0:p.cellType)??(p!=null&&p.blockTableRecordId?2:1);if(t.writeInt16(171,m),t.writeInt16(172,(p==null?void 0:p.flagValue)??0),t.writeInt16(173,(p==null?void 0:p.mergedValue)??0),t.writeBoolean(174,p==null?void 0:p.autoFit),t.writeInt16(175,p==null?void 0:p.borderWidth),t.writeInt16(176,p==null?void 0:p.borderHeight),(p==null?void 0:p.overrideFlag)!=null&&(s?t.writeInt32(91,p.overrideFlag):t.writeInt16(177,p.overrideFlag)),t.writeInt16(178,p==null?void 0:p.virtualEdgeFlag),t.writeAngle(145,p==null?void 0:p.rotation),s&&t.writeInt16(92,p==null?void 0:p.extendedCellFlags),m===1)p!=null&&p.fieldObjetId?t.writeObjectId(344,p.fieldObjetId):this.writeCellText(t,(p==null?void 0:p.text)??"",s,p==null?void 0:p.cellValueBlockBegin);else if(m===2){if(t.writeObjectId(340,p==null?void 0:p.blockTableRecordId),t.writeDouble(144,p==null?void 0:p.blockScale),t.writeInt16(179,p==null?void 0:p.blockAttrNum),(o=p==null?void 0:p.attrDefineId)!=null&&o.length)for(const y of p.attrDefineId)t.writeObjectId(331,y);if((p==null?void 0:p.attrText)!=null)if(Array.isArray(p.attrText))for(const y of p.attrText)t.writeString(300,y);else t.writeString(300,p.attrText)}p!=null&&p.textStyle&&t.writeString(7,p.textStyle),(p==null?void 0:p.textHeight)!=null&&t.writeDouble(140,p.textHeight),(p==null?void 0:p.attachmentPoint)!=null&&t.writeInt16(170,p.attachmentPoint),(p==null?void 0:p.topBorderVisibility)!=null&&t.writeInt16(289,p.topBorderVisibility?1:0),(p==null?void 0:p.rightBorderVisibility)!=null&&t.writeInt16(285,p.rightBorderVisibility?1:0),(p==null?void 0:p.bottomBorderVisibility)!=null&&t.writeInt16(286,p.bottomBorderVisibility?1:0),(p==null?void 0:p.leftBorderVisibility)!=null&&t.writeInt16(288,p.leftBorderVisibility?1:0)}if(t.writeInt16(70,this.flowDirection),t.writeDouble(40,this.horizontalCellMargin),t.writeDouble(41,this.verticalCellMargin),this.suppressTitle!=null&&t.writeInt16(280,this.suppressTitle?1:0),this.suppressHeader!=null&&t.writeInt16(281,this.suppressHeader?1:0),(l=this.cellTypeOverrides)!=null&&l.length)for(const g of this.cellTypeOverrides){t.writeString(7,g.textStyle),t.writeDouble(140,g.textHeight),t.writeInt16(170,g.alignment),t.writeInt16(63,g.backgroundColor),t.writeInt16(64,g.contentColor),g.backgroundColorEnabled!=null&&t.writeInt16(283,g.backgroundColorEnabled?1:0);const p=g.borderLineweights;p&&(t.writeInt16(274,p.top),t.writeInt16(275,p.right),t.writeInt16(276,p.bottom),t.writeInt16(277,p.left),t.writeInt16(278,p.insideHorizontal),t.writeInt16(279,p.insideVertical));const m=g.borderVisibility;m&&(t.writeInt16(284,m.top?1:0),t.writeInt16(285,m.right?1:0),t.writeInt16(286,m.bottom?1:0),t.writeInt16(287,m.left?1:0),t.writeInt16(288,m.insideHorizontal?1:0),t.writeInt16(289,m.insideVertical?1:0))}if(this.tableBorderColors&&(t.writeInt16(63,this.tableBorderColors.left),t.writeInt16(64,this.tableBorderColors.top),t.writeInt16(65,this.tableBorderColors.insideHorizontal),t.writeInt16(66,this.tableBorderColors.bottom),t.writeInt16(68,this.tableBorderColors.insideVertical),t.writeInt16(69,this.tableBorderColors.right)),(c=this.rowDataTypes)!=null&&c.length)for(const g of this.rowDataTypes)t.writeInt16(97,g);if((u=this.rowUnitTypes)!=null&&u.length)for(const g of this.rowUnitTypes)t.writeInt16(98,g);if((d=this.rowFormats)!=null&&d.length)for(const g of this.rowFormats)t.writeString(4,g);return this}writeCellText(t,e,s,n){if(!s){if(e.length<=250){t.writeString(1,e);return}const o=Math.ceil(e.length/250);for(let l=0;l<o;l++){const c=l*250,u=c+250,d=e.slice(c,u);l===o-1?t.writeString(1,d):t.writeString(2,d)}return}if(t.writeString(301,n??"CELL_VALUE"),e.length<=250){t.writeString(302,e),t.writeString(304,"ACVALUE_END");return}const a=Math.ceil(e.length/250);for(let o=0;o<a;o++){const l=o*250,c=l+250,u=e.slice(l,c);o===a-1?t.writeString(302,u):t.writeString(303,u)}t.writeString(304,"ACVALUE_END")}};kr.typeName="Table";let Oi=kr;const hi=new G,la=new Q,Lr=class Lr extends rt{get dxfTypeName(){return"TRACE"}constructor(){super(),this._elevation=0,this._thickness=1,this._vertices=[new w,new w,new w,new w]}get elevation(){return this._elevation}set elevation(t){this._elevation=t}get closed(){return!0}get thickness(){return this._thickness}set thickness(t){this._thickness=t}getPointAt(t){return t<0?this._vertices[0]:t>3?this._vertices[3]:this._vertices[t]}setPointAt(t,e){if(t<0&&this._vertices[0].copy(e),t>3)return this._vertices[3].copy(e);this._vertices[t].copy(e)}get geometricExtents(){return new C().setFromPoints(this._vertices)}subGetGripPoints(){const t=new Array;return t.push(...this._vertices),t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:n.push(...this._vertices);break}}transformBy(t){return this._vertices.forEach(e=>e.applyMatrix4(t)),this._elevation=this._vertices[0].z,this}subWorldDraw(t){const e=new Mt(this._vertices,!0),s=new ts;s.add(e);const n=t.subEntityTraits;return n.fillType={solidFill:!0,patternAngle:0,definitionLines:[]},t.area(s)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbTrace"),t.writeDouble(38,this.elevation),t.writeDouble(39,this.thickness),t.writePoint3d(10,this.getPointAt(0)),t.writePoint3d(11,this.getPointAt(1)),t.writePoint3d(12,this.getPointAt(2)),t.writePoint3d(13,this.getPointAt(3)),this}};Lr.typeName="Trace";let Ni=Lr;const Or=class Or extends rt{get dxfTypeName(){return"LWPOLYLINE"}constructor(){super(),this._elevation=0,this._geo=new Mt}get numberOfVertices(){return this._geo.numberOfVertices}get elevation(){return this._elevation}set elevation(t){this._elevation=t}get closed(){return this._geo.closed}set closed(t){this._geo.closed=t}addVertexAt(t,e,s=0,n=-1,r=-1){const a=n<0?void 0:n,o=r<0?void 0:r,l={x:e.x,y:e.y,bulge:s,startWidth:a,endWidth:o};this._geo.addVertexAt(t,l)}removeVertexAt(t){this._geo.removeVertexAt(t)}reset(t,e){this._geo.reset(t,e)}getPoint2dAt(t){return this._geo.getPointAt(t)}getPoint3dAt(t){const e=this.getPoint2dAt(t);return new w(e.x,e.y,this._elevation)}get geometricExtents(){const t=this._geo.box;return new C({x:t.min.x,y:t.min.y,z:this._elevation},{x:t.max.x,y:t.max.y,z:this._elevation})}subGetGripPoints(){const t=new Array;for(let e=0;e<this.numberOfVertices;++e)t.push(this.getPoint3dAt(e));return t}subGetOsnapPoints(t,e,s,n){const r=new Array;for(let a=0;a<this.numberOfVertices;++a)r.push(this.getPoint3dAt(a));switch(t){case z.EndPoint:n.push(...r);break}}transformBy(t){const e=t.determinant()<0;let s=this._elevation;return this._geo.vertices.forEach(n=>{const r=new w(n.x,n.y,this._elevation).applyMatrix4(t);n.x=r.x,n.y=r.y,s=r.z,e&&n.bulge!=null&&(n.bulge=-n.bulge)}),this._elevation=s,this._geo._boundingBoxNeedsUpdate=!0,this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"vertices",type:"array",editable:!1,itemSchema:{properties:[{name:"x",type:"float",editable:!0},{name:"y",type:"float",editable:!0}]},accessor:{get:()=>this._geo.vertices}},{name:"elevation",type:"float",editable:!0,accessor:{get:()=>this.elevation,set:t=>{this.elevation=t}}},{name:"length",type:"float",editable:!1,accessor:{get:()=>this._geo.length}}]},{groupName:"others",properties:[{name:"closed",type:"float",editable:!0,accessor:{get:()=>this.closed,set:t=>{this.closed=t}}}]}]}}subWorldDraw(t){const e=this._geo.getPoints(100),s=this.createWidthProfile();if(s!=null){const r=rc(s,this.closed);if(r!=null){const a=t.subEntityTraits;return a.fillType={solidFill:!0,patternAngle:0,definitionLines:[]},t.area(r)}}const n=[];return e.forEach(r=>n.push(new w().set(r.x,r.y,this.elevation))),t.lines(n)}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbPolyline"),t.writeInt32(90,this.numberOfVertices),t.writeInt16(70,this.closed?1:0),t.writeDouble(38,this.elevation);for(let e=0;e<this.numberOfVertices;++e)t.writePoint2d(10,this.getPoint2dAt(e));return this}createWidthProfile(){const t=this._geo.vertices,e=t.length;if(e<2)return null;const s=this.closed?e:e-1,n=[];let r=!1;for(let a=0;a<s;a++){const o=t[a],l=t[(a+1)%e],c=Math.max(0,o.startWidth??0),u=Math.max(0,o.endWidth??0);(c>Tt||u>Tt)&&(r=!0);const d=this.sampleSegment(o,l),g=d.length-1;for(let p=0;p<=g;p++){if(p===0&&n.length>0||this.closed&&a===s-1&&p===g)continue;const m=g>0?p/g:0;n.push({x:d[p].x,y:d[p].y,width:lc(c,u,m)})}}return r&&n.length>=2?n:null}sampleSegment(t,e){if(t.bulge&&Math.abs(t.bulge)>Tt){const n=new ye(t,e,t.bulge).getPoints(32);if(n.length>1)return n.map(r=>new k(r.x,r.y))}return[new k(t.x,t.y),new k(e.x,e.y)]}};Or.typeName="Polyline";let Ci=Or;const Tt=1e-6,ca=4;function rc(i,t){if(i.length<2)return null;const e=oc(i,t);if(e.length<2)return null;const{left:s,right:n}=ac(e,t);if(s.length<2||n.length<2)return null;const r=new ts;if(t){if(!dn(s)||!dn(n))return null;const o=Math.abs(Nn(s)),l=Math.abs(Nn(n)),[c,u]=o>=l?[s,n]:[n,s];return r.add(new Mt(c,!0)),r.add(new Mt(u,!0)),r}const a=[...s,...n.reverse()];return dn(a)?(r.add(new Mt(a,!0)),r):null}function ac(i,t){const e=[],s=[];for(let n=0;n<i.length;n++){const r=i[n],a=Math.max(0,r.width)/2;if(a<=Tt)continue;const o=hc(i,n,t);o!=null&&(e.push({x:r.x+o.x*a,y:r.y+o.y*a}),s.push({x:r.x-o.x*a,y:r.y-o.y*a}))}return{left:e,right:s}}function oc(i,t){const e=[];if(i.forEach(s=>{const n=e[e.length-1];(!n||Math.abs(n.x-s.x)>Tt||Math.abs(n.y-s.y)>Tt||Math.abs(n.width-s.width)>Tt)&&e.push(s)}),t&&e.length>1){const s=e[0],n=e[e.length-1];Math.abs(s.x-n.x)<=Tt&&Math.abs(s.y-n.y)<=Tt&&e.pop()}return e}function hc(i,t,e){const s=i.length,n=i[t],r=i[(t-1+s)%s],a=i[(t+1)%s];let o=da(n.x-r.x,n.y-r.y),l=da(a.x-n.x,a.y-n.y);if(e||(t===0&&(o=l),t===s-1&&(l=o)),o==null&&l==null)return null;if(o==null)return li(l);if(l==null)return li(o);const c=li(o),u=li(l),d=c.x+u.x,g=c.y+u.y,p=Math.hypot(d,g);if(p<=Tt)return u;const m={x:d/p,y:g/p},y=Math.abs(m.x*u.x+m.y*u.y),x=y<=Tt?ca:Math.min(1/y,ca);return{x:m.x*x,y:m.y*x}}function da(i,t){const e=Math.hypot(i,t);return e<=Tt?null:{x:i/e,y:t/e}}function li(i){return{x:-i.y,y:i.x}}function Nn(i){let t=0;const e=i.length;for(let s=0;s<e;s++){const n=i[s],r=i[(s+1)%e];t+=n.x*r.y-r.x*n.y}return t/2}function dn(i){return i.length>=3&&Math.abs(Nn(i))>Tt}function lc(i,t,e){return i+(t-i)*e}const Nr=class Nr extends gt{get dxfTypeName(){return"POINT"}constructor(){super(),this._geo=new w}get position(){return this._geo}set position(t){this._geo.set(t.x,t.y,t.z||0)}get geometricExtents(){return new C().expandByPoint(this._geo)}subGetOsnapPoints(t,e,s,n){z.Node===t&&n.push(this._geo)}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"positionX",type:"float",editable:!0,accessor:{get:()=>this.position.x,set:t=>{this.position.x=t}}},{name:"positionY",type:"float",editable:!0,accessor:{get:()=>this.position.y,set:t=>{this.position.y=t}}},{name:"positionZ",type:"float",editable:!0,accessor:{get:()=>this.position.z,set:t=>{this.position.z=t}}}]}]}}transformBy(t){return this._geo.applyMatrix4(t),this}subWorldDraw(t){return t.point(this._geo,{displayMode:this.database.pdmode,displaySize:this.database.pdsize})}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbPoint"),t.writePoint3d(10,this.position),this}};Nr.typeName="Point";let Bi=Nr;var vo=(i=>(i[i.Invalid=0]="Invalid",i[i.Rect=1]="Rect",i[i.Poly=2]="Poly",i))(vo||{}),ko=(i=>(i[i.Show=1]="Show",i[i.ShowUnAligned=2]="ShowUnAligned",i[i.Clip=4]="Clip",i[i.Transparent=8]="Transparent",i))(ko||{});const Cr=class Cr extends gt{get dxfTypeName(){return"IMAGE"}constructor(){super(),this._brightness=50,this._contrast=50,this._fade=0,this._width=0,this._height=0,this._position=new w,this._scale=new Y(1,1),this._rotation=0,this._imageSize=new k,this._clipBoundaryType=1,this._clipBoundary=[],this._isClipped=!1,this._isShownClipped=!1,this._isImageShown=!0,this._isImageTransparent=!1,this._imageDefId=""}get brightness(){return this._brightness}set brightness(t){this._brightness=t}get contrast(){return this._contrast}set contrast(t){this._contrast=t}get fade(){return this._fade}set fade(t){this._fade=t}get height(){return this._height}set height(t){this._height=t}get width(){return this._width}set width(t){this._width=t}get position(){return this._position}set position(t){this._position=t}get rotation(){return this._rotation}set rotation(t){this._rotation=t}get scale(){return this._scale}set scale(t){this._scale.copy(t)}get imageSize(){return this._imageSize}set imageSize(t){this._imageSize.copy(t)}get clipBoundaryType(){return this._clipBoundaryType}set clipBoundaryType(t){this._clipBoundaryType=t}get clipBoundary(){return this._clipBoundary}set clipBoundary(t){this._clipBoundary=[],this._clipBoundary.push(...t)}get isClipped(){return this._isClipped}set isClipped(t){this._isClipped=t}get isShownClipped(){return this._isShownClipped}set isShownClipped(t){this._isShownClipped=t}get isImageShown(){return this._isImageShown}set isImageShown(t){this._isImageShown=t}get isImageTransparent(){return this._isImageTransparent}set isImageTransparent(t){this._isImageTransparent=t}get image(){return this._image}set image(t){this._image=t}get imageDefId(){return this._imageDefId}set imageDefId(t){this._imageDefId=t}get imageFileName(){if(this._imageDefId){const t=this.database.objects.imageDefinition.getIdAt(this._imageDefId);if(t)return t.sourceFileName}return""}get geometricExtents(){const t=new C;return t.min.copy(this._position),t.max.set(this._position.x+this._width,this._position.y+this._height,0),t}subGetGripPoints(){return this.boundaryPath()}subWorldDraw(t){const e=this.boundaryPath();return this._image?t.image(this._image,{boundary:e,roation:this._rotation}):t.lines(e)}transformBy(t){const e=this._width*this._scale.x,s=this._height*this._scale.y,n=new b(e*Math.cos(this._rotation),e*Math.sin(this._rotation),0),r=new b(-s*Math.sin(this._rotation),s*Math.cos(this._rotation),0),a=this._position.clone(),o=this._position.clone().add(n),l=this._position.clone().add(r);a.applyMatrix4(t),o.applyMatrix4(t),l.applyMatrix4(t);const c=new b(o).sub(a),u=new b(l).sub(a);return this._position.copy(a),this._rotation=Math.atan2(c.y,c.x),this._width=c.length(),this._height=u.length(),this._scale.set(1,1),this}boundaryPath(){const t=[];if(this.isClipped&&this._clipBoundary.length>3){const e=this._width,s=this._height,n=new pt;n.setFromPoints(this._clipBoundary);const r=new k;r.setX(this._position.x-n.min.x*e),r.setY(this._position.y-n.min.y*s),this._clipBoundary.forEach(a=>{const o=a.x*e+r.x,l=a.y*s+r.y;t.push(new w(o,l,this._position.z))})}else{if(t.push(this._position),t.push(this._position.clone().setX(this._position.x+this._width)),t.push(this._position.clone().set(this._position.x+this._width,this._position.y+this._height,this._position.z)),t.push(this._position.clone().setY(this._position.y+this._height)),this._rotation>0){ua.copy(t[1]);for(let e=1;e<4;e++)ci.copy(t[e]),ci.rotateAround(ua,this._rotation),t[e].setX(ci.x),t[e].setY(ci.y)}t.push(t[0])}return t}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbRasterImage"),t.writePoint3d(10,this.position);const e=this.width*this.scale.x,s=this.height*this.scale.y,n=this._imageSize.x>0&&this._imageSize.y>0?this._imageSize:{x:e,y:s},r=n.x>0?e/n.x:e,a=n.y>0?s/n.y:s,o=Math.cos(this._rotation),l=Math.sin(this._rotation);t.writePoint3d(11,{x:r*o,y:r*l,z:0}),t.writePoint3d(12,{x:-a*l,y:a*o,z:0}),t.writePoint2d(13,n),t.writeObjectId(340,this.imageDefId);const c=(this.isImageShown?1:0)|(this.isShownClipped?4:0)|(this.isImageTransparent?8:0);if(t.writeInt16(70,c),t.writeInt16(280,this.isClipped?1:0),t.writeInt16(281,this.brightness),t.writeInt16(282,this.contrast),t.writeInt16(283,this.fade),t.writeInt16(71,this.clipBoundaryType),this.isClipped){t.writeInt16(91,this.clipBoundary.length);for(const u of this.clipBoundary)t.writePoint2d(14,u)}return this}};Cr.typeName="RasterImage";let js=Cr;const ua=new k,ci=new k,Br=class Br extends rt{get dxfTypeName(){return"RAY"}constructor(){super(),this._basePoint=new w,this._unitDir=new b}get basePoint(){return this._basePoint}set basePoint(t){this._basePoint.copy(t)}get unitDir(){return this._unitDir}set unitDir(t){this._unitDir.copy(t)}get closed(){return!1}get geometricExtents(){const t=new C;return t.expandByPoint(this._unitDir.clone().multiplyScalar(10).add(this._basePoint)),t.expandByPoint(this._unitDir.clone().multiplyScalar(-10).add(this._basePoint)),t}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"basePointX",type:"float",editable:!0,accessor:{get:()=>this.basePoint.x,set:t=>{this.basePoint.x=t}}},{name:"basePointY",type:"float",editable:!0,accessor:{get:()=>this.basePoint.y,set:t=>{this.basePoint.y=t}}},{name:"basePointZ",type:"float",editable:!0,accessor:{get:()=>this.basePoint.z,set:t=>{this.basePoint.z=t}}},{name:"unitDirX",type:"float",editable:!0,accessor:{get:()=>this.unitDir.x,set:t=>{this.unitDir.x=t}}},{name:"unitDirY",type:"float",editable:!0,accessor:{get:()=>this.unitDir.y,set:t=>{this.unitDir.y=t}}},{name:"unitDirZ",type:"float",editable:!0,accessor:{get:()=>this.unitDir.z,set:t=>{this.unitDir.z=t}}}]}]}}subGetGripPoints(){const t=new Array;return t.push(this.basePoint),t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:n.push(this.basePoint);break}}transformBy(t){return this._basePoint.applyMatrix4(t),this._unitDir.transformDirection(t),this}subWorldDraw(t){const e=[];return e.push(this.basePoint),e.push(this._unitDir.clone().multiplyScalar(1e6).add(this._basePoint)),t.lines(e)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbRay"),t.writePoint3d(10,this.basePoint),t.writeVector3d(11,this.unitDir),this}};Br.typeName="Ray";let Fi=Br;const Fr=class Fr extends gt{get dxfTypeName(){return"VIEWPORT"}constructor(){super(),this._centerPoint=new w,this._height=0,this._width=0,this._viewCenter=new w,this._viewHeight=0,this._number=-1}get number(){return this._number}set number(t){this._number=t}get centerPoint(){return this._centerPoint}set centerPoint(t){this._centerPoint=t}get height(){return this._height}set height(t){this._height=t}get width(){return this._width}set width(t){this._width=t}get viewCenter(){return this._viewCenter}set viewCenter(t){this._viewCenter=t}get viewHeight(){return this._viewHeight}set viewHeight(t){this._viewHeight=t}get geometricExtents(){return new C}transformBy(t){const e=this._centerPoint.clone(),s=this._centerPoint.clone().add(new b(this._width,0,0)),n=this._centerPoint.clone().add(new b(0,this._height,0));e.applyMatrix4(t),s.applyMatrix4(t),n.applyMatrix4(t);const r=new b(s).sub(e),a=new b(n).sub(e),o=this._height!==0?a.length()/this._height:1;return this._centerPoint.copy(e),this._width=r.length(),this._height=a.length(),this._viewHeight*=o,this}subWorldDraw(t){if(this._number>1&&this.ownerId!=this.database.tables.blockTable.modelSpace.objectId){const e=this.toGiViewport();return t.group(this.createViewportRect(e,t))}}toGiViewport(){const t=new fo;return t.id=this.objectId,t.groupId=this.ownerId,t.number=this.number,t.centerPoint=this.centerPoint,t.width=this.width,t.height=this.height,t.viewHeight=this.viewHeight,t.viewCenter=this.viewCenter,t}createViewportRect(t,e){const s=[];return s.push(e.lines([new w(t.centerPoint.x-t.width/2,t.centerPoint.y-t.height/2,0),new w(t.centerPoint.x+t.width/2,t.centerPoint.y-t.height/2,0)])),s.push(e.lines([new w(t.centerPoint.x+t.width/2,t.centerPoint.y-t.height/2,0),new w(t.centerPoint.x+t.width/2,t.centerPoint.y+t.height/2,0)])),s.push(e.lines([new w(t.centerPoint.x+t.width/2,t.centerPoint.y+t.height/2,0),new w(t.centerPoint.x-t.width/2,t.centerPoint.y+t.height/2,0)])),s.push(e.lines([new w(t.centerPoint.x-t.width/2,t.centerPoint.y+t.height/2,0),new w(t.centerPoint.x-t.width/2,t.centerPoint.y-t.height/2,0)])),s}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbViewport"),t.writePoint3d(10,this.centerPoint),t.writeDouble(40,this.height),t.writeDouble(41,this.width),t.writePoint3d(12,this.viewCenter),t.writeDouble(45,this.viewHeight),t.writeInt32(69,this.number),this}};Fr.typeName="Viewport";let Ri=Fr;const Rr=class Rr extends js{get dxfTypeName(){return"WIPEOUT"}subWorldDraw(t){const e=this.boundaryPath(),s=new ts;return s.add(new Mt(e)),t.area(s)}dxfOutFields(t){return super.dxfOutFields(t),this}};Rr.typeName="Wipeout";let zi=Rr;const zr=class zr extends rt{get dxfTypeName(){return"XLINE"}constructor(){super(),this._basePoint=new w,this._unitDir=new b}get basePoint(){return this._basePoint}set basePoint(t){this._basePoint.copy(t)}get unitDir(){return this._unitDir}set unitDir(t){this._unitDir.copy(t)}get closed(){return!1}get geometricExtents(){const t=new C;return t.expandByPoint(this._unitDir.clone().multiplyScalar(10).add(this._basePoint)),t.expandByPoint(this._unitDir.clone().multiplyScalar(-10).add(this._basePoint)),t}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"basePointX",type:"float",editable:!0,accessor:{get:()=>this.basePoint.x,set:t=>{this.basePoint.x=t}}},{name:"basePointY",type:"float",editable:!0,accessor:{get:()=>this.basePoint.y,set:t=>{this.basePoint.y=t}}},{name:"basePointZ",type:"float",editable:!0,accessor:{get:()=>this.basePoint.z,set:t=>{this.basePoint.z=t}}},{name:"unitDirX",type:"float",editable:!0,accessor:{get:()=>this.unitDir.x,set:t=>{this.unitDir.x=t}}},{name:"unitDirY",type:"float",editable:!0,accessor:{get:()=>this.unitDir.y,set:t=>{this.unitDir.y=t}}},{name:"unitDirZ",type:"float",editable:!0,accessor:{get:()=>this.unitDir.z,set:t=>{this.unitDir.z=t}}}]}]}}subGetGripPoints(){const t=new Array;return t.push(this.basePoint),t}transformBy(t){return this._basePoint.applyMatrix4(t),this._unitDir.transformDirection(t),this}subWorldDraw(t){const e=[];return e.push(this._unitDir.clone().multiplyScalar(-1e6).add(this._basePoint)),e.push(this._unitDir.clone().multiplyScalar(1e6).add(this._basePoint)),t.lines(e)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbXline"),t.writePoint3d(10,this.basePoint),t.writeVector3d(11,this.unitDir),this}};zr.typeName="Xline";let Vi=zr;class Lo{constructor(t){this.position=new w(t.x,t.y,t.z||0)}}const Vr=class Vr extends rt{get dxfTypeName(){return"POLYLINE"}constructor(t,e,s,n=!1,r=!1){super(),this._mCount=t,this._nCount=e,this._closedM=n,this._closedN=r,this._vertices=s.map(a=>new Lo(a))}get mCount(){return this._mCount}get nCount(){return this._nCount}get closedM(){return this._closedM}get closedN(){return this._closedN}get closed(){return this._closedM}set closed(t){this._closedM=t}get numberOfVertices(){return this._vertices.length}getVertexAt(t){if(t<0||t>=this._vertices.length)throw new Error("Vertex index out of bounds");return this._vertices[t]}getVertexAtMN(t,e){const s=t*this._nCount+e;return this.getVertexAt(s)}get geometricExtents(){if(this._vertices.length===0)return new C(new w(0,0,0),new w(0,0,0));let t=Number.MAX_VALUE,e=Number.MAX_VALUE,s=Number.MAX_VALUE,n=-Number.MAX_VALUE,r=-Number.MAX_VALUE,a=-Number.MAX_VALUE;return this._vertices.forEach(o=>{t=Math.min(t,o.position.x),e=Math.min(e,o.position.y),s=Math.min(s,o.position.z),n=Math.max(n,o.position.x),r=Math.max(r,o.position.y),a=Math.max(a,o.position.z)}),new C(new w(t,e,s),new w(n,r,a))}subGetGripPoints(){const t=new Array;return this._vertices.forEach(e=>{t.push(e.position)}),t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:this._vertices.forEach(r=>{n.push(r.position)});break}}transformBy(t){return this._vertices.forEach(e=>{e.position.applyMatrix4(t)}),this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"mCount",type:"float",editable:!1,accessor:{get:()=>this._mCount}},{name:"nCount",type:"float",editable:!1,accessor:{get:()=>this._nCount}},{name:"vertices",type:"array",editable:!1,itemSchema:{properties:[{name:"x",type:"float",editable:!0},{name:"y",type:"float",editable:!0},{name:"z",type:"float",editable:!0}]},accessor:{get:()=>this._vertices.map(t=>({x:t.position.x,y:t.position.y,z:t.position.z}))}}]},{groupName:"others",properties:[{name:"closedM",type:"boolean",editable:!0,accessor:{get:()=>this._closedM,set:t=>{this._closedM=t}}},{name:"closedN",type:"boolean",editable:!0,accessor:{get:()=>this._closedN,set:t=>{this._closedN=t}}}]}]}}subWorldDraw(t){const e=[];for(let s=0;s<this._mCount;s++)for(let n=0;n<this._nCount;n++){const r=this.getVertexAtMN(s,n);let a=n+1;if(a>=this._nCount)if(this._closedN)a=0;else continue;const o=this.getVertexAtMN(s,a);e.push(r.position),e.push(o.position)}for(let s=0;s<this._nCount;s++)for(let n=0;n<this._mCount;n++){const r=this.getVertexAtMN(n,s);let a=n+1;if(a>=this._mCount)if(this._closedM)a=0;else continue;const o=this.getVertexAtMN(a,s);e.push(r.position),e.push(o.position)}return t.lines(e)}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbPolygonMesh");let e=16;return this._closedM&&(e|=1),this._closedN&&(e|=32),t.writeInt16(66,1),t.writeInt16(70,e),t.writeInt32(71,this._mCount),t.writeInt32(72,this._nCount),this}dxfOut(t,e=!1){super.dxfOut(t,e);for(let s=0;s<this.numberOfVertices;s++){const n=this.getVertexAt(s);t.writeStart("VERTEX"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDbPolygonMeshVertex"),t.writePoint3d(10,n.position),t.writeInt16(70,16)}return t.writeStart("SEQEND"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),this}};Vr.typeName="PolygonMesh";let Di=Vr;class Oo{constructor(t){this.position=new w(t.x,t.y,t.z||0)}}class No{constructor(t){this.vertexIndices=t}}const Dr=class Dr extends rt{get dxfTypeName(){return"POLYLINE"}constructor(t,e){super(),this._vertices=t.map(s=>new Oo(s)),this._faces=e.map(s=>new No(s))}get numberOfVertices(){return this._vertices.length}get numberOfFaces(){return this._faces.length}get closed(){return!1}set closed(t){}getVertexAt(t){if(t<0||t>=this._vertices.length)throw new Error("Vertex index out of bounds");return this._vertices[t]}getFaceAt(t){if(t<0||t>=this._faces.length)throw new Error("Face index out of bounds");return this._faces[t]}get geometricExtents(){if(this._vertices.length===0)return new C(new w(0,0,0),new w(0,0,0));let t=Number.MAX_VALUE,e=Number.MAX_VALUE,s=Number.MAX_VALUE,n=-Number.MAX_VALUE,r=-Number.MAX_VALUE,a=-Number.MAX_VALUE;return this._vertices.forEach(o=>{t=Math.min(t,o.position.x),e=Math.min(e,o.position.y),s=Math.min(s,o.position.z),n=Math.max(n,o.position.x),r=Math.max(r,o.position.y),a=Math.max(a,o.position.z)}),new C(new w(t,e,s),new w(n,r,a))}subGetGripPoints(){const t=new Array;return this._vertices.forEach(e=>{t.push(e.position)}),t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:this._vertices.forEach(r=>{n.push(r.position)});break}}transformBy(t){return this._vertices.forEach(e=>{e.position.applyMatrix4(t)}),this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"vertices",type:"array",editable:!1,itemSchema:{properties:[{name:"x",type:"float",editable:!0},{name:"y",type:"float",editable:!0},{name:"z",type:"float",editable:!0}]},accessor:{get:()=>this._vertices.map(t=>({x:t.position.x,y:t.position.y,z:t.position.z}))}},{name:"faces",type:"array",editable:!1,itemSchema:{properties:[{name:"vertexIndices",type:"array",editable:!1,itemSchema:{properties:[{name:"index",type:"int",editable:!1}]}}]},accessor:{get:()=>this._faces.map(t=>({vertexIndices:t.vertexIndices}))}}]}]}}subWorldDraw(t){const e=[];return this._faces.forEach(s=>{const n=[];if(s.vertexIndices.forEach(r=>{const a=Math.abs(r)-1;a>=0&&a<this._vertices.length&&n.push(this._vertices[a].position)}),n.length>=3)for(let r=0;r<n.length;r++){const a=n[r],o=n[(r+1)%n.length];e.push(a),e.push(o)}}),t.lines(e)}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbPolyFaceMesh");const e=64;return t.writeInt16(66,1),t.writeInt16(70,e),this}dxfOut(t,e=!1){super.dxfOut(t,e);for(let s=0;s<this.numberOfVertices;s++){const n=this.getVertexAt(s);t.writeStart("VERTEX"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDbPolyFaceMeshVertex"),t.writePoint3d(10,n.position),t.writeInt16(70,64)}for(let s=0;s<this.numberOfFaces;s++){const n=this.getFaceAt(s);t.writeStart("VERTEX"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDbPolyFaceMeshVertex"),t.writeInt16(70,128),n.vertexIndices.forEach((r,a)=>{t.writeInt32(10+a,r)})}return t.writeStart("SEQEND"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),this}};Dr.typeName="PolyFaceMesh";let ji=Dr;var Wi=(i=>(i[i.AtLeast=1]="AtLeast",i[i.Exactly=2]="Exactly",i))(Wi||{});const jr=class jr extends gt{get dxfTypeName(){return"DIMENSION"}constructor(){super(),this._dimBlockId=null,this._dimBlockPosition=new w,this._dimensionStyleName=null,this._dimensionText=null,this._textLineSpacingFactor=1,this._textLineSpacingStyle=1,this._textPosition=new w,this._textRotation=0,this._normal=new b(0,0,1)}get dimBlockId(){return this._dimBlockId}set dimBlockId(t){this._dimBlockId=t}get dimBlockPosition(){return this._dimBlockPosition}set dimBlockPosition(t){this._dimBlockPosition.copy(t)}get dimensionStyleName(){return this._dimensionStyleName}set dimensionStyleName(t){this._dimensionStyleName=t,this._dimStyle=void 0}get dimensionStyle(){if(this._dimStyle==null){let t;this.dimensionStyleName&&(t=this.database.tables.dimStyleTable.getAt(this.dimensionStyleName)),t==null&&(t=new He),this._dimStyle=t}return this._dimStyle}get dimensionText(){return this._dimensionText}set dimensionText(t){this._dimensionText=t}get measurement(){return this._measurement}set measurement(t){this._measurement=t}get textLineSpacingFactor(){return this._textLineSpacingFactor}set textLineSpacingFactor(t){this._textLineSpacingFactor=t}get textLineSpacingStyle(){return this._textLineSpacingStyle}set textLineSpacingStyle(t){this._textLineSpacingStyle=t}get textPosition(){return this._textPosition}set textPosition(t){this._textPosition.copy(t)}get textRotation(){return this._textRotation}set textRotation(t){this._textRotation=t}get normal(){return this._normal}set normal(t){this._normal.copy(t).normalize()}get properties(){return this.getBaseProperties()}getBaseProperties(){return{type:this.type,groups:[this.getGeneralProperties(),this.getDimensionProperties()]}}transformBy(t){const e=this._textPosition.clone(),s=this._textPosition.clone().add(new b(Math.cos(this._textRotation),Math.sin(this._textRotation),0));this._dimBlockPosition.applyMatrix4(t),this._textPosition.applyMatrix4(t),this._normal.transformDirection(t),e.applyMatrix4(t),s.applyMatrix4(t);const n=new b(s).sub(e);return n.lengthSq()>0&&(this._textRotation=Math.atan2(n.y,n.x)),this.subTransformBy(t),this}subGetOsnapPoints(t,e,s,n,r){const a=this.getDimBlockTableRecord();if(!a)return;const o=this.getFullDimBlockTransform(),l=new w(e).applyMatrix4(o.clone().invert()),c=new w(s).applyMatrix4(o.clone().invert()),u=(d,g)=>{const p=[];d.subGetOsnapPoints(t,l,c,p,g,o),d instanceof Ge?p.forEach(m=>n.push(m.clone())):p.forEach(m=>n.push(new w(m).applyMatrix4(o)))};if(r){const d=a.getIdAt(r);if(d&&(u(d,r),n.length>0))return}for(const d of a.newIterator())u(d)}subWorldDraw(t){const e=this.getDimBlockTableRecord();if(e){const n=this.computeDimBlockTransform();return ss.instance.draw(t,e,this.rgbColor,[],!1,n,this._normal)}return t.group([])}getDimBlockGeometricExtents(){const t=new C,e=this.getDimBlockTableRecord();if(!e)return t;for(const s of e.newIterator())t.union(s.geometricExtents);return t.applyMatrix4(this.getFullDimBlockTransform()),t}getDimBlockTableRecord(){return this.dimBlockId?this.database.tables.blockTable.getAt(this.dimBlockId):void 0}getDimensionProperties(){return{groupName:"dimension",properties:[this.createProperty("dimensionStyleName","string",()=>this.dimensionStyleName??"",t=>{this.dimensionStyleName=t.trim()===""?null:t}),this.createProperty("dimensionText","string",()=>this.dimensionText??"",t=>{this.dimensionText=t}),this.createProperty("measurement","float",()=>this.getMeasurementPropertyValue()),this.createProperty("dimBlockId","string",()=>this.dimBlockId??""),...this.createPoint3dProperties("dimBlockPosition",()=>this.dimBlockPosition),...this.createPoint3dProperties("textPosition",()=>this.textPosition),this.createProperty("textRotation","float",()=>this.textRotation,t=>{this.textRotation=t}),this.createProperty("textLineSpacingFactor","float",()=>this.textLineSpacingFactor,t=>{this.textLineSpacingFactor=t}),this.createProperty("textLineSpacingStyle","enum",()=>this.textLineSpacingStyle,t=>{this.textLineSpacingStyle=t},[{label:Wi[1],value:1},{label:Wi[2],value:2}]),...this.createPoint3dProperties("normal",()=>this.normal)]}}createProperty(t,e,s,n,r){return{name:t,type:e,editable:n!=null,options:r,accessor:n?{get:s,set:n}:{get:s}}}createPoint3dProperties(t,e){return[this.createProperty(`${t}X`,"float",()=>e().x,s=>{e().x=s}),this.createProperty(`${t}Y`,"float",()=>e().y,s=>{e().y=s}),this.createProperty(`${t}Z`,"float",()=>e().z,s=>{e().z=s})]}getMeasurementPropertyValue(){return this.measurement}getFullDimBlockTransform(){const t=this.computeDimBlockTransform();if(this._normal.x===0&&this._normal.y===0&&this._normal.z===1)return t;const e=new G().setFromExtrusionDirection(this._normal);return new G().multiplyMatrices(e,t)}get arrowScaleFactor(){return this.dimensionStyle.dimasz}get firstArrowStyle(){return{type:this.firstArrowType,scale:this.arrowScaleFactor,appended:this.isAppendArrow,visible:this.dimensionStyle.dimse1==0}}get secondArrowStyle(){return{type:this.secondArrowType,scale:this.arrowScaleFactor,appended:this.isAppendArrow,visible:this.dimensionStyle.dimse2==0}}get isAppendArrow(){return!0}get firstArrowTypeBtrId(){const t=this.dimensionStyle;return t.dimsah==0?t.dimblk:t.dimblk1}get firstArrowType(){const t=this.firstArrowTypeBtrId;return this.getArrowName(t)}get secondArrowTypeBtrId(){const t=this.dimensionStyle;return t.dimsah==0?t.dimblk:t.dimblk2}get secondArrowType(){const t=this.secondArrowTypeBtrId;return this.getArrowName(t)}get arrowLineCount(){return 1}getLineArrowStyle(t){}findPointOnLine1(t,e,s){const n=new w().subVectors(e,t).normalize();return new w(e).addScaledVector(n,s)}findPointOnLine2(t,e,s){const n=t.x+s*Math.cos(e),r=t.y+s*Math.sin(e);return{x:n,y:r}}adjustExtensionLine(t){const e=this.dimensionStyle;t.extend(e.dimexe),t.extend(-e.dimexo,!0)}getArrowName(t){const e=this.database.tables.blockTable.getIdAt(t);return e?e.name.toUpperCase():tr.Closed}computeDimBlockTransform(){const t=this.dimBlockId?this.database.tables.blockTable.getAt(this.dimBlockId):void 0,e=(t==null?void 0:t.origin)??w.ORIGIN,s=new G().makeTranslation(-e.x,-e.y,-e.z),n=new G().makeTranslation(this._dimBlockPosition.x,this._dimBlockPosition.y,this._dimBlockPosition.z);return new G().multiplyMatrices(n,s)}subTransformBy(t){}dxfOutFields(t){super.dxfOutFields(t);const e=this.dimensionStyleName!=null?this.database.tables.dimStyleTable.getAt(this.dimensionStyleName):void 0;return t.writeSubclassMarker("AcDbDimension"),t.writeInt16(280,0),t.writeString(2,this.dimBlockId??void 0),t.writeString(3,this.dimensionStyleName??this.dimensionStyle.name),t.writePoint3d(10,this.dimBlockPosition),t.writeString(1,this.dimensionText??""),t.writeAngle(53,this.textRotation),t.writePoint3d(11,this.textPosition),t.writeInt16(70,0),t.writeInt16(72,this.textLineSpacingStyle),t.writeDouble(41,this.textLineSpacingFactor),t.writeDouble(42,this.measurement),t.writeVector3d(210,this.normal),t.writeObjectId(340,e==null?void 0:e.objectId),this}};jr.typeName="Dimension";let oe=jr;const Wr=class Wr extends oe{constructor(t,e,s,n,r=null,a=null){super(),this._centerPoint=new w().copy(t),this._xLine1Point=new w().copy(e),this._xLine2Point=new w().copy(s),this._arcPoint=new w().copy(n),this.dimensionText=r,this.dimensionStyleName=a}get arcPoint(){return this._arcPoint}set arcPoint(t){this._arcPoint.copy(t)}get centerPoint(){return this._centerPoint}set centerPoint(t){this._centerPoint.copy(t)}get xLine1Point(){return this._xLine1Point}set xLine1Point(t){this._xLine1Point.copy(t)}get xLine2Point(){return this._xLine2Point}set xLine2Point(t){this._xLine2Point.copy(t)}get properties(){const t=this.getBaseProperties();return{type:this.type,groups:[...t.groups,{groupName:"geometry",properties:[...this.createPoint3dProperties("centerPoint",()=>this.centerPoint),...this.createPoint3dProperties("xLine1Point",()=>this.xLine1Point),...this.createPoint3dProperties("xLine2Point",()=>this.xLine2Point),...this.createPoint3dProperties("arcPoint",()=>this.arcPoint)]}]}}subTransformBy(t){this._arcPoint.applyMatrix4(t),this._centerPoint.applyMatrix4(t),this._xLine1Point.applyMatrix4(t),this._xLine2Point.applyMatrix4(t)}get geometricExtents(){return new C}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDb3PointAngularDimension"),t.writePoint3d(13,this.xLine1Point),t.writePoint3d(14,this.xLine2Point),t.writePoint3d(15,this.centerPoint),t.writePoint3d(16,this.arcPoint),this}};Wr.typeName="3PointAngularDimension";let Gi=Wr;const Gr=class Gr extends oe{constructor(t,e,s,n=null,r=null){super(),this._dimLinePoint=new w().copy(s),this._xLine1Point=new w().copy(t),this._xLine2Point=new w().copy(e),this._oblique=0,this._rotation=0,this.calculateRotation(),n?this.dimensionText=n:this.dimensionText=this._xLine1Point.distanceTo(this._xLine2Point).toFixed(3),this.dimensionStyleName=r}get dimLinePoint(){return this._dimLinePoint}set dimLinePoint(t){this._dimLinePoint.copy(t)}get xLine1Point(){return this._xLine1Point}set xLine1Point(t){this._xLine1Point.copy(t)}get xLine2Point(){return this._xLine2Point}set xLine2Point(t){this._xLine2Point.copy(t)}get rotation(){return this._rotation}set rotation(t){this._rotation=t}get oblique(){return this._oblique}set oblique(t){this._oblique=t}get properties(){const t=this.getBaseProperties();return{type:this.type,groups:[...t.groups,{groupName:"geometry",properties:[...this.createPoint3dProperties("xLine1Point",()=>this.xLine1Point),...this.createPoint3dProperties("xLine2Point",()=>this.xLine2Point),...this.createPoint3dProperties("dimLinePoint",()=>this.dimLinePoint),this.createProperty("rotation","float",()=>this.rotation,e=>{this.rotation=e}),this.createProperty("oblique","float",()=>this.oblique,e=>{this.oblique=e})]}]}}subTransformBy(t){this._dimLinePoint.applyMatrix4(t),this._xLine1Point.applyMatrix4(t),this._xLine2Point.applyMatrix4(t),this.calculateRotation()}get geometricExtents(){return this.getDimBlockGeometricExtents()}get isAppendArrow(){return!1}createDimBlock(t){const e=new K;e.name=t;const s=this.createLines();s.forEach(o=>e.appendEntity(new zs(o.startPoint,o.endPoint))),this.createArrows(s[0]).forEach(o=>e.appendEntity(o));const r=s[0].midPoint,a=this.createMText(r,this._rotation);return a&&e.appendEntity(a),e}createMText(t,e){const s=n=>({x:Math.cos(n),y:Math.sin(n),z:0});if(this.dimensionText){const n=new Vs;return n.attachmentPoint=ot.MiddleLeft,n.layer="0",n.color=new Q(E.ByBlock),n.location=t,n.contents=this.dimensionText??"",n.height=10,n.direction=s(e),n.styleName=this.dimensionStyle.dimtxsty,n}}createArrows(t){const e=[];return e.push(this.createArrow(t.startPoint,this.rotation+Math.PI,10)),e.push(this.createArrow(t.endPoint,this.rotation,10)),e}createArrow(t,e,s){const n="_CAXARROW",r=new Ge(n);return r.position=t,r.rotation=e,r.scaleFactors={x:s,y:s,z:s},r}createLines(){const t=[],e=this.createExtensionLine(this._xLine1Point),s=this.createExtensionLine(this._xLine2Point),n=this.findIntersectionPoint(e,this._dimLinePoint),r=this.findIntersectionPoint(s,this._dimLinePoint),a=new _e(n,r);return t.push(a),e.endPoint=n,this.adjustExtensionLine(e),t.push(e),s.endPoint=r,this.adjustExtensionLine(s),t.push(s),t}createExtensionLine(t){const e=this.rotation+Math.PI/2,s=this.findPointOnLine2(t,e,100);return new _e(t,{...s,z:t.z})}findIntersectionPoint(t,e){const s=t.startPoint,n=t.endPoint,r=new b().subVectors(n,s).normalize(),o=new b().subVectors(e,s).dot(r),l=new b().copy(r).multiplyScalar(o);return new b().addVectors(s,l)}calculateRotation(){const t=this._xLine1Point,e=this._xLine2Point,s=e.x-t.x,n=e.y-t.y;this._rotation=Math.atan2(n,s)}get dxfSubclassMarker(){return"AcDbAlignedDimension"}getMeasurementPropertyValue(){return this.measurement??this.xLine1Point.distanceTo(this.xLine2Point)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker(this.dxfSubclassMarker),t.writePoint3d(13,this.xLine1Point),t.writePoint3d(14,this.xLine2Point),t.writePoint3d(15,this.dimLinePoint),t.writeAngle(50,this.rotation),t.writeAngle(52,this.oblique),this}};Gr.typeName="AlignedDimension";let Ws=Gr;const Hr=class Hr extends oe{constructor(t,e,s,n,r=null,a=null){super(),this._arcPoint=new w().copy(n),this._xLine1Point=new w().copy(e),this._xLine2Point=new w().copy(s),this._centerPoint=new w().copy(t),this.dimensionText=r,this.dimensionStyleName=a}get arcPoint(){return this._arcPoint}set arcPoint(t){this._arcPoint.copy(t)}get centerPoint(){return this._centerPoint}set centerPoint(t){this._centerPoint.copy(t)}get xLine1Point(){return this._xLine1Point}set xLine1Point(t){this._xLine1Point.copy(t)}get xLine2Point(){return this._xLine2Point}set xLine2Point(t){this._xLine2Point.copy(t)}get properties(){const t=this.getBaseProperties();return{type:this.type,groups:[...t.groups,{groupName:"geometry",properties:[...this.createPoint3dProperties("centerPoint",()=>this.centerPoint),...this.createPoint3dProperties("xLine1Point",()=>this.xLine1Point),...this.createPoint3dProperties("xLine2Point",()=>this.xLine2Point),...this.createPoint3dProperties("arcPoint",()=>this.arcPoint)]}]}}subTransformBy(t){this._arcPoint.applyMatrix4(t),this._centerPoint.applyMatrix4(t),this._xLine1Point.applyMatrix4(t),this._xLine2Point.applyMatrix4(t)}get geometricExtents(){return new C}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbArcDimension"),t.writePoint3d(13,this.xLine1Point),t.writePoint3d(14,this.xLine2Point),t.writePoint3d(15,this.centerPoint),t.writePoint3d(16,this.arcPoint),this}};Hr.typeName="ArcDimension";let Cn=Hr;const Ur=class Ur extends oe{constructor(t,e,s=0,n=null,r=null){super(),this._chordPoint=new w().copy(t),this._farChordPoint=new w().copy(e),this._extArcStartAngle=0,this._extArcEndAngle=0,this._leaderLength=s,this.dimensionText=n,this.dimensionStyleName=r}get chordPoint(){return this._chordPoint}set chordPoint(t){this._chordPoint.copy(t)}get farChordPoint(){return this._farChordPoint}set farChordPoint(t){this._farChordPoint.copy(t)}get extArcStartAngle(){return this._extArcStartAngle}set extArcStartAngle(t){this._extArcStartAngle=t}get extArcEndAngle(){return this._extArcEndAngle}set extArcEndAngle(t){this._extArcEndAngle=t}get leaderLength(){return this._leaderLength}set leaderLength(t){this._leaderLength=t}get properties(){const t=this.getBaseProperties();return{type:this.type,groups:[...t.groups,{groupName:"geometry",properties:[...this.createPoint3dProperties("chordPoint",()=>this.chordPoint),...this.createPoint3dProperties("farChordPoint",()=>this.farChordPoint),this.createProperty("leaderLength","float",()=>this.leaderLength,e=>{this.leaderLength=e}),this.createProperty("extArcStartAngle","float",()=>this.extArcStartAngle,e=>{this.extArcStartAngle=e}),this.createProperty("extArcEndAngle","float",()=>this.extArcEndAngle,e=>{this.extArcEndAngle=e})]}]}}subTransformBy(t){this._chordPoint.applyMatrix4(t),this._farChordPoint.applyMatrix4(t)}getMeasurementPropertyValue(){return this.measurement??this.chordPoint.distanceTo(this.farChordPoint)}get geometricExtents(){return new C}drawLines(t,e){const s=[],n=e.length;return n==1?s.push(this.drawLine(t,e[0],{firstArrow:this.firstArrowStyle})):n==3?(this.sortLines(e),s.push(this.drawLine(t,e[0],{firstArrow:this.firstArrowStyle})),s.push(this.drawLine(t,e[1])),s.push(this.drawLine(t,e[2],{firstArrow:this.firstArrowStyle}))):e.forEach(r=>{s.push(this.drawLine(t,r))}),s}drawLine(t,e,s){if(s){const n=[e.startPoint,e.endPoint];return t.lines(n)}else return e.worldDraw(t)}sortLines(t){const e=(s,n)=>s.x!==n.x?s.x-n.x:s.y!==n.y?s.y-n.y:s.z-n.z;t.sort((s,n)=>{const r=e(s.startPoint,n.startPoint);return r!==0?r:e(s.endPoint,n.endPoint)})}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbDiametricDimension"),t.writePoint3d(15,this.chordPoint),t.writePoint3d(16,this.farChordPoint),t.writeDouble(40,this.leaderLength),t.writeAngle(52,this.extArcStartAngle),t.writeAngle(53,this.extArcEndAngle),this}};Ur.typeName="DiametricDimension";let Hi=Ur;const Xr=class Xr extends oe{constructor(t,e,s=null,n=null){super(),this._definingPoint=new w().copy(t),this._leaderEndPoint=new w().copy(e),this.dimensionText=s,this.dimensionStyleName=n}get definingPoint(){return this._definingPoint}set definingPoint(t){this._definingPoint.copy(t)}get leaderEndPoint(){return this._leaderEndPoint}set leaderEndPoint(t){this._leaderEndPoint.copy(t)}get properties(){const t=this.getBaseProperties();return{type:this.type,groups:[...t.groups,{groupName:"geometry",properties:[...this.createPoint3dProperties("definingPoint",()=>this.definingPoint),...this.createPoint3dProperties("leaderEndPoint",()=>this.leaderEndPoint)]}]}}subTransformBy(t){this._definingPoint.applyMatrix4(t),this._leaderEndPoint.applyMatrix4(t)}get geometricExtents(){return new C}get arrowLineCount(){return 0}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbOrdinateDimension"),t.writePoint3d(13,this.definingPoint),t.writePoint3d(14,this.leaderEndPoint),this}};Xr.typeName="OrdinateDimension";let Ui=Xr;const Yr=class Yr extends oe{constructor(t,e,s,n=null,r=null){super(),this._center=new w().copy(t),this._chordPoint=new w().copy(e),this._leaderLength=s,this._extArcStartAngle=0,this._extArcEndAngle=0,this.dimensionText=n,this.dimensionStyleName=r}get center(){return this._center}set center(t){this._center.copy(t)}get chordPoint(){return this._chordPoint}set chordPoint(t){this._chordPoint.copy(t)}get extArcStartAngle(){return this._extArcStartAngle}set extArcStartAngle(t){this._extArcStartAngle=t}get extArcEndAngle(){return this._extArcEndAngle}set extArcEndAngle(t){this._extArcEndAngle=t}get leaderLength(){return this._leaderLength}set leaderLength(t){this._leaderLength=t}set leaderLenght(t){this._leaderLength=t}get properties(){const t=this.getBaseProperties();return{type:this.type,groups:[...t.groups,{groupName:"geometry",properties:[...this.createPoint3dProperties("center",()=>this.center),...this.createPoint3dProperties("chordPoint",()=>this.chordPoint),this.createProperty("leaderLength","float",()=>this.leaderLength,e=>{this.leaderLength=e}),this.createProperty("extArcStartAngle","float",()=>this.extArcStartAngle,e=>{this.extArcStartAngle=e}),this.createProperty("extArcEndAngle","float",()=>this.extArcEndAngle,e=>{this.extArcEndAngle=e})]}]}}subTransformBy(t){this._center.applyMatrix4(t),this._chordPoint.applyMatrix4(t)}getMeasurementPropertyValue(){return this.measurement??this.center.distanceTo(this.chordPoint)}get geometricExtents(){return new C}getLineArrowStyle(t){return{secondArrow:this.secondArrowStyle}}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbRadialDimension"),t.writePoint3d(15,this.center),t.writePoint3d(13,this.chordPoint),t.writeDouble(40,this.leaderLength),t.writeAngle(52,this.extArcStartAngle),t.writeAngle(53,this.extArcEndAngle),this}};Yr.typeName="RadialDimension";let Xi=Yr;const $r=class $r extends Ws{get dxfSubclassMarker(){return"AcDbRotatedDimension"}};$r.typeName="RotatedDimension";let Yi=$r;var Co=(i=>(i[i.kInches=0]="kInches",i[i.kMillimeters=1]="kMillimeters",i[i.kPixels=2]="kPixels",i))(Co||{}),Bo=(i=>(i[i.k0degrees=0]="k0degrees",i[i.k90degrees=1]="k90degrees",i[i.k180degrees=2]="k180degrees",i[i.k270degrees=3]="k270degrees",i))(Bo||{}),Fo=(i=>(i[i.kDisplay=0]="kDisplay",i[i.kExtents=1]="kExtents",i[i.kLimits=2]="kLimits",i[i.kView=3]="kView",i[i.kWindow=4]="kWindow",i[i.kLayout=5]="kLayout",i))(Fo||{}),pe=(i=>(i[i.kDraft=0]="kDraft",i[i.kPreview=1]="kPreview",i[i.kNormal=2]="kNormal",i[i.kPresentation=3]="kPresentation",i[i.kMaximum=4]="kMaximum",i[i.kCustom=5]="kCustom",i))(pe||{}),qe=(i=>(i[i.kAsDisplayed=0]="kAsDisplayed",i[i.kWireframe=1]="kWireframe",i[i.kHidden=2]="kHidden",i[i.kRendered=3]="kRendered",i[i.kVisualStyle=4]="kVisualStyle",i[i.kRenderPreset=5]="kRenderPreset",i))(qe||{}),Ro=(i=>(i[i.kScaleToFit=0]="kScaleToFit",i[i.k1_128in_1ft=1]="k1_128in_1ft",i[i.k1_64in_1ft=2]="k1_64in_1ft",i[i.k1_32in_1ft=3]="k1_32in_1ft",i[i.k1_16in_1ft=4]="k1_16in_1ft",i[i.k3_32in_1ft=5]="k3_32in_1ft",i[i.k1_8in_1ft=6]="k1_8in_1ft",i[i.k3_16in_1ft=7]="k3_16in_1ft",i[i.k1_4in_1ft=8]="k1_4in_1ft",i[i.k3_8in_1ft=9]="k3_8in_1ft",i[i.k1_2in_1ft=10]="k1_2in_1ft",i[i.k3_4in_1ft=11]="k3_4in_1ft",i[i.k1in_1ft=12]="k1in_1ft",i[i.k3in_1ft=13]="k3in_1ft",i[i.k6in_1ft=14]="k6in_1ft",i[i.k1ft_1ft=15]="k1ft_1ft",i[i.k1_1=16]="k1_1",i[i.k1_2=17]="k1_2",i[i.k1_4=18]="k1_4",i[i.k1_5=19]="k1_5",i[i.k1_8=20]="k1_8",i[i.k1_10=21]="k1_10",i[i.k1_16=22]="k1_16",i[i.k1_20=23]="k1_20",i[i.k1_30=24]="k1_30",i[i.k1_40=25]="k1_40",i[i.k1_50=26]="k1_50",i[i.k1_100=27]="k1_100",i[i.k2_1=28]="k2_1",i[i.k4_1=29]="k4_1",i[i.k8_1=30]="k8_1",i[i.k10_1=31]="k10_1",i[i.k100_1=32]="k100_1",i[i.k1000_1=33]="k1000_1",i[i.k1and1_2in_1ft=34]="k1and1_2in_1ft",i))(Ro||{});const cc={0:0,1:1/1536,2:1/768,3:1/384,4:1/192,5:1/128,6:1/96,7:1/64,8:1/48,9:1/32,10:1/24,11:1/16,12:1/12,13:1/4,14:1/2,15:1,16:1,17:1/2,18:1/4,19:1/5,20:1/8,21:1/10,22:1/16,23:1/20,24:1/30,25:1/40,26:1/50,27:1/100,28:2,29:4,30:8,31:10,32:100,33:1e3,34:1/8};class zo extends he{constructor(t=!1){super(),this._plotSettingsName="",this._plotCfgName="",this._canonicalMediaName="",this._currentStyleSheet="",this._plotOrigin=new k,this._customPrintScale={numerator:1,denominator:1},this._plotPaperSize=new k,this._plotPaperMargins={left:0,right:0,top:0,bottom:0},this._plotViewName="",this._plotWindowArea=new pt,this._modelType=t,this._plotCentered=!1,this._plotHidden=!1,this._plotPaperUnits=1,this._plotPlotStyles=!0,this._plotRotation=0,this._plotType=5,this._plotViewportBorders=!1,this._printLineweights=!0,this._scaleLineweights=!1,this._drawViewportsFirst=!1,this._showPlotStyles=!0,this._shadePlotType=0,this._shadePlotResLevel=2,this._shadePlotCustomDpi=300,this._shadePlotId=void 0,this._stdScaleType=0,this._useStandardScale=!0}get plotSettingsName(){return this._plotSettingsName}set plotSettingsName(t){this._plotSettingsName=t}getPlotSettingsName(){return this._plotSettingsName}setPlotSettingsName(t){this._plotSettingsName=t}get plotCfgName(){return this._plotCfgName}set plotCfgName(t){this._plotCfgName=t}getPlotCfgName(){return this._plotCfgName}get canonicalMediaName(){return this._canonicalMediaName}set canonicalMediaName(t){this._canonicalMediaName=t}getCanonicalMediaName(){return this._canonicalMediaName}get currentStyleSheet(){return this._currentStyleSheet}set currentStyleSheet(t){this._currentStyleSheet=t}getCurrentStyleSheet(){return this._currentStyleSheet}get plotOrigin(){return this._plotOrigin}set plotOrigin(t){this._plotOrigin=t}getPlotOrigin(){return this._plotOrigin}get customPrintScale(){return this._customPrintScale}set customPrintScale(t){this._customPrintScale=t}getCustomPrintScale(){return this._customPrintScale}get plotPaperSize(){return this._plotPaperSize}set plotPaperSize(t){this._plotPaperSize=t}getPlotPaperSize(){return this._plotPaperSize}get plotPaperMargins(){return this._plotPaperMargins}set plotPaperMargins(t){this._plotPaperMargins=t}getPlotPaperMargins(){return this._plotPaperMargins}get plotViewName(){return this._plotViewName}set plotViewName(t){this._plotViewName=t}getPlotViewName(){return this._plotViewName}get plotWindowArea(){return this._plotWindowArea}set plotWindowArea(t){this._plotWindowArea=t}getPlotWindowArea(){return this._plotWindowArea}get modelType(){return this._modelType}set modelType(t){this._modelType=t}getModelType(){return this._modelType}setModelType(t){this._modelType=t}get drawViewportsFirst(){return this._drawViewportsFirst}set drawViewportsFirst(t){this._drawViewportsFirst=t}setDrawViewportsFirst(t){this._drawViewportsFirst=t}get plotCentered(){return this._plotCentered}set plotCentered(t){this._plotCentered=t}setPlotCentered(t){this._plotCentered=t}get plotHidden(){return this._plotHidden}set plotHidden(t){this._plotHidden=t}setPlotHidden(t){this._plotHidden=t}get plotPaperUnits(){return this._plotPaperUnits}set plotPaperUnits(t){this._plotPaperUnits=t}get plotPlotStyles(){return this._plotPlotStyles}set plotPlotStyles(t){this._plotPlotStyles=t}setPlotPlotStyles(t){this._plotPlotStyles=t}get plotRotation(){return this._plotRotation}set plotRotation(t){this._plotRotation=t}get plotType(){return this._plotType}set plotType(t){this._plotType=t}get plotViewportBorders(){return this._plotViewportBorders}set plotViewportBorders(t){this._plotViewportBorders=t}setPlotViewportBorders(t){this._plotViewportBorders=t}get printLineweights(){return this._printLineweights}set printLineweights(t){this._printLineweights=t}setPrintLineweights(t){this._printLineweights=t}get scaleLineweights(){return this._scaleLineweights}set scaleLineweights(t){this._scaleLineweights=t}setScaleLineweights(t){this._scaleLineweights=t}get showPlotStyles(){return this._showPlotStyles}set showPlotStyles(t){this._showPlotStyles=t}setShowPlotStyles(t){this._showPlotStyles=t}get shadePlot(){return this._shadePlotType}set shadePlot(t){this._shadePlotType=t}setShadePlot(t){this._shadePlotType=t}get shadePlotResLevel(){return this._shadePlotResLevel}set shadePlotResLevel(t){this._shadePlotResLevel=t}setShadePlotResLevel(t){this._shadePlotResLevel=t}get shadePlotCustomDPI(){return this._shadePlotCustomDpi}set shadePlotCustomDPI(t){this._shadePlotCustomDpi=t}setShadePlotCustomDPI(t){this._shadePlotCustomDpi=t}get shadePlotId(){return this._shadePlotId}set shadePlotId(t){this._shadePlotId=t}get plotWireframe(){return this._shadePlotType===1}get plotAsRaster(){return this._shadePlotType===3||this._shadePlotType===4||this._shadePlotType===5}get stdScaleType(){return this._stdScaleType}set stdScaleType(t){this._stdScaleType=t}get stdScale(){return cc[this._stdScaleType]??1}get useStandardScale(){return this._useStandardScale}set useStandardScale(t){this._useStandardScale=t}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbPlotSettings"),t.writeString(1,this.plotSettingsName),t.writeString(2,this.plotCfgName),t.writeString(4,this.canonicalMediaName),t.writeString(6,this.plotViewName),t.writeDouble(40,this.plotPaperMargins.left),t.writeDouble(41,this.plotPaperMargins.bottom),t.writeDouble(42,this.plotPaperMargins.right),t.writeDouble(43,this.plotPaperMargins.top),t.writeDouble(44,this.plotPaperSize.x),t.writeDouble(45,this.plotPaperSize.y),t.writeDouble(46,this.plotOrigin.x),t.writeDouble(47,this.plotOrigin.y),t.writeDouble(48,this.plotWindowArea.min.x),t.writeDouble(49,this.plotWindowArea.min.y),t.writeDouble(140,this.plotWindowArea.max.x),t.writeDouble(141,this.plotWindowArea.max.y),t.writeDouble(142,this.customPrintScale.numerator),t.writeDouble(143,this.customPrintScale.denominator);let e=0;return this.plotViewportBorders&&(e|=1),this.showPlotStyles&&(e|=2),this.plotCentered&&(e|=4),this.plotHidden&&(e|=8),this.useStandardScale&&(e|=16),this.plotPlotStyles&&(e|=32),this.scaleLineweights&&(e|=64),this.printLineweights&&(e|=128),this.drawViewportsFirst&&(e|=512),this.modelType&&(e|=1024),t.writeInt16(70,e),t.writeInt16(72,this.plotPaperUnits),t.writeInt16(73,this.plotRotation),t.writeInt16(74,this.plotType),t.writeString(7,this.currentStyleSheet),t.writeInt16(75,this.stdScaleType),t.writeInt16(76,this.shadePlot),t.writeInt16(77,this.shadePlotResLevel),t.writeInt16(78,this.shadePlotCustomDPI),t.writeDouble(147,this.stdScale),t.writeObjectId(333,this.shadePlotId),this}}class qs extends zo{constructor(){super(),this._tabOrder=-1,this._tabSelected=!1,this._blockTableRecordId="",this._layoutName="",this._limits=new pt,this._extents=new C,this._viewportArray=[]}get layoutName(){return this._layoutName}set layoutName(t){this._layoutName=t.length>256?t.slice(0,256):t}get tabOrder(){return this._tabOrder}set tabOrder(t){this._tabOrder=t}get tabSelected(){return this._tabSelected}set tabSelected(t){this._tabSelected=t}get blockTableRecordId(){return this._blockTableRecordId}set blockTableRecordId(t){this._blockTableRecordId=t}get limits(){return this._limits}set limits(t){this._limits.copy(t)}get extents(){return this._extents}set extents(t){this._extents.copy(t)}get viewportArray(){return this._viewportArray}set viewportArray(t){this._viewportArray=t.slice()}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbLayout"),t.writeString(1,this.layoutName),t.writeInt16(70,this.tabSelected?1:0),t.writeInt16(71,this.tabOrder),t.writeObjectId(330,this.blockTableRecordId),t.writeObjectId(331,this._viewportArray.length>0?this._viewportArray[0]:"0"),t.writePoint2d(10,this.limits.min),t.writePoint2d(11,this.limits.max),t.writePoint3d(14,this.extents.min),t.writePoint3d(15,this.extents.max),this}}class Zs{constructor(t){this.i=0,this._records=t,this._keys=Array.from(t.keys())}get count(){return this._records.size}toArray(){return Array.from(this._records.values())}[Symbol.iterator](){return this}next(){for(;this.i<this._keys.length;){const t=this._records.get(this._keys[this.i]);return this.i+=1,{value:t,done:!1}}return{value:null,done:!0}}}class ks extends he{constructor(t){super(),this.database=t,this.objectId=t.generateHandle(),this._recordsByName=new Map,this._recordsById=new Map}get numEntries(){return this._recordsByName.size}setAt(t,e){e.database=this.database,e.ownerId=this.objectId,this.database.commitObjectHandle(e,s=>this.hasId(s)),this._recordsByName.set(t,e),this._recordsById.set(e.objectId,e),this.database.events.dictObjetSet.dispatch({database:this.database,object:e,key:t})}remove(t){const e=this.getAt(t);return e?(this._recordsByName.delete(t.toUpperCase()),this._recordsById.delete(this.objectId),this.database.events.dictObjectErased.dispatch({database:this.database,object:e,key:t}),!0):!1}removeId(t){const e=this.getIdAt(t);return e?(this._recordsById.delete(this.objectId),this._recordsByName.forEach((s,n)=>{s===e&&(this._recordsByName.delete(n),this.database.events.dictObjectErased.dispatch({database:this.database,object:e,key:n}))}),!0):!1}removeAll(){this._recordsByName.forEach((t,e)=>{this.database.events.dictObjectErased.dispatch({database:this.database,object:t,key:e})}),this._recordsByName.clear(),this._recordsById.clear()}has(t){return this._recordsByName.has(t.toUpperCase())}hasId(t){return this._recordsById.has(t)}getAt(t){return this._recordsByName.get(t)}getIdAt(t){return this._recordsById.get(t)}newIterator(){return new Zs(this._recordsByName)}entries(){return this._recordsByName.entries()}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbDictionary"),t.writeInt16(280,1),t.writeInt16(281,1);for(const[e,s]of this._recordsByName)t.writeString(3,e),t.writeObjectId(350,s.objectId);return this}}class Vo extends ks{getBtrIdAt(t){for(const[e,s]of this._recordsByName)if(s.blockTableRecordId==t)return s}get maxTabOrder(){let t=-1;return this._recordsByName.forEach(e=>{e.tabOrder>t&&(t=e.tabOrder)}),t}}class xe extends he{constructor(t,e){t=t||{},Hs(t,{name:""}),super(t,e)}get name(){return this.getAttr("name")}set name(t){this.setAttr("name",t)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbSymbolTableRecord"),this}}var Do=(i=>(i[i.Any=0]="Any",i[i.Uniform=1]="Uniform",i))(Do||{});const ge=class ge extends xe{static isModelSapceName(t){return t.toLowerCase()==ge.MODEL_SPACE_NAME.toLowerCase()}static isPaperSapceName(t){return t.toLowerCase().startsWith(ge.PAPER_SPACE_NAME_PREFIX.toLowerCase())}constructor(){super(),this._origin=new w,this._layoutId="",this._entities=new Map,this._blockInsertUnits=0,this._explodability=1,this._blockScaling=1,this._bmpPreview=void 0}get isModelSapce(){return ge.isModelSapceName(this.name)}get isPaperSapce(){return ge.isPaperSapceName(this.name)}get origin(){return this._origin}set origin(t){this._origin.copy(t)}get layoutId(){return this._layoutId}set layoutId(t){this._layoutId=t}get blockInsertUnits(){return this._blockInsertUnits}set blockInsertUnits(t){this._blockInsertUnits=t}get explodability(){return this._explodability}set explodability(t){this._explodability=t}get blockScaling(){return this._blockScaling}set blockScaling(t){this._blockScaling=t}get bmpPreview(){return this._bmpPreview}set bmpPreview(t){this._bmpPreview=t}appendEntity(t){const e=s=>{s.database=this.database,s.ownerId=this.objectId,this.database.commitObjectHandle(s,n=>this._entities.has(n)),s.resolveEffectiveProperties(),this._entities.set(s.objectId,s)};if(Array.isArray(t))for(let s=0;s<t.length;++s)e(t[s]);else e(t);(this.isModelSapce||this.isPaperSapce)&&this.database.events.entityAppended.dispatch({database:this.database,entity:t})}removeEntity(t){const e=Array.isArray(t)?t:[t],s=[];return e.forEach(n=>{const r=this._entities.get(n);r&&s.push(r),this._entities.delete(n)}),s.length>0&&this.database.events.entityErased.dispatch({database:this.database,entity:s}),s.length>0}newIterator(){return new Zs(this._entities)}getIdAt(t){return this._entities.get(t)}dxfOutBlockRecord(t){return t.writeStart("BLOCK_RECORD"),this.dxfOut(t),this}dxfOutBlockBegin(t){return t.writeStart("BLOCK"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeString(8,"0"),t.writeSubclassMarker("AcDbBlockBegin"),t.writeString(2,this.name),t.writeInt16(70,0),t.writePoint3d(10,this.origin),t.writeString(3,this.name),this}dxfOutBlockEnd(t){return t.writeStart("ENDBLK"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeSubclassMarker("AcDbBlockEnd"),this}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbBlockTableRecord"),t.writeString(2,this.name),t.writeInt16(70,this.blockInsertUnits),t.writeInt16(280,this.explodability),t.writeInt16(281,this.blockScaling),(this.isModelSapce||this.isPaperSapce)&&t.writeObjectId(340,this.layoutId),this}};ge.MODEL_SPACE_NAME="*Model_Space",ge.PAPER_SPACE_NAME_PREFIX="*Paper_Space";let K=ge;class jo{constructor(){this.events={layoutCreated:new Z,layoutRemoved:new Z,layoutRenamed:new Z,layoutSwitched:new Z}}countLayouts(t){return this.getWorkingDatabase(t).objects.layout.numEntries}findLayoutNamed(t,e){return this.getWorkingDatabase(e).objects.layout.getAt(t)}findActiveLayout(){const t=this.getActiveLayout();return t?t.layoutName:"Model"}setCurrentLayoutId(t,e){const s=this.getWorkingDatabase(e),n=s.objects.layout.getIdAt(t);return this.setCurrentLayoutInternal(n,s)}setCurrentLayoutBtrId(t,e){const s=this.getWorkingDatabase(e),n=s.objects.layout.getBtrIdAt(t);return this.setCurrentLayoutInternal(n,s)}setCurrentLayout(t,e){const s=this.getWorkingDatabase(e),n=s.objects.layout.getAt(t);return this.setCurrentLayoutInternal(n,s)}renameLayout(t,e,s){const r=this.getWorkingDatabase(s).objects.layout.getAt(t);return r?(r.layoutName=e,this.events.layoutRenamed.dispatch({layout:r,oldName:t,newName:e}),!0):!1}layoutExists(t,e){return this.getWorkingDatabase(e).objects.layout.has(t)}deleteLayout(t,e){const s=this.getWorkingDatabase(e).objects.layout,n=s.getAt(t);let r=!1;return n&&(r=s.remove(t),r&&this.events.layoutRemoved.dispatch({layout:n})),r}createLayout(t,e){const s=this.getWorkingDatabase(e),n=new qs;n.layoutName=t,n.tabOrder=s.objects.layout.maxTabOrder;const r=new K;return r.name=`*Paper_Space${n.tabOrder}`,s.tables.blockTable.add(r),s.objects.layout.setAt(t,n),this.events.layoutCreated.dispatch({layout:n}),{layout:n,btr:r}}getActiveLayout(t){const e=this.getWorkingDatabase(t);return e.objects.layout.getBtrIdAt(e.currentSpaceId)}getWorkingDatabase(t){return t||zn().workingDatabase}setCurrentLayoutInternal(t,e){return t?(this.events.layoutSwitched.dispatch({layout:t}),e.currentSpaceId=t.blockTableRecordId,!0):!1}}Ca(()=>new jo);class Wo extends he{constructor(){super(),this._sourceFileName=""}get sourceFileName(){return this._sourceFileName}set sourceFileName(t){this._sourceFileName=t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbRasterImageDef"),t.writeString(1,this.sourceFileName),t.writeInt16(280,1),t.writeInt16(281,0),this}}var Go=(i=>(i[i.NotApplicable=0]="NotApplicable",i[i.Ignore=1]="Ignore",i[i.Replace=2]="Replace",i[i.XrefMangleName=3]="XrefMangleName",i[i.MangleName=4]="MangleName",i))(Go||{});class dc extends he{constructor(){super(...arguments),this._data=null}get data(){return this._data}set data(t){this._data=t}clear(){var t;(t=this._data)==null||t.clear()}clone(){return super.clone()}getDuplicateRecordCloning(){return 0}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbXrecord"),t.writeInt16(280,1),t.writeResultBuffer(this.data),this}}class Ho{constructor(t){this.db=t}createDefaultLayer(){const t=new Q;return t.colorIndex=7,this.db.tables.layerTable.add(new tn({name:"0",standardFlags:0,linetype:"Continuous",lineWeight:0,isOff:!1,color:t,isPlottable:!0}))}createDefaultLineType(){this.db.tables.linetypeTable.add(new me({name:"ByBlock",standardFlag:0,description:"",totalPatternLength:0})),this.db.tables.linetypeTable.add(new me({name:"ByLayer",standardFlag:0,description:"",totalPatternLength:0})),this.db.tables.linetypeTable.add(new me({name:"Continuous",standardFlag:0,description:"Solid line",totalPatternLength:0}))}createDefaultTextStyle(){this.db.tables.textStyleTable.add(new en({name:tt,standardFlag:0,fixedTextHeight:0,widthFactor:1,obliqueAngle:0,textGenerationFlag:0,lastHeight:.2,font:"SimKai",bigFont:"",extendedFont:"SimKai"}))}createDefaultDimStyle(){this.db.tables.dimStyleTable.add(new He({name:tt,dimtxsty:tt}))}createDefaultLayout(){const t=new qs;t.layoutName="Model",t.tabOrder=0,t.blockTableRecordId=this.db.tables.blockTable.modelSpace.objectId,t.limits.min.copy({x:0,y:0}),t.limits.max.copy({x:1e6,y:1e6}),t.extents.min.copy({x:0,y:0,z:0}),t.extents.max.copy({x:1e6,y:1e6,z:0}),this.db.objects.layout.setAt(t.layoutName,t),this.db.tables.blockTable.modelSpace.layoutId=t.objectId}createArrowBlock(){if(!this.db.tables.blockTable.getAt("_CAXARROW")){const e=new Rs;e.patternName="SOLID";const s=new Fs;s.add(new Vt({x:0,y:0},{x:-1,y:.125})),s.add(new Vt({x:-1,y:.125},{x:-1,y:-.125})),s.add(new Vt({x:-1,y:-.125},{x:0,y:0})),e.add(s);const n=new K;n.name="_CAXARROW",n.appendEntity(e),this.db.tables.blockTable.add(n)}}}var Uo=(i=>(i.ClosedFilled="",i.Dot="_DOT",i.DotSmall="_DOTSMALL",i.DotBlank="_DOTBLANK",i.Origin="_ORIGIN",i.Origin2="_ORIGIN2",i.Open="_OPEN",i.Open90="_OPEN90",i.Open30="_OPEN30",i.Closed="_CLOSED",i.Small="_SMALL",i.None="_NONE",i.Oblique="_OBLIQUE",i.BoxFilled="_BOXFILLED",i.Box="_BOXBLANK",i.ClosedBlank="_CLOSEDBLANK",i.DatumBlank="_DATUMBLANK",i.DatumFilled="_DATUMFILLED",i.Integral="_INTEGRAL",i.ArchTick="_ARCHTICK",i))(Uo||{}),rr=(i=>(i[i.Undefined=0]="Undefined",i[i.Inches=1]="Inches",i[i.Feet=2]="Feet",i[i.Miles=3]="Miles",i[i.Millimeters=4]="Millimeters",i[i.Centimeters=5]="Centimeters",i[i.Meters=6]="Meters",i[i.Kilometers=7]="Kilometers",i[i.Microinches=8]="Microinches",i[i.Mils=9]="Mils",i[i.Yards=10]="Yards",i[i.Angstroms=11]="Angstroms",i[i.Nanometers=12]="Nanometers",i[i.Microns=13]="Microns",i[i.Decimeters=14]="Decimeters",i[i.Dekameters=15]="Dekameters",i[i.Hectometers=16]="Hectometers",i[i.Gigameters=17]="Gigameters",i[i.Astronomical=18]="Astronomical",i[i.LightYears=19]="LightYears",i[i.Parsecs=20]="Parsecs",i[i.USSurveyFeet=21]="USSurveyFeet",i[i.USSurveyInch=22]="USSurveyInch",i[i.USSurveyYard=23]="USSurveyYard",i[i.USSurveyMile=24]="USSurveyMile",i[i.Max=24]="Max",i))(rr||{});function uc(i){return i==4||i==5||i==6||i==7||i==12||i==13||i==14||i==15||i==16||i==17}function pc(i){return i==1||i==2||i==3||i==8||i==9||i==10||i==21}class le extends he{constructor(t){super(),this.database=t,this.objectId=t.generateHandle(),this.ownerId=t.objectId,this._recordsByName=new Map,this._recordsById=new Map}get numEntries(){return this._recordsByName.size}add(t){t.database=this.database,t.ownerId=this.objectId,this.database.commitObjectHandle(t,s=>this.hasId(s));const e=this.normalizeName(t.name);this._recordsByName.set(e,t),this._recordsById.set(t.objectId,t)}remove(t){const e=this.normalizeName(t),s=this._recordsByName.get(e);return s?(this._recordsById.delete(s.objectId),this._recordsByName.delete(e),!0):!1}removeId(t){const e=this._recordsById.get(t);return e?(this._recordsByName.delete(this.normalizeName(e.name)),this._recordsById.delete(t),!0):!1}removeAll(){this._recordsByName.clear(),this._recordsById.clear()}has(t){const e=this.normalizeName(t);return this._recordsByName.has(e)}hasId(t){return this._recordsById.has(t)}getAt(t){const e=this.normalizeName(t);return this._recordsByName.get(e)}getIdAt(t){return this._recordsById.get(t)}getOwnerIdAt(t){return this._recordsById.get(t)}newIterator(){return new Zs(this._recordsByName)}normalizeName(t){return t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbSymbolTable"),t.writeInt16(70,this.numEntries),this}}class Xo extends le{constructor(t){super(t)}get modelSpace(){let t=this.getAt(K.MODEL_SPACE_NAME);return t||(t=new K,t.name=K.MODEL_SPACE_NAME,this.add(t)),t}getEntityById(t){for(const e of this.database.tables.blockTable.newIterator()){const s=e.getIdAt(t);if(s)return s}}removeEntity(t){let e=!1;for(const s of this.database.tables.blockTable.newIterator())if(s.removeEntity(t)){e=!0;break}return e}normalizeName(t){let e=t;if(K.isModelSapceName(t))e=K.MODEL_SPACE_NAME;else if(K.isPaperSapceName(t)){const s=K.PAPER_SPACE_NAME_PREFIX,n=t.substring(s.length);e=s+n}return e}}class Yo extends le{constructor(t){super(t)}}var $o=(i=>(i[i.Center=0]="Center",i[i.Left=1]="Left",i[i.Right=2]="Right",i[i.OverFirst=3]="OverFirst",i[i.OverSecond=4]="OverSecond",i))($o||{}),qo=(i=>(i[i.Center=0]="Center",i[i.Above=1]="Above",i[i.Outside=2]="Outside",i[i.JIS=3]="JIS",i[i.Below=4]="Below",i))(qo||{}),Zo=(i=>(i[i.Feet=0]="Feet",i[i.None=1]="None",i[i.Inch=2]="Inch",i[i.FeetAndInch=3]="FeetAndInch",i[i.Leading=4]="Leading",i[i.Trailing=8]="Trailing",i[i.LeadingAndTrailing=12]="LeadingAndTrailing",i))(Zo||{}),Ko=(i=>(i[i.None=0]="None",i[i.Leading=1]="Leading",i[i.Trailing=2]="Trailing",i[i.LeadingAndTrailing=3]="LeadingAndTrailing",i))(Ko||{}),Qo=(i=>(i[i.Bottom=0]="Bottom",i[i.Middle=1]="Middle",i[i.Top=2]="Top",i))(Qo||{});const Zi=class Zi extends xe{constructor(t,e){t=t||{},Hs(t,Zi.DEFAULT_DIM_VALUES),super(t,e)}get dimpost(){return this.getAttr("dimpost")}set dimpost(t){this.setAttr("dimpost",t)}get dimapost(){return this.getAttr("dimapost")}set dimapost(t){this.setAttr("dimapost",t)}get dimscale(){return this.getAttr("dimscale")}set dimscale(t){this.setAttr("dimscale",t)}get dimasz(){return this.getAttr("dimasz")}set dimasz(t){this.setAttr("dimasz",t)}get dimexo(){return this.getAttr("dimexo")}set dimexo(t){this.setAttr("dimexo",t)}get dimdli(){return this.getAttr("dimdli")}set dimdli(t){this.setAttr("dimdli",t)}get dimexe(){return this.getAttr("dimexe")}set dimexe(t){this.setAttr("dimexe",t)}get dimrnd(){return this.getAttr("dimrnd")}set dimrnd(t){this.setAttr("dimrnd",t)}get dimdle(){return this.getAttr("dimdle")}set dimdle(t){this.setAttr("dimdle",t)}get dimtp(){return this.getAttr("dimtp")}set dimtp(t){this.setAttr("dimtp",t)}get dimtm(){return this.getAttr("dimtm")}set dimtm(t){this.setAttr("dimtm",t)}get dimtxt(){return this.getAttr("dimtxt")}set dimtxt(t){this.setAttr("dimtxt",t)}get dimcen(){return this.getAttr("dimcen")}set dimcen(t){this.setAttr("dimcen",t)}get dimtsz(){return this.getAttr("dimtsz")}set dimtsz(t){this.setAttr("dimtsz",t)}get dimaltf(){return this.getAttr("dimaltf")}set dimaltf(t){this.setAttr("dimaltf",t)}get dimlfac(){return this.getAttr("dimlfac")}set dimlfac(t){this.setAttr("dimlfac",t)}get dimtvp(){return this.getAttr("dimtvp")}set dimtvp(t){this.setAttr("dimtvp",t)}get dimtfac(){return this.getAttr("dimtfac")}set dimtfac(t){this.setAttr("dimtfac",t)}get dimgap(){return this.getAttr("dimgap")}set dimgap(t){this.setAttr("dimgap",t)}get dimaltrnd(){return this.getAttr("dimaltrnd")}set dimaltrnd(t){this.setAttr("dimaltrnd",t)}get dimtol(){return this.getAttr("dimtol")}set dimtol(t){this.setAttr("dimtol",t)}get dimlim(){return this.getAttr("dimlim")}set dimlim(t){this.setAttr("dimlim",t)}get dimtih(){return this.getAttr("dimtih")}set dimtih(t){this.setAttr("dimtih",t)}get dimtoh(){return this.getAttr("dimtoh")}set dimtoh(t){this.setAttr("dimtoh",t)}get dimse1(){return this.getAttr("dimse1")}set dimse1(t){this.setAttr("dimse1",t)}get dimse2(){return this.getAttr("dimse2")}set dimse2(t){this.setAttr("dimse2",t)}get dimtad(){return this.getAttr("dimtad")}set dimtad(t){this.setAttr("dimtad",t)}get dimzin(){return this.getAttr("dimzin")}set dimzin(t){this.setAttr("dimzin",t)}get dimazin(){return this.getAttr("dimazin")}set dimazin(t){this.setAttr("dimazin",t)}get dimalt(){return this.getAttr("dimalt")}set dimalt(t){this.setAttr("dimalt",t)}get dimaltd(){return this.getAttr("dimaltd")}set dimaltd(t){this.setAttr("dimaltd",t)}get dimtofl(){return this.getAttr("dimtofl")}set dimtofl(t){this.setAttr("dimtofl",t)}get dimsah(){return this.getAttr("dimsah")}set dimsah(t){this.setAttr("dimsah",t)}get dimtix(){return this.getAttr("dimtix")}set dimtix(t){this.setAttr("dimtix",t)}get dimsoxd(){return this.getAttr("dimsoxd")}set dimsoxd(t){this.setAttr("dimsoxd",t)}get dimclrd(){return this.getAttr("dimclrd")}set dimclrd(t){this.setAttr("dimclrd",t)}get dimclre(){return this.getAttr("dimclre")}set dimclre(t){this.setAttr("dimclre",t)}get dimclrt(){return this.getAttr("dimclrt")}set dimclrt(t){this.setAttr("dimclrt",t)}get dimadec(){return this.getAttr("dimadec")}set dimadec(t){this.setAttr("dimadec",t)}get dimunit(){return this.getAttr("dimunit")}set dimunit(t){this.setAttr("dimunit",t)}get dimdec(){return this.getAttr("dimdec")}set dimdec(t){this.setAttr("dimdec",t)}get dimtdec(){return this.getAttr("dimtdec")}set dimtdec(t){this.setAttr("dimtdec",t)}get dimaltu(){return this.getAttr("dimaltu")}set dimaltu(t){this.setAttr("dimaltu",t)}get dimalttd(){return this.getAttr("dimalttd")}set dimalttd(t){this.setAttr("dimalttd",t)}get dimaunit(){return this.getAttr("dimaunit")}set dimaunit(t){this.setAttr("dimaunit",t)}get dimfrac(){return this.getAttr("dimfrac")}set dimfrac(t){this.setAttr("dimfrac",t)}get dimlunit(){return this.getAttr("dimlunit")}set dimlunit(t){this.setAttr("dimlunit",t)}get dimdsep(){return this.getAttr("dimdsep")}set dimdsep(t){this.setAttr("dimdsep",t)}get dimtmove(){return this.getAttr("dimtmove")}set dimtmove(t){this.setAttr("dimtmove",t)}get dimjust(){return this.getAttr("dimjust")}set dimjust(t){this.setAttr("dimjust",t)}get dimsd1(){return this.getAttr("dimsd1")}set dimsd1(t){this.setAttr("dimsd1",t)}get dimsd2(){return this.getAttr("dimsd2")}set dimsd2(t){this.setAttr("dimsd2",t)}get dimtolj(){return this.getAttr("dimtolj")}set dimtolj(t){this.setAttr("dimtolj",t)}get dimtzin(){return this.getAttr("dimtzin")}set dimtzin(t){this.setAttr("dimtzin",t)}get dimaltz(){return this.getAttr("dimaltz")}set dimaltz(t){this.setAttr("dimaltz",t)}get dimalttz(){return this.getAttr("dimalttz")}set dimalttz(t){this.setAttr("dimalttz",t)}get dimfit(){return this.getAttr("dimfit")}set dimfit(t){this.setAttr("dimfit",t)}get dimupt(){return this.getAttr("dimupt")}set dimupt(t){this.setAttr("dimupt",t)}get dimatfit(){return this.getAttr("dimatfit")}set dimatfit(t){this.setAttr("dimatfit",t)}get dimtxsty(){return this.getAttr("dimtxsty")}set dimtxsty(t){this.setAttr("dimtxsty",t)}get dimldrblk(){return this.getAttr("dimldrblk")}set dimldrblk(t){this.setAttr("dimldrblk",t)}get dimblk(){return this.getAttr("dimblk")}set dimblk(t){this.setAttr("dimblk",t)}get dimblk1(){return this.getAttr("dimblk1")}set dimblk1(t){this.setAttr("dimblk1",t)}get dimblk2(){return this.getAttr("dimblk2")}set dimblk2(t){this.setAttr("dimblk2",t)}get dimlwd(){return this.getAttr("dimlwd")}set dimlwd(t){this.setAttr("dimlwd",t)}get dimlwe(){return this.getAttr("dimlwe")}set dimlwe(t){this.setAttr("dimlwe",t)}dxfOutFields(t){super.dxfOutFields(t);const e=this.database.tables.textStyleTable.getAt(this.dimtxsty),s=this.database.tables.blockTable.getAt(this.dimldrblk),n=this.database.tables.blockTable.getAt(this.dimblk),r=this.database.tables.blockTable.getAt(this.dimblk1),a=this.database.tables.blockTable.getAt(this.dimblk2);return t.writeSubclassMarker("AcDbDimStyleTableRecord"),t.writeString(2,this.name),t.writeInt16(70,0),t.writeString(3,this.dimpost),t.writeString(4,this.dimapost),t.writeDouble(40,this.dimscale),t.writeDouble(41,this.dimasz),t.writeDouble(42,this.dimexo),t.writeDouble(43,this.dimdli),t.writeDouble(44,this.dimexe),t.writeDouble(140,this.dimtxt),t.writeDouble(147,this.dimgap),t.writeInt16(170,this.dimalt),t.writeInt16(171,this.dimtol),t.writeInt16(172,this.dimlim),t.writeInt16(173,this.dimtih),t.writeInt16(174,this.dimtoh),t.writeObjectId(340,e==null?void 0:e.objectId),t.writeObjectId(341,s==null?void 0:s.objectId),t.writeObjectId(342,n==null?void 0:n.objectId),t.writeObjectId(343,r==null?void 0:r.objectId),t.writeObjectId(344,a==null?void 0:a.objectId),t.writeInt16(371,this.dimlwd),t.writeInt16(372,this.dimlwe),this}};Zi.DEFAULT_DIM_VALUES={name:"",dimpost:"",dimapost:"",dimscale:1,dimasz:2.5,dimexo:.625,dimdli:.38,dimexe:.18,dimrnd:0,dimdle:0,dimtp:0,dimtm:0,dimtxt:2.5,dimcen:2.5,dimtsz:0,dimaltf:0,dimlfac:1,dimtvp:0,dimtfac:1,dimgap:1,dimaltrnd:0,dimtol:0,dimlim:0,dimtih:0,dimtoh:0,dimse1:0,dimse2:0,dimtad:0,dimzin:0,dimazin:0,dimalt:0,dimaltd:2,dimtofl:0,dimsah:0,dimtix:0,dimsoxd:0,dimclrd:0,dimclre:0,dimclrt:0,dimadec:0,dimunit:2,dimdec:4,dimtdec:4,dimaltu:2,dimalttd:2,dimaunit:0,dimfrac:0,dimlunit:2,dimdsep:".",dimtmove:0,dimjust:0,dimsd1:0,dimsd2:0,dimtolj:0,dimtzin:0,dimaltz:0,dimalttz:0,dimfit:0,dimupt:0,dimatfit:3,dimtxsty:tt,dimldrblk:"",dimblk:"",dimblk1:"",dimblk2:"",dimlwd:-2,dimlwe:-2};let He=Zi;class Jo extends le{constructor(t){super(t)}add(t){super.add(t),this.database.events.layerAppended.dispatch({database:this.database,layer:t})}}class tn extends xe{constructor(t,e){t=t||{},Hs(t,{color:new Q,description:"",standardFlags:0,isHidden:!1,isInUse:!0,isOff:!1,isPlottable:!0,transparency:new Qi,linetype:"",lineWeight:1,materialId:-1}),super(t,e),this.attrs.events.attrChanged.addEventListener(s=>{this.database.events.layerModified.dispatch({database:this.database,layer:this,changes:s.object.changedAttributes()})})}get color(){return this.getAttr("color")}set color(t){this.setAttr("color",t.clone())}get description(){return this.getAttr("description")}set description(t){this.setAttr("description",t)}get standardFlags(){return this.getAttr("standardFlags")}set standardFlags(t){this.setAttr("standardFlags",t)}get isFrozen(){return(this.standardFlags&1)==1}set isFrozen(t){const e=t?1:0;this.standardFlags=this.standardFlags|e}get isHidden(){return this.getAttr("isHidden")}set isHidden(t){this.setAttr("isHidden",t)}get isInUse(){return this.getAttr("isInUse")}set isInUse(t){this.setAttr("isInUse",t)}get isLocked(){return(this.standardFlags&4)==4}set isLocked(t){const e=t?4:0;this.standardFlags=this.standardFlags|e}get isOff(){return this.getAttr("isOff")}set isOff(t){this.setAttr("isOff",t)}get isPlottable(){return this.getAttr("isPlottable")}set isPlottable(t){this.setAttr("isPlottable",t)}get transparency(){return this.getAttr("transparency")}set transparency(t){this.setAttr("transparency",t.clone())}get linetype(){return this.getAttr("linetype")}set linetype(t){this.setAttr("linetype",t)}get lineStyle(){var e;const t=(e=this.database)==null?void 0:e.tables.linetypeTable.getAt(this.linetype);if(t)return{type:"UserSpecified",...t.linetype}}get lineWeight(){return this.getAttr("lineWeight")}set lineWeight(t){this.setAttr("lineWeight",t)}get materialId(){return this.getAttr("materialId")}set materialId(t){this.setAttr("materialId",t)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbLayerTableRecord"),t.writeString(2,this.name),t.writeInt16(70,this.standardFlags),t.writeCmColor(this.color),t.writeString(6,this.linetype),t.writeInt16(290,this.isPlottable?1:0),t.writeInt16(370,this.lineWeight),t.writeTransparency(this.transparency),this.description&&t.writeString(4,this.description),this}}class th extends le{constructor(t){super(t)}}class me extends xe{constructor(t){super(),this.name=t.name,this._linetype=t}get numDashes(){return this._linetype.pattern?this._linetype.pattern.length:0}get patternLength(){return this._linetype.totalPatternLength}get comments(){return this._linetype.description}get linetype(){return this._linetype}dashLengthAt(t){if(t<0||t>=this.numDashes)throw new Error('Index must be greater than or equal to zero, but less than the value of property "numDashes".');return this._linetype.pattern[t].elementLength}toPreviewSvgString(t){const e=Math.max((t==null?void 0:t.width)??220,1),s=Math.max((t==null?void 0:t.height)??36,1),n=Math.min(Math.max((t==null?void 0:t.padding)??8,0),Math.floor(e/2)),r=Math.max((t==null?void 0:t.strokeWidth)??2,.5),a=this.escapeSvgAttribute((t==null?void 0:t.stroke)??"currentColor"),o=Math.max((t==null?void 0:t.repeats)??4,1),l=s/2,c=n,u=Math.max(e-n,c+1),d=u-c,g=this._linetype.pattern??[];if(g.length===0||this.patternLength<=0||!g.some(I=>I.elementLength!==0))return this.buildSvgString({width:e,height:s,stroke:a,strokeWidth:r,lineSegments:[[c,u]],dots:[],y:l});const p=[],m=[],y=d/(this.patternLength*o),x=.5,f=Math.max(r*2,2);let P=c;for(;P<u;)for(const I of g){if(P>=u)break;const M=I.elementLength;if(M===0){m.push(P),P=Math.min(P+f,u);continue}const A=Math.max(Math.abs(M)*y,x),j=Math.min(P+A,u);M>0&&j>P&&p.push([P,j]),P=j}return this.buildSvgString({width:e,height:s,stroke:a,strokeWidth:r,lineSegments:p,dots:m,y:l})}buildSvgString(t){const{width:e,height:s,stroke:n,strokeWidth:r,lineSegments:a,dots:o,y:l}=t,c=a.map(([d,g])=>`<line x1="${d.toFixed(2)}" y1="${l.toFixed(2)}" x2="${g.toFixed(2)}" y2="${l.toFixed(2)}" stroke="${n}" stroke-width="${r.toFixed(2)}" stroke-linecap="round" />`).join(""),u=o.map(d=>`<circle cx="${d.toFixed(2)}" cy="${l.toFixed(2)}" r="${(r/2).toFixed(2)}" fill="${n}" />`).join("");return`<svg xmlns="http://www.w3.org/2000/svg" width="${e}" height="${s}" viewBox="0 0 ${e} ${s}" role="img" aria-label="${this.escapeSvgAttribute(this.name)} linetype preview">${c}${u}</svg>`}escapeSvgAttribute(t){return t.replace(/&/g,"&amp;").replace(/"/g,"&quot;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/'/g,"&#39;")}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbLinetypeTableRecord"),t.writeString(2,this.name),t.writeInt16(70,this.linetype.standardFlag),t.writeString(3,this.comments),t.writeInt16(72,65),t.writeInt16(73,this.numDashes),t.writeDouble(40,this.patternLength);for(const e of this.linetype.pattern??[])t.writeDouble(49,e.elementLength),t.writeInt16(74,e.elementTypeFlag);return this}}class eh extends le{constructor(t){super(t)}get fonts(){const t=new Set,e=n=>{if(n){const r=n.lastIndexOf(".");if(r>=0){const a=n.substring(0,r).toLowerCase();t.add(a)}else t.add(n.toLowerCase())}},s=this.newIterator();for(const n of s)e(n.fileName),e(n.bigFontFileName);return Array.from(t)}}class en extends xe{constructor(t){super(),this.name=t.name,this._textStyle=t,this._textStyle.font=this.getFileNameWithoutExtension(this._textStyle.font||this._textStyle.extendedFont||this.name),this._isVertical=!1}get obliquingAngle(){return this._textStyle.obliqueAngle}set obliquingAngle(t){this._textStyle.obliqueAngle=t}get priorSize(){return this._textStyle.lastHeight}set priorSize(t){this._textStyle.lastHeight=t}get textSize(){return this._textStyle.fixedTextHeight}set textSize(t){this._textStyle.fixedTextHeight=t}get xScale(){return this._textStyle.widthFactor}set xScale(t){this._textStyle.widthFactor=t}get isVertical(){return this._isVertical}set isVertical(t){this._isVertical=t}get fileName(){return this._textStyle.font}set fileName(t){this._textStyle.font=t}get bigFontFileName(){return this._textStyle.bigFont}set bigFontFileName(t){this._textStyle.bigFont=t}get textStyle(){return this._textStyle}getFileNameWithoutExtension(t){const e=t.split("/").pop();if(e){const s=e.lastIndexOf(".");return s===-1?e:e.substring(0,s)}return t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbTextStyleTableRecord"),t.writeString(2,this.name),t.writeInt16(70,this.textStyle.standardFlag),t.writeDouble(40,this.textSize),t.writeDouble(41,this.xScale),t.writeAngle(50,this.obliquingAngle),t.writeInt16(71,this.isVertical?4:this.textStyle.textGenerationFlag),t.writeDouble(42,this.priorSize),t.writeString(3,this.fileName),t.writeString(4,this.bigFontFileName),this}}class sh extends le{constructor(t){super(t)}}class ih extends le{constructor(t){super(t)}}const gc=()=>({center:new k,viewDirectionFromTarget:new w(0,0,1),viewTarget:new w(0,0,0),lensLength:500,frontClippingPlane:0,backClippingPlane:0,viewHeight:1e3,viewTwistAngle:0,frozenLayers:[],styleSheet:"",renderMode:er.OPTIMIZED_2D,viewMode:0,ucsIconSetting:0,ucsOrigin:new w(0,0,0),ucsXAxis:new w(1,0,0),ucsYAxis:new w(0,1,0),orthographicType:sr.TOP,shadePlotSetting:0,shadePlotObjectId:void 0,visualStyleObjectId:void 0,isDefaultLightingOn:!1,defaultLightingType:ir.ONE_DISTANT_LIGHT,brightness:0,contrast:0,ambientColor:void 0});class ar extends xe{constructor(){super(),this._gsView=gc(),this._centerPoint=this._gsView.center}get gsView(){return this._gsView}get centerPoint(){return this._centerPoint}set centerPoint(t){this._centerPoint.copy(t)}get viewDirectionFromTarget(){return this._gsView.viewDirectionFromTarget}set viewDirectionFromTarget(t){this._gsView.viewDirectionFromTarget.copy(t)}get viewTarget(){return this._gsView.viewTarget}set viewTarget(t){this._gsView.viewTarget.copy(t)}get viewHeight(){return this._gsView.viewHeight}set viewHeight(t){this._gsView.viewHeight=t}get viewTwistAngle(){return this._gsView.viewTwistAngle}set viewTwistAngle(t){this._gsView.viewTwistAngle=t}get lensLength(){return this._gsView.lensLength}set lensLength(t){this._gsView.lensLength=t}get frontClippingPlane(){return this._gsView.frontClippingPlane}set frontClippingPlane(t){this._gsView.frontClippingPlane=t}get backClippingPlane(){return this._gsView.backClippingPlane}set backClippingPlane(t){this._gsView.backClippingPlane=t}get renderMode(){return this._gsView.renderMode}set renderMode(t){this._gsView.renderMode=t}get viewMode(){return this._gsView.viewMode}set viewMode(t){this._gsView.viewMode=t}get ucsIconSetting(){return this._gsView.ucsIconSetting}set ucsIconSetting(t){this._gsView.ucsIconSetting=t}get ucsOrigin(){return this._gsView.ucsOrigin}set ucsOrigin(t){this._gsView.ucsOrigin.copy(t)}get ucsXAxis(){return this._gsView.ucsXAxis}set ucsXAxis(t){this._gsView.ucsXAxis.copy(t)}get ucsYAxis(){return this._gsView.ucsYAxis}set ucsYAxis(t){this._gsView.ucsYAxis.copy(t)}get orthographicType(){return this._gsView.orthographicType}set orthographicType(t){this._gsView.orthographicType=t}get shadePlotSetting(){return this._gsView.shadePlotSetting}set shadePlotSetting(t){this._gsView.shadePlotSetting=t}get shadePlotObjectId(){return this._gsView.shadePlotObjectId}set shadePlotObjectId(t){this._gsView.shadePlotObjectId=t}get visualStyleObjectId(){return this._gsView.visualStyleObjectId}set visualStyleObjectId(t){this._gsView.visualStyleObjectId=t}get isDefaultLightingOn(){return this._gsView.isDefaultLightingOn}set isDefaultLightingOn(t){this._gsView.isDefaultLightingOn=t}get defaultLightingType(){return this._gsView.defaultLightingType}set defaultLightingType(t){this._gsView.defaultLightingType=t}get brightness(){return this._gsView.brightness}set brightness(t){this._gsView.brightness=t}get contrast(){return this._gsView.contrast}set contrast(t){this._gsView.contrast=t}get ambientColor(){return this._gsView.ambientColor}set ambientColor(t){this._gsView.ambientColor=t}}class or extends ar{constructor(){super(),this._circleSides=100,this._lowerLeftCorner=new k(0,0),this._upperRightCorner=new k(1,1),this._snapBase=new k(0,0),this._snapAngle=0,this._snapSpacing=new k(0,0),this._standardFlag=0,this._gridSpacing=new k,this._gridMajor=10}get circleSides(){return this._circleSides}set circleSides(t){this._circleSides=t}get center(){return this.centerPoint}set center(t){this.centerPoint=t}get lowerLeftCorner(){return this._lowerLeftCorner}set lowerLeftCorner(t){this._lowerLeftCorner.copy(t)}get upperRightCorner(){return this._upperRightCorner}set upperRightCorner(t){this._upperRightCorner.copy(t)}get snapBase(){return this._snapBase}set snapBase(t){this._snapBase.copy(t)}get snapAngle(){return this._snapAngle}set snapAngle(t){this._snapAngle=t}get snapIncrements(){return this._snapSpacing}set snapIncrements(t){this._snapSpacing.copy(t)}get gridMajor(){return this._gridMajor}set gridMajor(t){this._gridMajor=t}get gridIncrements(){return this._gridSpacing}set gridIncrements(t){this._gridSpacing.copy(t)}get standardFlag(){return this._standardFlag}set standardFlag(t){this._standardFlag=t}get snapEnabled(){return!!(this._standardFlag&256)}get backgroundObjectId(){return this._backgroundObjectId}set backgroundObjectId(t){this._backgroundObjectId=t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbViewportTableRecord"),t.writeString(2,this.name),t.writeDouble(45,this.gsView.viewHeight),t.writePoint2d(10,this.lowerLeftCorner),t.writePoint2d(11,this.upperRightCorner),t.writePoint2d(12,this.center),t.writePoint2d(13,this.snapBase),t.writePoint2d(14,this.snapIncrements),t.writePoint2d(15,this.gridIncrements),t.writeInt16(70,this.standardFlag),t.writeInt16(71,this.circleSides),t.writeDouble(42,this.gsView.lensLength),t.writePoint3d(16,this.gsView.viewDirectionFromTarget),t.writePoint3d(17,this.gsView.viewTarget),t.writeAngle(50,this.snapAngle),t.writeAngle(51,this.gsView.viewTwistAngle),t.writeInt16(61,this.gridMajor),t.writeInt16(281,this.backgroundObjectId?1:0),t.writeObjectId(332,this.backgroundObjectId),this}}class nh extends le{constructor(t){super(t)}}class Bn extends xe{constructor(t){super(),this.name=t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbRegAppTableRecord"),t.writeString(2,this.name),t.writeInt16(70,0),this}}const R={ACADVER:"ACADVER",ANGBASE:"ANGBASE",ANGDIR:"ANGDIR",AUNITS:"AUNITS",CECOLOR:"CECOLOR",CELTYPE:"CELTYPE",CELTSCALE:"CELTSCALE",CELWEIGHT:"CELWEIGHT",CLAYER:"CLAYER",COLORTHEME:"COLORTHEME",DYNMODE:"DYNMODE",DYNPROMPT:"DYNPROMPT",EXTMAX:"EXTMAX",EXTMIN:"EXTMIN",INSUNITS:"INSUNITS",LTSCALE:"LTSCALE",LWDISPLAY:"LWDISPLAY",MEASUREMENTCOLOR:"MEASUREMENTCOLOR",OSMODE:"OSMODE",PDMODE:"PDMODE",PDSIZE:"PDSIZE",PICKBOX:"PICKBOX",SHORTCUTMENU:"SHORTCUTMENU",TEXTSTYLE:"TEXTSTYLE",WHITEBKCOLOR:"WHITEBKCOLOR"},mc=Object.freeze(Object.values(R)),Ki=class Ki{constructor(){this.registry=new Map,this.cache=new Map,this.events={sysVarChanged:new Z},this.registerVar({name:R.CECOLOR,type:"color",isDbVar:!0,defaultValue:new Q(E.ByLayer)}),this.registerVar({name:R.CELTSCALE,type:"number",isDbVar:!0,defaultValue:-1}),this.registerVar({name:R.CELTYPE,type:"string",isDbVar:!0,defaultValue:At}),this.registerVar({name:R.CELWEIGHT,type:"number",isDbVar:!0,defaultValue:We.ByLayer}),this.registerVar({name:R.CLAYER,type:"string",isDbVar:!0,defaultValue:"0"}),this.registerVar({name:R.COLORTHEME,type:"number",isDbVar:!1,defaultValue:"0"}),this.registerVar({name:R.DYNMODE,type:"number",isDbVar:!1,defaultValue:3}),this.registerVar({name:R.DYNPROMPT,type:"boolean",isDbVar:!1,defaultValue:!0}),this.registerVar({name:R.LWDISPLAY,type:"boolean",isDbVar:!0,defaultValue:!1}),this.registerVar({name:R.MEASUREMENTCOLOR,type:"color",isDbVar:!1,defaultValue:(()=>{const t=new Q(E.ByColor);return t.setRGB(96,165,250),t})()}),this.registerVar({name:R.OSMODE,type:"number",isDbVar:!0,defaultValue:0}),this.registerVar({name:R.PICKBOX,type:"number",isDbVar:!1,defaultValue:10}),this.registerVar({name:R.SHORTCUTMENU,type:"number",isDbVar:!1,defaultValue:0}),this.registerVar({name:R.TEXTSTYLE,type:"string",isDbVar:!0,defaultValue:tt}),this.registerVar({name:R.WHITEBKCOLOR,type:"boolean",isDbVar:!1,defaultValue:!1})}static instance(){return this._instance||(this._instance=new Ki),this._instance}registerVar(t){const e=this.normalizeName(t.name);this.registry.set(e,{...t,name:e}),t.isDbVar||this.cache.set(e,t.defaultValue)}registerMany(t){t.forEach(e=>this.registerVar(e))}getVar(t,e){t=this.normalizeName(t);const s=this.getDescriptor(t);if(!s)throw new Error(`System variable ${t} not found!`);if(s.isDbVar)return e[t.toLowerCase()];if(this.cache.has(t))return this.cache.get(t)}getDefaultValue(t){t=this.normalizeName(t);const e=this.getDescriptor(t);if(!e)throw new Error(`System variable ${t} not found!`);return e.defaultValue}setVar(t,e,s){t=this.normalizeName(t);const n=this.getDescriptor(t);if(n){const r=this.getVar(t,s);if(n.type!=="string"&&(typeof e=="string"||e instanceof String)){if(n.type==="number"){const a=Number(e);if(Number.isNaN(a))throw new Error("Invalid number input!");e=a}else if(n.type==="boolean")e=this.parseBoolean(e);else if(n.type==="color"){const a=Q.fromString(e);if(a==null)throw new Error("Invalid color value!");e=a}}n.isDbVar?s[t.toLowerCase()]=e:(this.cache.set(t,e),this.hasValueChanged(r,e)&&this.events.sysVarChanged.dispatch({database:s,name:t,newVal:e,oldVal:r}))}else throw new Error(`System variable ${t} not found!`)}getDescriptor(t){return this.registry.get(this.normalizeName(t))}getAllDescriptors(){return[...this.registry.values()]}parseBoolean(t){if(t==null)return!1;const e=String(t).trim().toLowerCase(),s=new Set(["true","t","1","yes","y"]),n=new Set(["false","f","0","no","n"]);return s.has(e)?!0:(n.has(e),!1)}hasValueChanged(t,e){return t instanceof Q&&e instanceof Q?!t.equals(e):!Object.is(t,e)}normalizeName(t){return t.toLowerCase()}};Ki._instance=null;let Gs=Ki;class yc extends he{constructor(){super({objectId:"0"}),this.events={dictObjetSet:new Z,dictObjectErased:new Z,entityAppended:new Z,entityModified:new Z,entityErased:new Z,layerAppended:new Z,layerModified:new Z,layerErased:new Z,openProgress:new Z},this._version=new vt("AC1014"),this._angBase=0,this._angDir=0,this._aunits=jn.DecimalDegrees,this._celtscale=1,this._cecolor=new Q,this._celtype=At,this._celweight=We.ByLayer,this._clayer="0",this._textstyle=tt,this._extents=new C,this._insunits=rr.Millimeters,this._ltscale=1,this._lwdisplay=!1,this._pdmode=0,this._pdsize=0,this._osmode=0,this._maxHandle=0,this._tables={appIdTable:new nh(this),blockTable:new Xo(this),dimStyleTable:new Yo(this),linetypeTable:new th(this),textStyleTable:new eh(this),viewTable:new sh(this),layerTable:new Jo(this),viewportTable:new ih(this)},this._objects={dictionary:new ks(this),imageDefinition:new ks(this),layout:new Vo(this),xrecord:new ks(this)}}get tables(){return this._tables}get objects(){return this._objects}generateHandle(){return this._maxHandle++,this._maxHandle.toString(16).toUpperCase()}updateMaxHandle(t){const e=parseInt(t,16);!isNaN(e)&&e>this._maxHandle&&(this._maxHandle=e)}commitObjectHandle(t,e){const s=t.getAttrWithoutException("objectId");!s||t.isTemp||e&&e(s)?t.objectId=this.generateHandle():this.updateMaxHandle(s)}get currentSpaceId(){return this._currentSpace||(this._currentSpace=this._tables.blockTable.modelSpace),this._currentSpace.objectId}set currentSpaceId(t){const e=this.tables.blockTable.getIdAt(t);if(e==null)throw new Error(`[AcDbDatabase] The specified block table record id '${t}' doesn't exist in the drawing database!`);this._currentSpace=e}get aunits(){return this._aunits}set aunits(t){this.updateSysVar(R.AUNITS,this._aunits,t??0,e=>{this._aunits=e})}get version(){return this._version}set version(t){this.updateSysVar(R.ACADVER,this._version,new vt(t),e=>{this._version=e})}get insunits(){return this._insunits}set insunits(t){this.updateSysVar(R.INSUNITS,this._insunits,t??4,e=>{this._insunits=e})}get ltscale(){return this._ltscale}set ltscale(t){this.updateSysVar(R.LTSCALE,this._ltscale,t??1,e=>{this._ltscale=e})}get lwdisplay(){return this._lwdisplay}set lwdisplay(t){this.updateSysVar(R.LWDISPLAY,this._lwdisplay,t??!1,e=>{this._lwdisplay=e})}get cecolor(){return this._cecolor}set cecolor(t){this.updateSysVar(R.CECOLOR,this._cecolor,t||0,e=>{this._cecolor=e.clone()})}get celtscale(){return this._celtscale}set celtscale(t){this.updateSysVar(R.CELTSCALE,this._celtscale,t??1,e=>{this._celtscale=e})}get celtype(){return this._celtype}set celtype(t){const e=this.normalizeLinetypeName(t??At);this.updateSysVar(R.CELTYPE,this._celtype,e,s=>{this._celtype=s})}get celweight(){return this._celweight}set celweight(t){this.updateSysVar(R.CELWEIGHT,this._celweight,t??We.ByLayer,e=>{this._celweight=e})}get clayer(){return this._clayer}set clayer(t){this.updateSysVar(R.CLAYER,this._clayer,t??"0",e=>{this._clayer=e})}get textstyle(){return this._textstyle}set textstyle(t){this.updateSysVar(R.TEXTSTYLE,this._textstyle,t??tt,e=>{this._textstyle=e})}get angBase(){return this._angBase}set angBase(t){this.updateSysVar(R.ANGBASE,this._angBase,t??0,e=>{this._angBase=e})}get angDir(){return this._angDir}set angDir(t){this.updateSysVar(R.ANGDIR,this._angDir,t??0,e=>{this._angDir=e})}get extmax(){return this._extents.max}set extmax(t){if(t){const e=this._extents.max.clone();this._extents.expandByPoint(t),this._extents.max.equals(e)||this.triggerSysVarChangedEvent(R.EXTMAX,e,this._extents.max)}}get extmin(){return this._extents.min}set extmin(t){if(t){const e=this._extents.min.clone();this._extents.expandByPoint(t),this._extents.min.equals(e)||this.triggerSysVarChangedEvent(R.EXTMIN,e,this._extents.min)}}get extents(){return this._extents}get pdmode(){return this._pdmode}set pdmode(t){this.updateSysVar(R.PDMODE,this._pdmode,t??0,e=>{this._pdmode=e})}get pdsize(){return this._pdsize}set pdsize(t){this.updateSysVar(R.PDSIZE,this._pdsize,t??0,e=>{this._pdsize=e})}get osmode(){return this._osmode}set osmode(t){this.updateSysVar(R.OSMODE,this._osmode,t??0,e=>{this._osmode=e})}async read(t,e,s=Es.DXF){const n=Rt.instance.get(s);if(n==null)throw new Error(`Database converter for file type '${s}' isn't registered and can can't read this file!`);this.clear(),await n.read(t,this,e&&e.minimumChunkSize||10,async(r,a,o,l)=>{if(this.events.openProgress.dispatch({database:this,percentage:r,stage:"CONVERSION",subStage:a,subStageStatus:o,data:l}),e&&e.fontLoader&&a=="FONT"&&o=="END"){const c=l||this.tables.textStyleTable.fonts;await e.fontLoader.load(c)}},e==null?void 0:e.timeout,e==null?void 0:e.sysVars),this.ensureDatabaseDefaults()}async openUri(t,e){var p;this.events.openProgress.dispatch({database:this,percentage:0,stage:"FETCH_FILE",subStageStatus:"START"});const s=await fetch(t);if(!s.ok)throw this.events.openProgress.dispatch({database:this,percentage:100,stage:"FETCH_FILE",subStageStatus:"ERROR"}),new Error(`Failed to fetch file '${t}' with HTTP status code '${s.status}'!`);const n=s.headers.get("content-length"),r=n?parseInt(n,10):null;let a=0;const o=(p=s.body)==null?void 0:p.getReader();if(!o)throw new Error("Failed to get response reader");const l=[];for(;;){const{done:m,value:y}=await o.read();if(m)break;if(l.push(y),a+=y.length,r!==null){const x=Math.round(a/r*100);this.events.openProgress.dispatch({database:this,percentage:x,stage:"FETCH_FILE",subStageStatus:"IN-PROGRESS"})}}const c=new Uint8Array(a);let u=0;for(const m of l)c.set(m,u),u+=m.length;const g=this.getFileNameFromUri(t).toLowerCase().split(".").pop();g==="dwg"?await this.read(c.buffer,e,Es.DWG):g==="dxf"?await this.read(c.buffer,e,Es.DXF):await this.read(c.buffer,e,g),this.events.openProgress.dispatch({database:this,percentage:100,stage:"FETCH_FILE",subStageStatus:"END"})}dxfOut(t,e=16,s=this.version.name,n=!1){this.ensureDatabaseDefaults();const r=s instanceof vt?s:new vt(s),a=new ba({database:this,precision:e,version:r});return this.writeDxfHeaderSection(a),this.writeDxfTablesSection(a,r),this.writeDxfBlocksSection(a),this.writeDxfEntitiesSection(a),this.writeDxfObjectsSection(a),a.writeStart("EOF"),a.toString()}async regen(){await new El(this).read(null,this,500,async(e,s,n,r)=>{this.events.openProgress.dispatch({database:this,percentage:e,stage:"CONVERSION",subStage:s,subStageStatus:n,data:r})})}createDefaultData(t={layer:!0,lineType:!0,textStyle:!0,dimStyle:!0,layout:!0}){const e=new Ho(this);t.layer&&e.createDefaultLayer(),t.lineType&&e.createDefaultLineType(),t.textStyle&&e.createDefaultTextStyle(),t.dimStyle&&e.createDefaultDimStyle(),t.layout&&e.createDefaultLayout()}ensureDatabaseDefaults(){if(!this.tables.layerTable.has("0")){const e=new Q;e.colorIndex=7,this.tables.layerTable.add(new tn({name:"0",standardFlags:0,linetype:Ke,lineWeight:0,isOff:!1,color:e,isPlottable:!0}))}if(this.tables.linetypeTable.has(Qe)||this.tables.linetypeTable.add(new me({name:Qe,standardFlag:0,description:"",totalPatternLength:0})),this.tables.linetypeTable.has(At)||this.tables.linetypeTable.add(new me({name:At,standardFlag:0,description:"",totalPatternLength:0})),this.tables.linetypeTable.has(Ke)||this.tables.linetypeTable.add(new me({name:Ke,standardFlag:0,description:"Solid line",totalPatternLength:0})),this.tables.textStyleTable.has(tt)||this.tables.textStyleTable.add(new en({name:tt,standardFlag:0,fixedTextHeight:0,widthFactor:1,obliqueAngle:0,textGenerationFlag:0,lastHeight:.2,font:"SimKai",bigFont:"",extendedFont:"SimKai"})),this.tables.dimStyleTable.has(tt)||this.tables.dimStyleTable.add(new He({name:tt,dimtxsty:tt})),!this.tables.viewportTable.has("*Active")){const e=new or;e.name="*Active",this.tables.viewportTable.add(e)}const t=this.tables.blockTable.modelSpace;if(!this.objects.layout.getAt("Model")){const e=new qs;e.layoutName="Model",e.tabOrder=0,e.blockTableRecordId=t.objectId,e.limits.min.copy({x:0,y:0}),e.limits.max.copy({x:1e6,y:1e6}),e.extents.min.copy({x:0,y:0,z:0}),e.extents.max.copy({x:1e6,y:1e6,z:0}),this.objects.layout.setAt(e.layoutName,e),t.layoutId=e.objectId}this.tables.appIdTable.has(Pn)||this.tables.appIdTable.add(new Bn(Pn)),this.tables.appIdTable.has(In)||this.tables.appIdTable.add(new Bn(In))}writeDxfHeaderSection(t){var e;t.startSection("HEADER"),t.writeString(9,"$ACADVER"),t.writeString(1,((e=t.version)==null?void 0:e.name)??this.version.name),t.writeString(9,"$HANDSEED"),t.writeString(5,t.nextHandle.toString(16).toUpperCase()),t.version!=null&&t.version.value>=27&&(t.writeString(9,"$DWGCODEPAGE"),t.writeString(3,"UTF-8")),t.writeString(9,"$INSUNITS"),t.writeInt16(70,this.insunits),t.writeString(9,"$LTSCALE"),t.writeDouble(40,this.ltscale),t.writeString(9,"$LWDISPLAY"),t.writeInt16(70,this.lwdisplay?1:0),t.writeString(9,"$CLAYER"),t.writeString(8,this.clayer),t.writeString(9,"$CELTYPE"),t.writeString(6,this.celtype),t.writeString(9,"$TEXTSTYLE"),t.writeString(7,this.textstyle),t.writeString(9,"$ANGBASE"),t.writeAngle(50,this.angBase),t.writeString(9,"$ANGDIR"),t.writeInt16(70,this.angDir),t.writeString(9,"$EXTMIN"),t.writePoint3d(10,this.extmin),t.writeString(9,"$EXTMAX"),t.writePoint3d(10,this.extmax),t.writeString(9,"$PDMODE"),t.writeInt32(70,this.pdmode),t.writeString(9,"$PDSIZE"),t.writeDouble(40,this.pdsize),t.writeString(9,"$OSMODE"),t.writeInt32(70,this.osmode),t.endSection()}writeDxfTablesSection(t,e){t.startSection("TABLES"),this.writeDxfTable(t,"VPORT",this.tables.viewportTable,this.tables.viewportTable.newIterator(),"VPORT"),this.writeDxfTable(t,"VIEW",this.tables.viewTable,this.tables.viewTable.newIterator(),"VIEW"),this.writeDxfTable(t,"LTYPE",this.tables.linetypeTable,this.tables.linetypeTable.newIterator(),"LTYPE"),this.writeDxfTable(t,"LAYER",this.tables.layerTable,this.tables.layerTable.newIterator(),"LAYER"),this.writeDxfTable(t,"STYLE",this.tables.textStyleTable,this.tables.textStyleTable.newIterator(),"STYLE"),this.writeDxfTable(t,"APPID",this.tables.appIdTable,this.tables.appIdTable.newIterator(),"APPID"),this.writeDxfTable(t,"DIMSTYLE",this.tables.dimStyleTable,this.tables.dimStyleTable.newIterator(),"DIMSTYLE"),e.value>=19&&this.writeDxfTable(t,"BLOCK_RECORD",this.tables.blockTable,this.tables.blockTable.newIterator(),"BLOCK_RECORD"),t.endSection()}writeDxfBlocksSection(t){t.startSection("BLOCKS");for(const e of this.tables.blockTable.newIterator()){if(e.dxfOutBlockBegin(t),!e.isModelSapce&&!e.isPaperSapce)for(const s of e.newIterator())this.writeDxfEntity(t,s);e.dxfOutBlockEnd(t)}t.endSection()}writeDxfEntitiesSection(t){t.startSection("ENTITIES");for(const e of this.tables.blockTable.newIterator())if(!(!e.isModelSapce&&!e.isPaperSapce))for(const s of e.newIterator())this.writeDxfEntity(t,s);t.endSection()}writeDxfObjectsSection(t){t.startSection("OBJECTS");const e=this.objects.dictionary;e.ownerId="0";const s=a=>{t.writeStart("DICTIONARY"),a.dxfOut(t)},n=(a,o)=>{e.getAt(a)!==o&&e.setAt(a,o)},r=a=>{e.getAt(a)&&e.remove(a)};n("ACAD_LAYOUT",this.objects.layout),this.objects.imageDefinition.numEntries>0?n("ISM_RASTER_IMAGE_DICT",this.objects.imageDefinition):r("ISM_RASTER_IMAGE_DICT"),this.objects.xrecord.numEntries>0?n("MLIGHT_XRECORD",this.objects.xrecord):r("MLIGHT_XRECORD"),s(e),s(this.objects.layout),this.objects.imageDefinition.numEntries>0&&s(this.objects.imageDefinition),this.objects.xrecord.numEntries>0&&s(this.objects.xrecord);for(const[a,o]of this.objects.layout.entries())t.writeStart("LAYOUT"),o.dxfOut(t);for(const[a,o]of this.objects.imageDefinition.entries())t.writeStart("IMAGEDEF"),o.dxfOut(t);for(const[a,o]of this.objects.xrecord.entries())t.writeStart("XRECORD"),o.dxfOut(t);t.endSection()}writeDxfTable(t,e,s,n,r){const a=[...n];t.startTable(e),s.dxfOut(t);for(const o of a){if(r==="BLOCK_RECORD"&&o instanceof K){o.dxfOutBlockRecord(t);continue}t.writeStart(r),o.dxfOut(t)}t.endTable()}writeDxfEntity(t,e){t.writeStart(e.dxfTypeName),e.dxfOut(t)}clear(){this._tables.blockTable.removeAll(),this._tables.dimStyleTable.removeAll(),this._tables.linetypeTable.removeAll(),this._tables.textStyleTable.removeAll(),this._tables.viewTable.removeAll(),this._tables.layerTable.removeAll(),this._tables.viewportTable.removeAll(),this._objects.layout.removeAll(),this._currentSpace=void 0,this._extents.makeEmpty()}updateSysVar(t,e,s,n){this.hasSysVarValueChanged(e,s)&&(n(s),this.triggerSysVarChangedEvent(t,e,s))}hasSysVarValueChanged(t,e){return t instanceof Q&&e instanceof Q?!t.equals(e):t instanceof vt&&e instanceof vt?t.value!==e.value:!Object.is(t,e)}normalizeLinetypeName(t){const e=t.trim();return e.toUpperCase()==="BYLAYER"?At:e.toUpperCase()==="BYBLOCK"?Qe:e}triggerSysVarChangedEvent(t,e,s){const n=Gs.instance(),r=t.toLowerCase();n.getDescriptor(r)!=null&&n.events.sysVarChanged.dispatch({database:this,name:r,oldVal:e,newVal:s})}getFileNameFromUri(t){try{const s=new URL(t).pathname.split("/");return s[s.length-1]||""}catch{return""}}}const rh="Load Database",pa=3e4,_c=12e4,wc=1024*1024;class mt extends Ma{constructor(t,e){super(t.stage),this.data=t,this.progress=e}async run(t){const e=Rn.getInstance().getEntry(rh),s=Date.now();this.progress&&await this.progress(this.data.progress.value,this.data.stage,"START");const n=await this.data.task(t);return this.progress&&(await this.progress(this.data.progress.value,this.data.stage,"END",n?n.data:null),this.data.progress.value+=this.data.step,this.data.progress.value>100&&(this.data.progress.value=100)),e&&(e.data[this.name]=Date.now()-s),n}}class hr{constructor(t={}){this.config=t}async read(t,e,s,n,r,a){const o={name:rh,data:{total:0},format(){let d="";return Object.keys(this.data).forEach(g=>{g!=="total"&&(d+=`- ${g}: ${this.data[g]} ms
4
- `)}),d+=`- total: ${this.data.total} ms`,d}};Rn.getInstance().collect(o),this.progress=n;const l={value:0},c=new va;c.setCompleteCallback(()=>this.onFinished()),c.setErrorCallback(d=>this.onError(d)),c.addTask(new mt({stage:"START",step:1,progress:l,task:async d=>d},n)),c.addTask(new mt({stage:"PARSE",step:5,progress:l,task:async d=>await this.parse(d,r)},n)),c.addTask(new mt({stage:"FONT",step:5,progress:l,task:async d=>{const g=this.getFonts(d.model);return{model:d.model,data:g}}},n)),c.addTask(new mt({stage:"LTYPE",step:1,progress:l,task:async d=>(this.processLineTypes(d.model,e),d)},n)),c.addTask(new mt({stage:"STYLE",step:1,progress:l,task:async d=>(this.processTextStyles(d.model,e),d)},n)),c.addTask(new mt({stage:"DIMSTYLE",step:1,progress:l,task:async d=>(this.processDimStyles(d.model,e),d)},n)),c.addTask(new mt({stage:"LAYER",step:1,progress:l,task:async d=>(this.processLayers(d.model,e),e.tables.layerTable.numEntries===0&&e.createDefaultData({layer:!0}),d)},n)),c.addTask(new mt({stage:"VPORT",step:1,progress:l,task:async d=>(this.processViewports(d.model,e),d)},n)),c.addTask(new mt({stage:"HEADER",step:1,progress:l,task:async d=>{if(this.processHeader(d.model,e),a){const g=Gs.instance();for(const[p,m]of Object.entries(a))g.setVar(p,m,e)}return d}},n)),c.addTask(new mt({stage:"BLOCK_RECORD",step:5,progress:l,task:async d=>(this.processBlockTables(d.model,e),d)},n)),c.addTask(new mt({stage:"OBJECT",step:5,progress:l,task:async d=>(this.processObjects(d.model,e),e.objects.layout.numEntries===0&&e.createDefaultData({layout:!0}),d)},n)),c.addTask(new mt({stage:"BLOCK",step:5,progress:l,task:async d=>(await this.processBlocks(d.model,e),d)},n)),c.addTask(new mt({stage:"ENTITY",step:100,progress:l,task:async d=>(await this.processEntities(d.model,e,s,l,n),d)},n)),c.addTask(new mt({stage:"END",step:0,progress:l,task:async d=>d},n));const u=Date.now();await c.run(t),o.data.total=Date.now()-u}onError(t){if(this.progress){const e=t.task;this.progress(e.data.progress.value,e.data.stage,"ERROR",void 0,t)}return t.task.name==="ENTITY"?!1:(this.onFinished(),!0)}onFinished(){this.progress&&(this.progress(100,"END","END"),ss.instance.clear())}getParserWorkerTimeout(t,e){const s=e??this.config.timeout;if(s!=null)return s;const n=Math.ceil(t.byteLength/wc),r=pa+n*1e3;return Math.min(_c,Math.max(pa,r))}async parse(t,e){throw new Error("Not impelemented yet!")}getFonts(t){throw new Error("Not impelemented yet!")}processLineTypes(t,e){throw new Error("Not impelemented yet!")}processTextStyles(t,e){throw new Error("Not impelemented yet!")}processDimStyles(t,e){throw new Error("Not impelemented yet!")}processLayers(t,e){throw new Error("Not impelemented yet!")}processViewports(t,e){throw new Error("Not impelemented yet!")}processHeader(t,e){throw new Error("Not impelemented yet!")}processBlockTables(t,e){throw new Error("Not impelemented yet!")}processObjects(t,e){throw new Error("Not impelemented yet!")}processBlocks(t,e){throw new Error("Not impelemented yet!")}processEntities(t,e,s,n,r){throw new Error("Not impelemented yet!")}}class xc extends ar{constructor(){super(),this._standardFlags=0,this._viewWidth=this.viewHeight,this._ucsAssociated=!1,this._cameraPlottable=!1,this._ucsElevation=0}get standardFlags(){return this._standardFlags}set standardFlags(t){this._standardFlags=t}get viewWidth(){return this._viewWidth}set viewWidth(t){this._viewWidth=t}get ucsAssociated(){return this._ucsAssociated}set ucsAssociated(t){this._ucsAssociated=t}get cameraPlottable(){return this._cameraPlottable}set cameraPlottable(t){this._cameraPlottable=t}get ucsElevation(){return this._ucsElevation}set ucsElevation(t){this._ucsElevation=t}get ucsObjectId(){return this._ucsObjectId}set ucsObjectId(t){this._ucsObjectId=t}get ucsBaseObjectId(){return this._ucsBaseObjectId}set ucsBaseObjectId(t){this._ucsBaseObjectId=t}get backgroundObjectId(){return this._backgroundObjectId}set backgroundObjectId(t){this._backgroundObjectId=t}get liveSectionObjectId(){return this._liveSectionObjectId}set liveSectionObjectId(t){this._liveSectionObjectId=t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbViewTableRecord"),t.writeString(2,this.name),t.writeInt16(70,this.standardFlags),t.writeDouble(40,this.gsView.viewHeight),t.writePoint2d(10,this.centerPoint),t.writeDouble(41,this.viewWidth),t.writePoint3d(11,this.gsView.viewDirectionFromTarget),t.writePoint3d(12,this.gsView.viewTarget),t.writeDouble(42,this.gsView.lensLength),t.writeDouble(43,this.gsView.frontClippingPlane),t.writeDouble(44,this.gsView.backClippingPlane),t.writeAngle(50,this.gsView.viewTwistAngle),t.writeInt16(71,this.gsView.viewMode),t.writeInt16(281,this.gsView.renderMode),t.writeInt16(72,this.ucsAssociated?1:0),t.writeInt16(73,this.cameraPlottable?1:0),t.writeObjectId(332,this.backgroundObjectId),t.writeObjectId(334,this.liveSectionObjectId),t.writeObjectId(348,this.gsView.visualStyleObjectId),this.ucsAssociated&&(t.writePoint3d(110,this.gsView.ucsOrigin),t.writePoint3d(111,this.gsView.ucsXAxis),t.writePoint3d(112,this.gsView.ucsYAxis),t.writeInt16(79,this.gsView.orthographicType),t.writeDouble(146,this.ucsElevation),t.writeObjectId(345,this.ucsObjectId),t.writeObjectId(346,this.ucsBaseObjectId)),this}}var st,ns,$,q,rs,Lt,Pe,Gt,ht,Ht,Ot,Se,Ee,Ae,wt,Ut,as,os,Te,Me,hs,ls,cs,xt,Xt,H,ve,ds,L,lt,us,ct,ps,Yt,D,gs,$t,ke,un,pn,Nt,ms,Le,ft,qt,Zt,Kt,ys,_s,Qt,Oe,Ne,gn,ws,Ce,Jt,Be,it,te,bt,mn,nt,yn,ee,It,Fe,xs,Re,Pt,se,St,ie,_n,ze,Et;(st={})[st.None=0]="None",st[st.Anonymous=1]="Anonymous",st[st.NonConstant=2]="NonConstant",st[st.Xref=4]="Xref",st[st.XrefOverlay=8]="XrefOverlay",st[st.ExternallyDependent=16]="ExternallyDependent",st[st.ResolvedOrDependent=32]="ResolvedOrDependent",st[st.ReferencedXref=64]="ReferencedXref";(ns={})[ns.BYBLOCK=0]="BYBLOCK",ns[ns.BYLAYER=256]="BYLAYER";($={})[$.Rotated=0]="Rotated",$[$.Aligned=1]="Aligned",$[$.Angular=2]="Angular",$[$.Diameter=3]="Diameter",$[$.Radius=4]="Radius",$[$.Angular3Point=5]="Angular3Point",$[$.Ordinate=6]="Ordinate",$[$.ReferenceIsExclusive=32]="ReferenceIsExclusive",$[$.IsOrdinateXTypeFlag=64]="IsOrdinateXTypeFlag",$[$.IsCustomTextPositionFlag=128]="IsCustomTextPositionFlag";(q={})[q.TopLeft=1]="TopLeft",q[q.TopCenter=2]="TopCenter",q[q.TopRight=3]="TopRight",q[q.MiddleLeft=4]="MiddleLeft",q[q.MiddleCenter=5]="MiddleCenter",q[q.MiddleRight=6]="MiddleRight",q[q.BottomLeft=7]="BottomLeft",q[q.BottomCenter=8]="BottomCenter",q[q.BottomRight=9]="BottomRight";(rs={})[rs.AtLeast=1]="AtLeast",rs[rs.Exact=2]="Exact";var ga=((Lt={})[Lt.Center=0]="Center",Lt[Lt.Above=1]="Above",Lt[Lt.Outside=2]="Outside",Lt[Lt.JIS=3]="JIS",Lt[Lt.Below=4]="Below",Lt);(Pe={})[Pe.WithDimension=0]="WithDimension",Pe[Pe.AddLeader=1]="AddLeader",Pe[Pe.Independent=2]="Independent";(Gt={})[Gt.BothOutside=0]="BothOutside",Gt[Gt.ArrowFirst=1]="ArrowFirst",Gt[Gt.TextFirst=2]="TextFirst",Gt[Gt.Auto=3]="Auto";var Ye=((ht={})[ht.Feet=0]="Feet",ht[ht.None=1]="None",ht[ht.Inch=2]="Inch",ht[ht.FeetAndInch=3]="FeetAndInch",ht[ht.Leading=4]="Leading",ht[ht.Trailing=8]="Trailing",ht[ht.LeadingAndTrailing=12]="LeadingAndTrailing",ht),fc=((Ht={})[Ht.None=0]="None",Ht[Ht.Leading=1]="Leading",Ht[Ht.Trailing=2]="Trailing",Ht[Ht.LeadingAndTrailing=3]="LeadingAndTrailing",Ht),bc=((Ot={})[Ot.Center=0]="Center",Ot[Ot.First=1]="First",Ot[Ot.Second=2]="Second",Ot[Ot.OverFirst=3]="OverFirst",Ot[Ot.OverSecond=4]="OverSecond",Ot),Ic=((Se={})[Se.Bottom=0]="Bottom",Se[Se.Center=1]="Center",Se[Se.Top=2]="Top",Se);(Ee={})[Ee.None=0]="None",Ee[Ee.UseDrawingBackground=1]="UseDrawingBackground",Ee[Ee.Custom=2]="Custom";(Ae={})[Ae.Horizontal=0]="Horizontal",Ae[Ae.Diagonal=1]="Diagonal",Ae[Ae.NotStacked=2]="NotStacked";(wt={})[wt.Scientific=1]="Scientific",wt[wt.Decimal=2]="Decimal",wt[wt.Engineering=3]="Engineering",wt[wt.Architectural=4]="Architectural",wt[wt.Fractional=5]="Fractional",wt[wt.WindowDesktop=6]="WindowDesktop";(Ut={})[Ut.Decimal=0]="Decimal",Ut[Ut.DegreesMinutesSecond=1]="DegreesMinutesSecond",Ut[Ut.Gradian=2]="Gradian",Ut[Ut.Radian=3]="Radian";var Pc=((as={})[as.PatternFill=0]="PatternFill",as[as.SolidFill=1]="SolidFill",as);(os={})[os.NonAssociative=0]="NonAssociative",os[os.Associative=1]="Associative";(Te={})[Te.Normal=0]="Normal",Te[Te.Outer=1]="Outer",Te[Te.Ignore=2]="Ignore";(Me={})[Me.UserDefined=0]="UserDefined",Me[Me.Predefined=1]="Predefined",Me[Me.Custom=2]="Custom";(hs={})[hs.NotAnnotated=0]="NotAnnotated",hs[hs.Annotated=1]="Annotated";(ls={})[ls.Solid=0]="Solid",ls[ls.Gradient=1]="Gradient";(cs={})[cs.TwoColor=0]="TwoColor",cs[cs.OneColor=1]="OneColor";var Sc=((xt={})[xt.Default=0]="Default",xt[xt.External=1]="External",xt[xt.Polyline=2]="Polyline",xt[xt.Derived=4]="Derived",xt[xt.Textbox=8]="Textbox",xt[xt.Outermost=16]="Outermost",xt),di=((Xt={})[Xt.Line=1]="Line",Xt[Xt.Circular=2]="Circular",Xt[Xt.Elliptic=3]="Elliptic",Xt[Xt.Spline=4]="Spline",Xt),Ec=((H={})[H.Off=0]="Off",H[H.Solid=1]="Solid",H[H.Dashed=2]="Dashed",H[H.Dotted=3]="Dotted",H[H.ShotDash=4]="ShotDash",H[H.MediumDash=5]="MediumDash",H[H.LongDash=6]="LongDash",H[H.DoubleShortDash=7]="DoubleShortDash",H[H.DoubleMediumDash=8]="DoubleMediumDash",H[H.DoubleLongDash=9]="DoubleLongDash",H[H.DoubleMediumLongDash=10]="DoubleMediumLongDash",H[H.SparseDot=11]="SparseDot",H);Ec.Off;(ve={})[ve.Standard=-3]="Standard",ve[ve.ByLayer=-2]="ByLayer",ve[ve.ByBlock=-1]="ByBlock";(ds={})[ds.English=0]="English",ds[ds.Metric=1]="Metric";(L={})[L.PERSPECTIVE_MODE=1]="PERSPECTIVE_MODE",L[L.FRONT_CLIPPING=2]="FRONT_CLIPPING",L[L.BACK_CLIPPING=4]="BACK_CLIPPING",L[L.UCS_FOLLOW=8]="UCS_FOLLOW",L[L.FRONT_CLIP_NOT_AT_EYE=16]="FRONT_CLIP_NOT_AT_EYE",L[L.UCS_ICON_VISIBILITY=32]="UCS_ICON_VISIBILITY",L[L.UCS_ICON_AT_ORIGIN=64]="UCS_ICON_AT_ORIGIN",L[L.FAST_ZOOM=128]="FAST_ZOOM",L[L.SNAP_MODE=256]="SNAP_MODE",L[L.GRID_MODE=512]="GRID_MODE",L[L.ISOMETRIC_SNAP_STYLE=1024]="ISOMETRIC_SNAP_STYLE",L[L.HIDE_PLOT_MODE=2048]="HIDE_PLOT_MODE",L[L.K_ISO_PAIR_TOP=4096]="K_ISO_PAIR_TOP",L[L.K_ISO_PAIR_RIGHT=8192]="K_ISO_PAIR_RIGHT",L[L.VIEWPORT_ZOOM_LOCKING=16384]="VIEWPORT_ZOOM_LOCKING",L[L.UNUSED=32768]="UNUSED",L[L.NON_RECTANGULAR_CLIPPING=65536]="NON_RECTANGULAR_CLIPPING",L[L.VIEWPORT_OFF=131072]="VIEWPORT_OFF",L[L.GRID_BEYOND_DRAWING_LIMITS=262144]="GRID_BEYOND_DRAWING_LIMITS",L[L.ADAPTIVE_GRID_DISPLAY=524288]="ADAPTIVE_GRID_DISPLAY",L[L.SUBDIVISION_BELOW_SPACING=1048576]="SUBDIVISION_BELOW_SPACING",L[L.GRID_FOLLOWS_WORKPLANE=2097152]="GRID_FOLLOWS_WORKPLANE";(lt={})[lt.OPTIMIZED_2D=0]="OPTIMIZED_2D",lt[lt.WIREFRAME=1]="WIREFRAME",lt[lt.HIDDEN_LINE=2]="HIDDEN_LINE",lt[lt.FLAT_SHADED=3]="FLAT_SHADED",lt[lt.GOURAUD_SHADED=4]="GOURAUD_SHADED",lt[lt.FLAT_SHADED_WITH_WIREFRAME=5]="FLAT_SHADED_WITH_WIREFRAME",lt[lt.GOURAUD_SHADED_WITH_WIREFRAME=6]="GOURAUD_SHADED_WITH_WIREFRAME";(us={})[us.UCS_UNCHANGED=0]="UCS_UNCHANGED",us[us.HAS_OWN_UCS=1]="HAS_OWN_UCS";(ct={})[ct.NON_ORTHOGRAPHIC=0]="NON_ORTHOGRAPHIC",ct[ct.TOP=1]="TOP",ct[ct.BOTTOM=2]="BOTTOM",ct[ct.FRONT=3]="FRONT",ct[ct.BACK=4]="BACK",ct[ct.LEFT=5]="LEFT",ct[ct.RIGHT=6]="RIGHT";(ps={})[ps.ONE_DISTANT_LIGHT=0]="ONE_DISTANT_LIGHT",ps[ps.TWO_DISTANT_LIGHTS=1]="TWO_DISTANT_LIGHTS";(Yt={})[Yt.ByLayer=0]="ByLayer",Yt[Yt.ByBlock=1]="ByBlock",Yt[Yt.ByDictionaryDefault=2]="ByDictionaryDefault",Yt[Yt.ByObject=3]="ByObject";(D={})[D.NotAllowed=0]="NotAllowed",D[D.AllowErase=1]="AllowErase",D[D.AllowTransform=2]="AllowTransform",D[D.AllowChangeColor=4]="AllowChangeColor",D[D.AllowChangeLayer=8]="AllowChangeLayer",D[D.AllowChangeLinetype=16]="AllowChangeLinetype",D[D.AllowChangeLinetypeScale=32]="AllowChangeLinetypeScale",D[D.AllowChangeVisibility=64]="AllowChangeVisibility",D[D.AllowClone=128]="AllowClone",D[D.AllowChangeLineweight=256]="AllowChangeLineweight",D[D.AllowChangePlotStyleName=512]="AllowChangePlotStyleName",D[D.AllowAllExceptClone=895]="AllowAllExceptClone",D[D.AllowAll=1023]="AllowAll",D[D.DisableProxyWarning=1024]="DisableProxyWarning",D[D.R13FormatProxy=32768]="R13FormatProxy";function N(i,t,e){return i.code===t&&(e==null||i.value===e)}function we(i){let t={};i.rewind();let e=i.next(),s=e.code;if(t.x=e.value,(e=i.next()).code!==s+10)throw Error("Expected code for point value to be 20 but got "+e.code+".");return t.y=e.value,(e=i.next()).code!==s+20?i.rewind():t.z=e.value,t}let Ks=Symbol();function S(i,t){return(e,s,n)=>{let r=function(l,c=!1){return l.reduce((u,d)=>{d.pushContext&&u.push({});let g=u[u.length-1];for(let p of typeof d.code=="number"?[d.code]:d.code){let m=g[p]??(g[p]=[]);d.isMultiple&&m.length,m.push(d)}return u},[{}])}(i,s.debug),a=!1,o=r.length-1;for(;!N(e,0,"EOF");){let l=function(x,f,P){return x.find((I,M)=>{var A;return M>=P&&((A=I[f])==null?void 0:A.length)})}(r,e.code,o),c=l==null?void 0:l[e.code],u=c==null?void 0:c[c.length-1];if(!l||!u){s.rewind();break}u.isMultiple||l[e.code].pop();let{name:d,parser:g,isMultiple:p,isReducible:m}=u,y=g==null?void 0:g(e,s,n);if(y===Ks){s.rewind();break}if(d){let[x,f]=Ac(n,d);p&&!m?(Object.prototype.hasOwnProperty.call(x,f)||(x[f]=[]),x[f].push(y)):x[f]=y}u.pushContext&&(o-=1),a=!0,e=s.next()}return t&&Object.setPrototypeOf(n,t),a}}function Ac(i,t){let e=t.split(".");if(!e.length)throw Error("[parserGenerator::getObjectByPath] Invalid empty path");let s=i;for(let n=0;n<e.length-1;++n){let r=wn(e[n]),a=wn(e[n+1]);Object.prototype.hasOwnProperty.call(s,r)||(typeof a=="number"?s[r]=[]:s[r]={}),s=s[r]}return[s,wn(e[e.length-1])]}function wn(i){let t=Number.parseInt(i);return Number.isNaN(t)?i:t}function h({value:i}){return i}function _(i,t){return we(t)}function O({value:i}){return!!i}function Tc({value:i}){return i.trim()}let Mc=[{code:281,name:"isEntity",parser:O},{code:280,name:"wasProxy",parser:O},{code:91,name:"instanceCount",parser:h},{code:90,name:"proxyFlag",parser:h},{code:3,name:"appName",parser:h},{code:2,name:"cppClassName",parser:h},{code:1,name:"name",parser:h}],vc=S(Mc),kc=[{code:0,name:"classes",isMultiple:!0,parser(i,t){if(i.value!=="CLASS")return Ks;i=t.next();let e={};return vc(i,t,e),e}}],Lc=S(kc);(gs={})[gs.RayTrace=0]="RayTrace",gs[gs.ShadowMap=1]="ShadowMap";function jt(i,t,e){for(;N(i,102);){var s;let n=i.value;if(i=t.next(),!n.startsWith("{")){t.debug,function(a,o){for(;!N(a,102)&&!N(a,0,"EOF");)a=o.next()}(i,t),i=t.next();continue}let r=n.slice(1).trim();e.extensions??(e.extensions={}),(s=e.extensions)[r]??(s[r]=[]),function(a,o,l){for(;!N(a,102,"}")&&!N(a,0,"EOF");)l.push(a),a=o.next()}(i,t,e.extensions[r]),i=t.next()}t.rewind()}let Oc=[{code:1001,name:"xdata",isMultiple:!0,parser:ah}],Nc=new Set([1010,1011,1012,1013]);function ah(i,t){var n;if(!N(i,1001))throw Error("XData must starts with code 1001");let e={appName:i.value,value:[]};i=t.next();let s=[e.value];for(;!N(i,0,"EOF")&&!N(i,1001)&&i.code>=1e3;){let r=s[s.length-1];if(i.code===1002){i.value==="{"?s.push([]):(s.pop(),(n=s[s.length-1])==null||n.push(r)),i=t.next();continue}Nc.has(i.code)?r.push(we(t)):r.push(i.value),i=t.next()}return t.rewind(),e}($t={})[$t.CAST_AND_RECEIVE=0]="CAST_AND_RECEIVE",$t[$t.CAST=1]="CAST",$t[$t.RECEIVE=2]="RECEIVE",$t[$t.IGNORE=3]="IGNORE";let V=[...Oc,{code:284,name:"shadowMode",parser:h},{code:390,name:"plotStyleHardId",parser:h},{code:380,name:"plotStyleType",parser:h},{code:440,name:"transparency",parser:h},{code:430,name:"colorName",parser:h},{code:420,name:"color",parser:h},{code:310,name:"proxyEntity",isMultiple:!0,isReducible:!0,parser:(i,t,e)=>(e.proxyEntity??"")+i.value},{code:[92,160],name:"proxyByte",parser:h},{code:60,name:"isVisible",parser:O},{code:48,name:"lineTypeScale",parser:h},{code:370,name:"lineweight",parser:h},{code:62,name:"colorIndex",parser:h},{code:347,name:"materialObjectHardId",parser:h},{code:6,name:"lineType",parser:h},{code:8,name:"layer",parser:h},{code:410,name:"layoutTabName",parser:h},{code:67,name:"isInPaperSpace",parser:O},{code:100},{code:330,name:"ownerBlockRecordSoftId",parser:h},{code:102,parser:jt},{code:102,parser:jt},{code:102,parser:jt},{code:5,name:"handle",parser:h}];function sn(i){return[{code:3,name:i,parser:(t,e,s)=>(s._code3text=(s._code3text??"")+t.value,s._code3text+(s._code1text??"")),isMultiple:!0,isReducible:!0},{code:1,name:i,parser:(t,e,s)=>(s._code1text=t.value,(s._code3text??"")+s._code1text)}]}function oh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let Cc={extrusionDirection:{x:0,y:0,z:1}},Bc=[{code:210,name:"extrusionDirection",parser:_},{code:51,name:"endAngle",parser:h},{code:50,name:"startAngle",parser:h},{code:100,name:"subclassMarker",parser:h},{code:40,name:"radius",parser:h},{code:10,name:"center",parser:_},{code:39,name:"thickness",parser:h},{code:100},...V];class hh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){oh(this,"parser",S(Bc,Cc))}}oh(hh,"ForEntityName","ARC");(ke={})[ke.BeforeText=0]="BeforeText",ke[ke.AboveText=1]="AboveText",ke[ke.None=2]="None";let lr=[{name:"DIMPOST",code:3},{name:"DIMAPOST",code:4,defaultValue:""},{name:"DIMBLK_OBSOLETE",code:5},{name:"DIMBLK1_OBSOLETE",code:6},{name:"DIMBLK2_OBSOLETE",code:7},{name:"DIMSCALE",code:40,defaultValue:1},{name:"DIMASZ",code:41,defaultValue:.25},{name:"DIMEXO",code:42,defaultValue:.625,defaultValueImperial:.0625},{name:"DIMDLI",code:43,defaultValue:3.75,defaultValueImperial:.38},{name:"DIMEXE",code:44,defaultValue:2.25,defaultValueImperial:.28},{name:"DIMRND",code:45,defaultValue:0},{name:"DIMDLE",code:46,defaultValue:0},{name:"DIMTP",code:47,defaultValue:0},{name:"DIMTM",code:48,defaultValue:0},{name:"DIMFXL",code:49,defaultValue:1},{name:"DIMJOGANG",code:50,defaultValue:45},{name:"DIMTFILL",code:69,defaultValue:0},{name:"DIMTFILLCLR",code:70,defaultValue:0},{name:"DIMTOL",code:71,defaultValue:0,defaultValueImperial:1},{name:"DIMLIM",code:72,defaultValue:0},{name:"DIMTIH",code:73,defaultValue:0,defaultValueImperial:1},{name:"DIMTOH",code:74,defaultValue:0,defaultValueImperial:1},{name:"DIMSE1",code:75,defaultValue:0},{name:"DIMSE2",code:76,defaultValue:0},{name:"DIMTAD",code:77,defaultValue:ga.Above,defaultValueImperial:ga.Center},{name:"DIMZIN",code:78,defaultValue:Ye.Trailing,defaultValueImperial:Ye.Feet},{name:"DIMAZIN",code:79,defaultValue:fc.None},{name:"DIMARCSYM",code:90,defaultValue:0},{name:"DIMTXT",code:140,defaultValue:2.5,defaultValueImperial:.28},{name:"DIMCEN",code:141,defaultValue:2.5,defaultValueImperial:.09},{name:"DIMTSZ",code:142,defaultValue:0},{name:"DIMALTF",code:143,defaultValue:25.4},{name:"DIMLFAC",code:144,defaultValue:1},{name:"DIMTVP",code:145,defaultValue:0},{name:"DIMTFAC",code:146,defaultValue:1},{name:"DIMGAP",code:147,defaultValue:.625,defaultValueImperial:.09},{name:"DIMALTRND",code:148,defaultValue:0},{name:"DIMALT",code:170,defaultValue:0},{name:"DIMALTD",code:171,defaultValue:3,defaultValueImperial:2},{name:"DIMTOFL",code:172,defaultValue:1,defaultValueImperial:0},{name:"DIMSAH",code:173,defaultValue:0},{name:"DIMTIX",code:174,defaultValue:0},{name:"DIMSOXD",code:175,defaultValue:0},{name:"DIMCLRD",code:176,defaultValue:0},{name:"DIMCLRE",code:177,defaultValue:0},{name:"DIMCLRT",code:178,defaultValue:0},{name:"DIMADEC",code:179,defaultValue:0},{name:"DIMUNIT",code:270},{name:"DIMDEC",code:271,defaultValue:2,defaultValueImperial:4},{name:"DIMTDEC",code:272,defaultValue:2,defaultValueImperial:4},{name:"DIMALTU",code:273,defaultValue:2},{name:"DIMALTTD",code:274,defaultValue:3,defaultValueImperial:2},{name:"DIMAUNIT",code:275,defaultValue:0},{name:"DIMFRAC",code:276,defaultValue:0},{name:"DIMLUNIT",code:277,defaultValue:2},{name:"DIMDSEP",code:278,defaultValue:44,defaultValueImperial:46},{name:"DIMTMOVE",code:279,defaultValue:0},{name:"DIMJUST",code:280,defaultValue:bc.Center},{name:"DIMSD1",code:281,defaultValue:0},{name:"DIMSD2",code:282,defaultValue:0},{name:"DIMTOLJ",code:283,defaultValue:Ic.Center},{name:"DIMTZIN",code:284,defaultValue:Ye.Trailing,defaultValueImperial:Ye.Feet},{name:"DIMALTZ",code:285,defaultValue:Ye.Trailing},{name:"DIMALTTZ",code:286,defaultValue:Ye.Trailing},{name:"DIMFIT",code:287},{name:"DIMUPT",code:288,defaultValue:0},{name:"DIMATFIT",code:289,defaultValue:3},{name:"DIMFXLON",code:290,defaultValue:0},{name:"DIMTXTDIRECTION",code:294,defaultValue:0},{name:"DIMTXSTY",code:340,defaultValue:"Standard"},{name:"DIMLDRBLK",code:341,defaultValue:""},{name:"DIMBLK",code:342,defaultValue:""},{name:"DIMBLK1",code:343,defaultValue:""},{name:"DIMBLK2",code:344,defaultValue:""},{name:"DIMLTYPE",code:345,defaultValue:""},{name:"DIMLTEX1",code:346,defaultValue:""},{name:"DIMLTEX2",code:347,defaultValue:""},{name:"DIMLWD",code:371,defaultValue:-2},{name:"DIMLWE",code:372,defaultValue:-2}],lh=[{code:3,name:"styleName",parser:h},{code:210,name:"extrusionDirection",parser:_},{code:51,name:"ocsRotation",parser:h},{code:53,name:"textRotation",parser:h},{code:1,name:"text",parser:h},{code:42,name:"measurement",parser:h},{code:72,name:"textLineSpacingStyle",parser:h},{code:71,name:"attachmentPoint",parser:h},{code:70,name:"dimensionType",parser:h},{code:11,name:"textPoint",parser:_},{code:10,name:"definitionPoint",parser:_},{code:2,name:"name",parser:h},{code:280,name:"version",parser:h},{code:100}],Fc=[{code:100},{code:52,name:"obliqueAngle",parser:h},{code:50,name:"rotationAngle",parser:h},{code:14,name:"subDefinitionPoint2",parser:_},{code:13,name:"subDefinitionPoint1",parser:_},{code:12,name:"insertionPoint",parser:_},{code:100,name:"subclassMarker",parser:h}],Rc=[{code:16,name:"arcPoint",parser:_},{code:15,name:"centerPoint",parser:_},{code:14,name:"subDefinitionPoint2",parser:_},{code:13,name:"subDefinitionPoint1",parser:_},{code:100,name:"subclassMarker",parser:h}],zc=[{code:14,name:"subDefinitionPoint2",parser:_},{code:13,name:"subDefinitionPoint1",parser:_},{code:100,name:"subclassMarker",parser:h}],Vc=[{code:40,name:"leaderLength",parser:h},{code:15,name:"subDefinitionPoint",parser:_},{code:100,name:"subclassMarker",parser:h}],Dc=[{code:100,parser(i,t,e){let s=function(n){switch(n){case"AcDbAlignedDimension":return S(Fc);case"AcDb3PointAngularDimension":case"AcDb2LineAngularDimension":return S(Rc);case"AcDbOrdinateDimension":return S(zc);case"AcDbRadialDimension":case"AcDbDiametricDimension":return S(Vc)}return null}(i.value);if(!s)return Ks;s(i,t,e)},pushContext:!0},...lr.map(i=>({...i,parser:h})),...lh,...V];class yi{parseEntity(t,e){let s={};return S(Dc)(e,t,s),s}}(un="ForEntityName")in yi?Object.defineProperty(yi,un,{value:"DIMENSION",enumerable:!0,configurable:!0,writable:!0}):yi[un]="DIMENSION";let jc=[{code:73},{code:17,name:"leaderEnd",parser:_},{code:16,name:"leaderStart",parser:_},{code:71,name:"hasLeader",parser:O},{code:41,name:"endAngle",parser:h},{code:40,name:"startAngle",parser:h},{code:70,name:"isPartial",parser:O},{code:15,name:"centerPoint",parser:_},{code:14,name:"xline2Point",parser:_},{code:13,name:"xline1Point",parser:_},{code:100,name:"subclassMarker",parser:h,pushContext:!0},...lr.map(i=>({...i,parser:h})),...lh,...V];class _i{parseEntity(t,e){let s={};return S(jc)(e,t,s),s}}(pn="ForEntityName")in _i?Object.defineProperty(_i,pn,{value:"ARC_DIMENSION",enumerable:!0,configurable:!0,writable:!0}):_i[pn]="ARC_DIMENSION";(Nt={})[Nt.NONE=0]="NONE",Nt[Nt.INVISIBLE=1]="INVISIBLE",Nt[Nt.CONSTANT=2]="CONSTANT",Nt[Nt.VERIFICATION_REQUIRED=4]="VERIFICATION_REQUIRED",Nt[Nt.PRESET=8]="PRESET";(ms={})[ms.MULTILINE=2]="MULTILINE",ms[ms.CONSTANT_MULTILINE=4]="CONSTANT_MULTILINE";(Le={})[Le.NONE=0]="NONE",Le[Le.MIRRORED_X=2]="MIRRORED_X",Le[Le.MIRRORED_Y=4]="MIRRORED_Y";var Wc=((ft={})[ft.LEFT=0]="LEFT",ft[ft.CENTER=1]="CENTER",ft[ft.RIGHT=2]="RIGHT",ft[ft.ALIGNED=3]="ALIGNED",ft[ft.MIDDLE=4]="MIDDLE",ft[ft.FIT=5]="FIT",ft),Gc=((qt={})[qt.BASELINE=0]="BASELINE",qt[qt.BOTTOM=1]="BOTTOM",qt[qt.MIDDLE=2]="MIDDLE",qt[qt.TOP=3]="TOP",qt);function ch(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let dh={thickness:0,rotation:0,xScale:1,obliqueAngle:0,styleName:"STANDARD",generationFlag:0,halign:Wc.LEFT,valign:Gc.BASELINE,extrusionDirection:{x:0,y:0,z:1}},uh=[{code:73,name:"valign",parser:h},{code:100},{code:210,name:"extrusionDirection",parser:_},{code:11,name:"endPoint",parser:_},{code:72,name:"valign",parser:h},{code:72,name:"halign",parser:h},{code:71,name:"generationFlag",parser:h},{code:7,name:"styleName",parser:h},{code:51,name:"obliqueAngle",parser:h},{code:41,name:"xScale",parser:h},{code:50,name:"rotation",parser:h},{code:1,name:"text",parser:h},{code:40,name:"textHeight",parser:h},{code:10,name:"startPoint",parser:_},{code:39,name:"thickness",parser:h},{code:100,name:"subclassMarker",parser:h},...V];class ph{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){ch(this,"parser",S(uh,dh))}}function gh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}ch(ph,"ForEntityName","TEXT");let Hc={...dh},Uc=[{code:2},{code:40,name:"annotationScale",parser:h},{code:10,name:"alignmentPoint",parser:_},{code:340,name:"secondaryAttributesHardIds",isMultiple:!0,parser:h},{code:70,name:"numberOfSecondaryAttributes",parser:h},{code:70,name:"isReallyLocked",parser:O},{code:70,name:"mtextFlag",parser:h},{code:280,name:"isDuplicatedRecord",parser:O},{code:100},{code:280,name:"isLocked",parser:O},{code:74,name:"valign",parser:h},{code:73},{code:70,name:"attributeFlag",parser:h},{code:2,name:"tag",parser:h},{code:3,name:"prompt",parser:h},{code:280},{code:100,name:"subclassMarker",parser:h},...uh.slice(2)];class mh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){gh(this,"parser",S(Uc,Hc))}}function Xc(i,t){let e={};for(let s of i){let n=t(s);n!=null&&(e[n]??(e[n]=[]),e[n].push(s))}return e}function*$i(i,t=1/0,e=1){for(let s=i;s!==t;s+=e)yield s}function ma(i){return{x:i.x??0,y:i.y??0,z:i.z??0}}gh(mh,"ForEntityName","ATTDEF");var Yc=[0,16711680,16776960,65280,65535,255,16711935,16777215,8421504,12632256,16711680,16744319,13369344,13395558,10027008,10046540,8323072,8339263,4980736,4990502,16727808,16752511,13382400,13401958,10036736,10051404,8331008,8343359,4985600,4992806,16744192,16760703,13395456,13408614,10046464,10056268,8339200,8347455,4990464,4995366,16760576,16768895,13408512,13415014,10056192,10061132,8347392,8351551,4995328,4997670,16776960,16777087,13421568,13421670,10000384,10000460,8355584,8355647,5000192,5000230,12582656,14679935,10079232,11717734,7510016,8755276,6258432,7307071,3755008,4344870,8388352,12582783,6736896,10079334,5019648,7510092,4161280,6258495,2509824,3755046,4194048,10485631,3394560,8375398,2529280,6264908,2064128,5209919,1264640,3099686,65280,8388479,52224,6736998,38912,5019724,32512,4161343,19456,2509862,65343,8388511,52275,6737023,38950,5019743,32543,4161359,19475,2509871,65407,8388543,52326,6737049,38988,5019762,32575,4161375,19494,2509881,65471,8388575,52377,6737074,39026,5019781,32607,4161391,19513,2509890,65535,8388607,52428,6737100,39064,5019800,32639,4161407,19532,2509900,49151,8380415,39372,6730444,29336,5014936,24447,4157311,14668,2507340,32767,8372223,26316,6724044,19608,5010072,16255,4153215,9804,2505036,16383,8364031,13260,6717388,9880,5005208,8063,4149119,4940,2502476,255,8355839,204,6710988,152,5000344,127,4145023,76,2500172,4129023,10452991,3342540,8349388,2490520,6245528,2031743,5193599,1245260,3089996,8323327,12550143,6684876,10053324,4980888,7490712,4128895,6242175,2490444,3745356,12517631,14647295,10027212,11691724,7471256,8735896,6226047,7290751,3735628,4335180,16711935,16744447,13369548,13395660,9961624,9981080,8323199,8339327,4980812,4990540,16711871,16744415,13369497,13395634,9961586,9981061,8323167,8339311,4980793,4990530,16711807,16744383,13369446,13395609,9961548,9981042,8323135,8339295,4980774,4990521,16711743,16744351,13369395,13395583,9961510,9981023,8323103,8339279,4980755,4990511,3355443,5987163,8684676,11382189,14079702,16777215];function $c(i){return Yc[i]}function qc(i){i.rewind();let t=i.next();if(t.code!==101)throw Error("Bad call for skipEmbeddedObject()");do t=i.next();while(t.code!==0);i.rewind()}function Zc(i,t,e){if(N(t,102))return jt(t,e,i),!0;switch(t.code){case 0:i.type=t.value;break;case 5:i.handle=t.value;break;case 330:i.ownerBlockRecordSoftId=t.value;break;case 67:i.isInPaperSpace=!!t.value;break;case 8:i.layer=t.value;break;case 6:i.lineType=t.value;break;case 347:i.materialObjectHardId=t.value;break;case 62:i.colorIndex=t.value,i.color=$c(Math.abs(t.value));break;case 370:i.lineweight=t.value;break;case 48:i.lineTypeScale=t.value;break;case 60:i.isVisible=!!t.value;break;case 92:i.proxyByte=t.value;break;case 310:i.proxyEntity=t.value;break;case 100:break;case 420:i.color=t.value;break;case 430:i.transparency=t.value;break;case 390:i.plotStyleHardId=t.value;break;case 284:i.shadowMode=t.value;break;case 1001:(i.xdata??(i.xdata=[])).push(ah(t,e));break;default:return!1}return!0}function yh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let Kc={textStyle:"STANDARD",extrusionDirection:{x:0,y:0,z:1},rotation:0},wi=[{code:46,name:"annotationHeight",parser:h},{code:101,parser(i,t){qc(t)}},{code:50,name:"columnHeight",parser:h},{code:49,name:"columnGutter",parser:h},{code:48,name:"columnWidth",parser:h},{code:79,name:"columnAutoHeight",parser:h},{code:78,name:"columnFlowReversed",parser:h},{code:76,name:"columnCount",parser:h},{code:75,name:"columnType",parser:h},{code:441,name:"backgroundFillTransparency",parser:h},{code:63,name:"backgroundFillColor",parser:h},{code:45,name:"fillBoxScale",parser:h},{code:[...$i(430,440)],name:"backgroundColor",parser:h},{code:[...$i(420,430)],name:"backgroundColor",parser:h},{code:90,name:"backgroundFill",parser:h},{code:44,name:"lineSpacing",parser:h},{code:73,name:"lineSpacingStyle",parser:h},{code:50,name:"rotation",parser:h},{code:43},{code:42},{code:11,name:"direction",parser:_},{code:210,name:"extrusionDirection",parser:_},{code:7,name:"styleName",parser:h},...sn("text"),{code:72,name:"drawingDirection",parser:h},{code:71,name:"attachmentPoint",parser:h},{code:41,name:"width",parser:h},{code:40,name:"height",parser:h},{code:10,name:"insertionPoint",parser:_},{code:100,name:"subclassMarker",parser:h},...V];class _h{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){yh(this,"parser",S(wi,Kc))}}function wh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}yh(_h,"ForEntityName","MTEXT");let Qc={thickness:0,rotation:0,scale:1,obliqueAngle:0,textStyle:"STANDARD",textGenerationFlag:0,horizontalJustification:0,verticalJustification:0,extrusionDirection:{x:0,y:0,z:1}},Jc=[...wi.slice(wi.findIndex(({name:i})=>i==="columnType"),wi.findIndex(({name:i})=>i==="subclassMarker")+1),{code:100},{code:0,parser(i){if(!N(i,0,"MTEXT"))return Ks}},{code:2,name:"definitionTag",parser:h},{code:40,name:"annotationScale",parser:h},{code:10,name:"alignmentPoint",parser:_},{code:340,name:"secondaryAttributesHardId",parser:h},{code:70,name:"numberOfSecondaryAttributes",parser:h},{code:70,name:"isReallyLocked",parser:O},{code:70,name:"mtextFlag",parser:h},{code:280,name:"isDuplicatedEntriesKeep",parser:O},{code:100},{code:280,name:"lockPositionFlag",parser:O},{code:210,name:"extrusionDirection",parser:_},{code:11,name:"alignmentPoint",parser:_},{code:74,name:"verticalJustification",parser:h},{code:72,name:"horizontalJustification",parser:h},{code:71,name:"textGenerationFlag",parser:h},{code:7,name:"textStyle",parser:h},{code:51,name:"obliqueAngle",parser:h},{code:41,name:"scale",parser:h},{code:50,name:"rotation",parser:h},{code:73},{code:70,name:"attributeFlag",parser:h},{code:2,name:"tag",parser:h},{code:280},{code:100,name:"subclassMarker",parser:h},{code:1,name:"text",parser:h},{code:40,name:"textHeight",parser:h},{code:10,name:"startPoint",parser:_},{code:39,name:"thickness",parser:h},{code:100},...V];class xh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){wh(this,"parser",S(Jc,Qc))}}function fh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}wh(xh,"ForEntityName","ATTRIB");let td=[...sn("data"),{code:70,name:"version",parser:h},{code:100,name:"subclassMarker",parser:h},...V];class bh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){fh(this,"parser",S(td))}}function Ih(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}fh(bh,"ForEntityName","BODY");let ed={thickness:0,extrusionDirection:{x:0,y:0,z:1}},sd=[{code:210,name:"extrusionDirection",parser:_},{code:40,name:"radius",parser:h},{code:10,name:"center",parser:_},{code:39,name:"thickness",parser:h},{code:100,name:"subclassMarker",parser:h},...V];class Ph{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Ih(this,"parser",S(sd,ed))}}function Sh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Ih(Ph,"ForEntityName","CIRCLE");let id={extrusionDirection:{x:0,y:0,z:1}},nd=[{code:42,name:"endAngle",parser:h},{code:41,name:"startAngle",parser:h},{code:40,name:"axisRatio",parser:h},{code:210,name:"extrusionDirection",parser:_},{code:11,name:"majorAxisEndPoint",parser:_},{code:10,name:"center",parser:_},{code:100,name:"subclassMarker",parser:h},...V];class Eh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Sh(this,"parser",S(nd,id))}}function Ah(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Sh(Eh,"ForEntityName","ELLIPSE");let rd=[{code:13,name:"vertices.3",parser:_},{code:12,name:"vertices.2",parser:_},{code:11,name:"vertices.1",parser:_},{code:10,name:"vertices.0",parser:_},{code:100,name:"subclassMarker",parser:h},...V];class Th{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Ah(this,"parser",S(rd))}}Ah(Th,"ForEntityName","3DFACE");(Zt={})[Zt.First=1]="First",Zt[Zt.Second=2]="Second",Zt[Zt.Third=4]="Third",Zt[Zt.Fourth=8]="Fourth";let Mh=[{code:330,name:"sourceBoundaryObjects",parser:h,isMultiple:!0},{code:97,name:"numberOfSourceBoundaryObjects",parser:h}],ad=[{code:11,name:"end",parser:_},{code:10,name:"start",parser:_}],od=[{code:73,name:"isCCW",parser:O},{code:51,name:"endAngle",parser:h},{code:50,name:"startAngle",parser:h},{code:40,name:"radius",parser:h},{code:10,name:"center",parser:_}],hd=[{code:73,name:"isCCW",parser:O},{code:51,name:"endAngle",parser:h},{code:50,name:"startAngle",parser:h},{code:40,name:"lengthOfMinorAxis",parser:h},{code:11,name:"end",parser:_},{code:10,name:"center",parser:_}],ld=[{code:13,name:"endTangent",parser:_},{code:12,name:"startTangent",parser:_},{code:11,name:"fitDatum",isMultiple:!0,parser:_},{code:97,name:"numberOfFitData",parser:h},{code:10,name:"controlPoints",isMultiple:!0,parser(i,t){let e={...we(t),weight:1};return(i=t.next()).code===42?e.weight=i.value:t.rewind(),e}},{code:40,name:"knots",isMultiple:!0,parser:h},{code:96,name:"numberOfControlPoints",parser:h},{code:95,name:"numberOfKnots",parser:h},{code:74,name:"isPeriodic",parser:O},{code:73,name:"splineFlag",parser:h},{code:94,name:"degree",parser:h}],cd={[di.Line]:ad,[di.Circular]:od,[di.Elliptic]:hd,[di.Spline]:ld},dd=[...Mh,{code:72,name:"edges",parser(i,t){let e={type:i.value},s=S(cd[e.type]);if(!s)throw Error(`Invalid edge type ${e.type}`);return s(i=t.next(),t,e),e},isMultiple:!0},{code:93,name:"numberOfEdges",parser:h}],ud=[...Mh,{code:10,name:"vertices",parser(i,t){let e={...we(t),bulge:0};return(i=t.next()).code===42?e.bulge=i.value:t.rewind(),e},isMultiple:!0},{code:93,name:"numberOfVertices",parser:h},{code:73,name:"isClosed",parser:O},{code:72,name:"hasBulge",parser:O}];function pd(i,t){let e={boundaryPathTypeFlag:i.value},s=e.boundaryPathTypeFlag&Sc.Polyline;return i=t.next(),s?S(ud)(i,t,e):S(dd)(i,t,e),e}let gd=[{code:49,name:"dashLengths",parser:h,isMultiple:!0},{code:79,name:"numberOfDashLengths",parser:h},{code:45,name:"offset",parser:ya},{code:43,name:"base",parser:ya},{code:53,name:"angle",parser:h}];function ya(i,t){let e=i.code+1,s={x:i.value,y:1};return(i=t.next()).code===e?s.y=i.value:t.rewind(),s}function md(i,t){let e={};return S(gd)(i,t,e),e}function yd(i,t){let e=[];for(;i.code===463;){let s={reservedField:i.value};if((i=t.next()).code===63&&(s.colorIndex=i.value,i=t.next()),i.code===421)s.rgb=i.value,e.push(s),i=t.next();else{t.rewind();break}}return i.code!==463&&e.length>0&&t.rewind(),e}function vh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let _d={extrusionDirection:{x:0,y:0,z:1},gradientRotation:0,colorTint:0},wd=[{code:470,name:"gradientName",parser:h},{code:463,name:"gradientColors",parser:yd},{code:462,name:"colorTint",parser:h},{code:461,name:"gradientDefinition",parser:h},{code:460,name:"gradientRotation",parser:h},{code:453,name:"numberOfColors",parser:h},{code:452,name:"gradientColorFlag",parser:h},{code:451},{code:450,name:"gradientFlag",parser:h},{code:10,name:"seedPoints",parser:_,isMultiple:!0},{code:99},{code:11,name:"offsetVector",parser:_},{code:98,name:"numberOfSeedPoints",parser:h},{code:47,name:"pixelSize",parser:h},{code:53,name:"definitionLines",parser:md,isMultiple:!0},{code:78,name:"numberOfDefinitionLines",parser:h},{code:77,name:"isDouble",parser:O},{code:73,name:"isAnnotated",parser:O},{code:41,name:"patternScale",parser:h},{code:52,name:"patternAngle",parser:h},{code:76,name:"patternType",parser:h},{code:75,name:"hatchStyle",parser:h},{code:92,name:"boundaryPaths",parser:pd,isMultiple:!0},{code:91,name:"numberOfBoundaryPaths",parser:h},{code:71,name:"associativity",parser:h},{code:63,name:"patternFillColor",parser:h},{code:70,name:"solidFill",parser:h},{code:2,name:"patternName",parser:h},{code:210,name:"extrusionDirection",parser:_},{code:10,name:"elevationPoint",parser:_},{code:100,name:"subclassMarker",parser:h,pushContext:!0},...V];class kh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){vh(this,"parser",S(wd,_d))}}function Lh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}vh(kh,"ForEntityName","HATCH");let xd={brightness:50,contrast:50,fade:0,clippingBoundaryPath:[]},fd=[{code:290,name:"clipMode",parser:h},{code:14,name:"clippingBoundaryPath",isMultiple:!0,parser:_},{code:91,name:"countBoundaryPoints",parser:h},{code:71,name:"clippingBoundaryType",parser:h},{code:360,name:"imageDefReactorHandle",parser:h},{code:283,name:"fade",parser:h},{code:282,name:"contrast",parser:h},{code:281,name:"brightness",parser:h},{code:280,name:"isClipped",parser:O},{code:70,name:"flags",parser:h},{code:340,name:"imageDefHandle",parser:h},{code:13,name:"imageSize",parser:_},{code:12,name:"vPixel",parser:_},{code:11,name:"uPixel",parser:_},{code:10,name:"position",parser:_},{code:90,name:"version",parser:h},{code:100,name:"subclassMarker",parser:h},...V];class Oh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Lh(this,"parser",S(fd,xd))}}Lh(Oh,"ForEntityName","IMAGE");(Kt={})[Kt.ShowImage=1]="ShowImage",Kt[Kt.ShowImageWhenNotAlignedWithScreen=2]="ShowImageWhenNotAlignedWithScreen",Kt[Kt.UseClippingBoundary=4]="UseClippingBoundary",Kt[Kt.TransparencyIsOn=8]="TransparencyIsOn";(ys={})[ys.Rectangular=1]="Rectangular",ys[ys.Polygonal=2]="Polygonal";(_s={})[_s.Outside=0]="Outside",_s[_s.Inside=1]="Inside";function Nh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let bd={xScale:1,yScale:1,zScale:1,rotation:0,columnCount:0,rowCount:0,columnSpacing:0,rowSpacing:0,extrusionDirection:{x:0,y:0,z:1}},Id=[{code:210,name:"extrusionDirection",parser:_},{code:45,name:"rowSpacing",parser:h},{code:44,name:"columnSpacing",parser:h},{code:71,name:"rowCount",parser:h},{code:70,name:"columnCount",parser:h},{code:50,name:"rotation",parser:h},{code:43,name:"zScale",parser:h},{code:42,name:"yScale",parser:h},{code:41,name:"xScale",parser:h},{code:10,name:"insertionPoint",parser:_},{code:2,name:"name",parser:h},{code:66,name:"isVariableAttributes",parser:O},{code:100,name:"subclassMarker",parser:h},...V];class Ch{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Nh(this,"parser",S(Id,bd))}}function Bh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Nh(Ch,"ForEntityName","INSERT");let Pd={isArrowheadEnabled:!0},Sd=[{code:213,name:"offsetFromAnnotation",parser:_},{code:212,name:"offsetFromBlock",parser:_},{code:211,name:"horizontalDirection",parser:_},{code:210,name:"normal",parser:_},{code:340,name:"associatedAnnotation",parser:h},{code:77,name:"byBlockColor",parser:h},{code:10,name:"vertices",parser:_,isMultiple:!0},{code:76,name:"numberOfVertices",parser:h},{code:41,name:"textWidth",parser:h},{code:40,name:"textHeight",parser:h},{code:75,name:"isHooklineExists",parser:O},{code:74,name:"isHooklineSameDirection",parser:O},{code:73,name:"leaderCreationFlag",parser:h},{code:72,name:"isSpline",parser:O},{code:71,name:"isArrowheadEnabled",parser:O},{code:3,name:"styleName",parser:h},{code:100,name:"subclassMarker",parser:h},...V];class Fh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Bh(this,"parser",S(Sd,Pd))}}Bh(Fh,"ForEntityName","LEADER");(Qt={})[Qt.TextAnnotation=0]="TextAnnotation",Qt[Qt.ToleranceAnnotation=1]="ToleranceAnnotation",Qt[Qt.BlockReferenceAnnotation=2]="BlockReferenceAnnotation",Qt[Qt.NoAnnotation=3]="NoAnnotation";function Rh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let Ed={thickness:0,extrusionDirection:{x:0,y:0,z:1}},Ad=[{code:210,name:"extrusionDirection",parser:_},{code:11,name:"endPoint",parser:_},{code:10,name:"startPoint",parser:_},{code:39,name:"thickness",parser:h},{code:100,name:"subclassMarker",parser:h},...V];class zh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Rh(this,"parser",S(Ad,Ed))}}function Vh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Rh(zh,"ForEntityName","LINE");let Td=[{code:280,name:"shadowMapSoftness",parser:h},{code:91,name:"shadowMapSize",parser:h},{code:73,name:"shadowType",parser:h},{code:293,name:"isShadowCast",parser:O},{code:51,name:"falloffAngle",parser:h},{code:50,name:"hotspotAngle",parser:h},{code:42,name:"limitEnd",parser:h},{code:41,name:"limitStart",parser:h},{code:292,name:"isAttenuationLimited",parser:O},{code:72,name:"attenuationType",parser:h},{code:11,name:"target",parser:_},{code:10,name:"position",parser:_},{code:40,name:"intensity",parser:h},{code:291,name:"isPlotGlyph",parser:O},{code:290,name:"isOn",parser:O},{code:421,name:"lightColorInstance",parser:h},{code:63,name:"lightColorIndex",parser:h},{code:70,name:"lightType",parser:h},{code:1,name:"name",parser:h},{code:90,name:"version",parser:h},{code:100,name:"subclassMarker",parser:h},...V];class Dh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Vh(this,"parser",S(Td))}}Vh(Dh,"ForEntityName","LIGHT");(Oe={})[Oe.Distant=1]="Distant",Oe[Oe.Point=2]="Point",Oe[Oe.Spot=3]="Spot";(Ne={})[Ne.None=0]="None",Ne[Ne.InverseLinear=1]="InverseLinear",Ne[Ne.InverseSquare=2]="InverseSquare";let Md={flag:0,elevation:0,thickness:0,extrusionDirection:{x:0,y:0,z:1},vertices:[]},vd={bulge:0},kd=[{code:42,name:"bulge",parser:h},{code:41,name:"endWidth",parser:h},{code:40,name:"startWidth",parser:h},{code:91,name:"id",parser:h},{code:20,name:"y",parser:h},{code:10,name:"x",parser:h}],Ld=[{code:210,name:"extrusionDirection",parser:_},{code:10,name:"vertices",isMultiple:!0,parser(i,t){let e={};return S(kd,vd)(i,t,e),e}},{code:39,name:"thickness",parser:h},{code:38,name:"elevation",parser:h},{code:43,name:"constantWidth",parser:h},{code:70,name:"flag",parser:h},{code:90,name:"numberOfVertices",parser:h},{code:100,name:"subclassMarker",parser:h},...V];class xi{parseEntity(t,e){let s={};return S(Ld,Md)(e,t,s),s}}(gn="ForEntityName")in xi?Object.defineProperty(xi,gn,{value:"LWPOLYLINE",enumerable:!0,configurable:!0,writable:!0}):xi[gn]="LWPOLYLINE";(ws={})[ws.IS_CLOSED=1]="IS_CLOSED",ws[ws.PLINE_GEN=128]="PLINE_GEN";function jh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let Od=[{code:90,name:"overridenSubEntityCount",parser:h},{code:140,name:"edgeCreaseWeights",parser:h,isMultiple:!0},{code:95,name:"edgeCreaseCount",parser:h},{code:94,parser(i,t,e){e.edgeCount=i.value,e.edgeIndices=[];for(let s=0;s<e.edgeCount;++s){let n=[];i=t.next(),n[0]=i.value,i=t.next(),n[1]=i.value,e.edgeIndices.push(n)}}},{code:93,parser(i,t,e){e.totalFaceIndices=i.value,e.faceIndices=[];let s=[];for(let r=0;r<e.totalFaceIndices&&!N(i,0);++r)i=t.next(),s.push(i.value);let n=0;for(;n<s.length;){let r=s[n++],a=[];for(let o=0;o<r;++o)a.push(s[n++]);e.faceIndices.push(a)}}},{code:10,name:"vertices",parser:_,isMultiple:!0},{code:92,name:"verticesCount",parser:h},{code:91,name:"subdivisionLevel",parser:h},{code:40,name:"blendCrease",parser:h},{code:72,name:"isBlendCreased",parser:O},{code:71,name:"version",parser:h},{code:100,name:"subclassMarker",parser:Tc,pushContext:!0},...V];class Wh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){jh(this,"parser",S(Od))}}function Gh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}jh(Wh,"ForEntityName","MESH");let Nd=[{code:42,name:"fillParameters",parser:h,isMultiple:!0},{code:75,name:"fillCount",parser:h},{code:41,name:"parameters",parser:h,isMultiple:!0},{code:74,name:"parameterCount",parser:h}],Cd=[{code:[74,41,75,42],name:"elements",parser(i,t){let e=S(Nd),s={};return e(i,t,s),s},isMultiple:!0},{code:13,name:"miterDirection",parser:_},{code:12,name:"direction",parser:_},{code:11,name:"position",parser:_}],Bd=[{code:[11,12,13],name:"segments",parser(i,t){let e=S(Cd),s={};return e(i,t,s),s},isMultiple:!0},{code:210,name:"extrusionDirection",parser:_},{code:10,name:"startPosition",parser:_},{code:73,name:"styleCount",parser:h},{code:72,name:"vertexCount",parser:h},{code:71,name:"flags",parser:h},{code:70,name:"justification",parser:h},{code:40,name:"scale",parser:h},{code:340,name:"styleObjectHandle",parser:h},{code:2,name:"name",parser:h},{code:100,name:"subclassMarker",parser:h,pushContext:!0},...V];class Hh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Gh(this,"parser",S(Bd))}}Gh(Hh,"ForEntityName","MLINE");(Ce={})[Ce.Top=0]="Top",Ce[Ce.Zero=1]="Zero",Ce[Ce.Bottom=2]="Bottom";(Jt={})[Jt.HasVertex=1]="HasVertex",Jt[Jt.Closed=2]="Closed",Jt[Jt.SuppressStartCaps=4]="SuppressStartCaps",Jt[Jt.SuppressEndCaps=8]="SuppressEndCaps";(Be={})[Be.LEFT_TO_RIGHT=1]="LEFT_TO_RIGHT",Be[Be.TOP_TO_BOTTOM=3]="TOP_TO_BOTTOM",Be[Be.BY_STYLE=5]="BY_STYLE";function Uh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let Fd={},Rd=[{code:170,name:"multileaderType",parser:h},{code:291,name:"doglegEnabled",parser:O},{code:40,name:"doglegLength",parser:h},{code:172,name:"contentType",parser:h},{code:3,name:"textContent",parser:h},{code:12,name:"textAnchor",parser:_},{code:344,name:"blockHandle",parser:h},{code:15,name:"blockPosition",parser:_},{code:302,name:"leaderSections",parser:function(i,t,e){let s,n={leaderLines:[]};for(;t.hasNext()&&(s=t.next()).code!==303;)switch(s.code){case 10:n.landingPoint=_(s.value,t);break;case 11:n.doglegVector=_(s.value,t);break;case 40:n.doglegLength=s.value;break;case 304:n.leaderLines.push(function(r,a,o){let l,c={vertices:[]};for(;a.hasNext()&&(l=a.next()).code!==305;)l.code===10&&c.vertices.push(_(l.value,a));return c}(0,t))}return n},isMultiple:!0},...V];class Xh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Uh(this,"parser",S(Rd,Fd))}}function Yh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Uh(Xh,"ForEntityName","MULTILEADER");let zd={thickness:0,extrusionDirection:{x:0,y:0,z:1},angle:0},Vd=[{code:50,name:"angle",parser:h},{code:210,name:"extrusionDirection",parser:_},{code:39,name:"thickness",parser:h},{code:10,name:"position",parser:_},{code:100,name:"subclassMarker",parser:h},...V];class $h{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Yh(this,"parser",S(Vd,zd))}}function qh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Yh($h,"ForEntityName","POINT");let Dd={startWidth:0,endWidth:0,bulge:0},jd=[{code:91,name:"id",parser:h},{code:[...$i(71,75)],name:"faces",isMultiple:!0,parser:h},{code:50,name:"tangentDirection",parser:h},{code:70,name:"flag",parser:h},{code:42,name:"bulge",parser:h},{code:41,name:"endWidth",parser:h},{code:40,name:"startWidth",parser:h},{code:30,name:"z",parser:h},{code:20,name:"y",parser:h},{code:10,name:"x",parser:h},{code:100,name:"subclassMarker",parser:h},{code:100},...V];class cr{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){qh(this,"parser",S(jd,Dd))}}function Zh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}qh(cr,"ForEntityName","VERTEX");let Wd={thickness:0,flag:0,startWidth:0,endWidth:0,meshMVertexCount:0,meshNVertexCount:0,surfaceMDensity:0,surfaceNDensity:0,smoothType:0,extrusionDirection:{x:0,y:0,z:1},vertices:[]},Gd=[{code:0,name:"vertices",isMultiple:!0,parser:(i,t)=>N(i,0,"VERTEX")?(i=t.next(),new cr().parseEntity(t,i)):Ks},{code:210,name:"extrusionDirection",parser:_},{code:75,name:"smoothType",parser:h},{code:74,name:"surfaceNDensity",parser:h},{code:73,name:"surfaceMDensity",parser:h},{code:72,name:"meshNVertexCount",parser:h},{code:71,name:"meshMVertexCount",parser:h},{code:41,name:"endWidth",parser:h},{code:40,name:"startWidth",parser:h},{code:70,name:"flag",parser:h},{code:39,name:"thickness",parser:h},{code:30,name:"elevation",parser:h},{code:20},{code:10},{code:66},{code:100,name:"subclassMarker",parser:h},...V];class Kh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Zh(this,"parser",S(Gd,Wd))}}Zh(Kh,"ForEntityName","POLYLINE");(it={})[it.CLOSED_POLYLINE=1]="CLOSED_POLYLINE",it[it.CURVE_FIT=2]="CURVE_FIT",it[it.SPLINE_FIT=4]="SPLINE_FIT",it[it.POLYLINE_3D=8]="POLYLINE_3D",it[it.POLYGON_3D=16]="POLYGON_3D",it[it.CLOSED_POLYGON=32]="CLOSED_POLYGON",it[it.POLYFACE=64]="POLYFACE",it[it.CONTINUOUS=128]="CONTINUOUS";var ui=((te={})[te.NONE=0]="NONE",te[te.QUADRATIC=5]="QUADRATIC",te[te.CUBIC=6]="CUBIC",te[te.BEZIER=8]="BEZIER",te);function Qh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let Hd=[{code:11,name:"direction",parser:_},{code:10,name:"position",parser:_},{code:100,name:"subclassMarker",parser:h},...V];class Jh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Qh(this,"parser",S(Hd))}}function tl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Qh(Jh,"ForEntityName","RAY");let Ud=[...sn("data"),{code:70,name:"version",parser:h},{code:100,name:"subclassMarker",parser:h},...V];class el{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){tl(this,"parser",S(Ud))}}function sl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}tl(el,"ForEntityName","REGION");let Xd={vertices:[],backLineVertices:[]},Yd=[{code:360,name:"geometrySettingHardId",parser:h},{code:12,name:"backLineVertices",isMultiple:!0,parser:_},{code:93,name:"numberOfBackLineVertices",parser:h},{code:11,name:"vertices",isMultiple:!0,parser:_},{code:92,name:"verticesCount",parser:h},{code:[63,411],name:"indicatorColor",parser:h},{code:70,name:"indicatorTransparency",parser:h},{code:41,name:"bottomHeight",parser:h},{code:40,name:"topHeight",parser:h},{code:10,name:"verticalDirection",parser:_},{code:1,name:"name",parser:h},{code:91,name:"flag",parser:h},{code:90,name:"state",parser:h},{code:100,name:"subclassMarker",parser:h},...V];class il{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){sl(this,"parser",S(Yd,Xd))}}function nl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}sl(il,"ForEntityName","SECTION");let $d={points:[],thickness:0,extrusionDirection:{x:0,y:0,z:1}},qd=[{code:210,name:"extrusionDirection",parser:_},{code:39,name:"thickness",parser:h},{code:[...$i(10,14)],name:"points",isMultiple:!0,parser:_},{code:100,name:"subclassMarker",parser:h},...V];class rl{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){nl(this,"parser",S(qd,$d))}}function al(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}nl(rl,"ForEntityName","SOLID");let Zd=[{code:350,name:"historyObjectSoftId",parser:h},{code:100,name:"subclassMarker",parser:h},...sn("data"),{code:70,name:"version",parser:h},{code:100},...V];class ol{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){al(this,"parser",S(Zd))}}function hl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}al(ol,"ForEntityName","3DSOLID");let Kd={knotTolerance:1e-6,controlTolerance:1e-6,fitTolerance:1e-9,knotValues:[],controlPoints:[],fitPoints:[]},Qd=[{code:11,name:"fitPoints",isMultiple:!0,parser:_},{code:10,name:"controlPoints",isMultiple:!0,parser:_},{code:41,name:"weights",isMultiple:!0,parser:h},{code:40,name:"knots",isMultiple:!0,parser:h},{code:13,name:"endTangent",parser:_},{code:12,name:"startTangent",parser:_},{code:44,name:"fitTolerance",parser:h},{code:43,name:"controlTolerance",parser:h},{code:42,name:"knotTolerance",parser:h},{code:74,name:"numberOfFitPoints",parser:h},{code:73,name:"numberOfControlPoints",parser:h},{code:72,name:"numberOfKnots",parser:h},{code:71,name:"degree",parser:h},{code:70,name:"flag",parser:h},{code:210,name:"normal",parser:_},{code:100,name:"subclassMarker",parser:h},...V];class ll{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){hl(this,"parser",S(Qd,Kd))}}hl(ll,"ForEntityName","SPLINE");(bt={})[bt.NONE=0]="NONE",bt[bt.CLOSED=1]="CLOSED",bt[bt.PERIODIC=2]="PERIODIC",bt[bt.RATIONAL=4]="RATIONAL",bt[bt.PLANAR=8]="PLANAR",bt[bt.LINEAR=16]="LINEAR";function cl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let Jd=[{code:280,name:"shadowMapSoftness",parser:h},{code:71,name:"shadowMapSize",parser:h},{code:70,name:"shadowType",parser:h},{code:292,name:"isSummerTime",parser:O},{code:92,name:"time",parser:h},{code:91,name:"julianDay",parser:h},{code:291,name:"hasShadow",parser:O},{code:40,name:"intensity",parser:h},{code:421,name:"lightColorInstance",parser:h},{code:63,name:"lightColorIndex",parser:h},{code:290,name:"isOn",parser:O},{code:90,name:"version",parser:h},{code:100,name:"subclassMarker",parser:h,pushContext:!0},...V.filter(i=>i.code!==100)];class dl{parseEntity(t,e){let s={layer:""};return this.parser(e,t,s),s}constructor(){cl(this,"parser",S(Jd))}}cl(dl,"ForEntityName","SUN");class fi{parseEntity(t,e){let s={};for(;!t.isEOF();){if(e.code===0){t.rewind();break}switch(e.code){case 100:s.subclassMarker=e.value,e=t.next();break;case 2:s.name=e.value,e=t.next();break;case 5:s.handle=e.value,e=t.next();break;case 10:s.startPoint=ma(we(t)),e=t.lastReadGroup;break;case 11:s.directionVector=ma(we(t)),e=t.lastReadGroup;break;case 90:s.tableValue=e.value,e=t.next();break;case 91:s.rowCount=e.value,e=t.next();break;case 92:s.columnCount=e.value,e=t.next();break;case 93:s.overrideFlag=e.value,e=t.next();break;case 94:s.borderColorOverrideFlag=e.value,e=t.next();break;case 95:s.borderLineWeightOverrideFlag=e.value,e=t.next();break;case 96:s.borderVisibilityOverrideFlag=e.value,e=t.next();break;case 141:s.rowHeightArr??(s.rowHeightArr=[]),s.rowHeightArr.push(e.value),e=t.next();break;case 142:s.columnWidthArr??(s.columnWidthArr=[]),s.columnWidthArr.push(e.value),e=t.next();break;case 280:s.version=e.value,e=t.next();break;case 310:s.bmpPreview??(s.bmpPreview=""),s.bmpPreview+=e.value,e=t.next();break;case 330:s.ownerBlockRecordSoftId=e.value,e=t.next();break;case 342:s.tableStyleId=e.value,e=t.next();break;case 343:s.blockRecordHandle=e.value,e=t.next();break;case 170:s.attachmentPoint=e.value,e=t.next();break;case 171:s.cells??(s.cells=[]),s.cells.push(function(n,r){let a=!1,o=!1,l={};for(;!n.isEOF()&&r.code!==0&&!o;)switch(r.code){case 171:if(a){o=!0;continue}l.cellType=r.value,a=!0,r=n.next();break;case 172:l.flagValue=r.value,r=n.next();break;case 173:l.mergedValue=r.value,r=n.next();break;case 174:l.autoFit=r.value,r=n.next();break;case 175:l.borderWidth=r.value,r=n.next();break;case 176:l.borderHeight=r.value,r=n.next();break;case 91:l.overrideFlag=r.value,r=n.next();break;case 178:l.virtualEdgeFlag=r.value,r=n.next();break;case 145:l.rotation=r.value,r=n.next();break;case 345:l.fieldObjetId=r.value,r=n.next();break;case 340:l.blockTableRecordId=r.value,r=n.next();break;case 146:l.blockScale=r.value,r=n.next();break;case 177:l.blockAttrNum=r.value,r=n.next();break;case 7:l.textStyle=r.value,r=n.next();break;case 140:l.textHeight=r.value,r=n.next();break;case 170:l.attachmentPoint=r.value,r=n.next();break;case 92:l.extendedCellFlags=r.value,r=n.next();break;case 285:l.rightBorderVisibility=!!(r.value??!0),r=n.next();break;case 286:l.bottomBorderVisibility=!!(r.value??!0),r=n.next();break;case 288:l.leftBorderVisibility=!!(r.value??!0),r=n.next();break;case 289:l.topBorderVisibility=!!(r.value??!0),r=n.next();break;case 301:(function(c,u,d){for(;d.code!==304;)switch(d.code){case 301:case 93:case 90:case 94:d=u.next();break;case 1:c.text=d.value,d=u.next();break;case 300:c.attrText=d.value,d=u.next();break;case 302:c.text=d.value?d.value:c.text,d=u.next();break;default:d=u.next()}})(l,n,r),r=n.next();break;default:return l}return a=!1,o=!1,l}(t,e)),e=t.lastReadGroup;break;default:Zc(s,e,t),e=t.next()}}return s}}function ul(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}(mn="ForEntityName")in fi?Object.defineProperty(fi,mn,{value:"ACAD_TABLE",enumerable:!0,configurable:!0,writable:!0}):fi[mn]="ACAD_TABLE";let tu=[{code:11,name:"xAxisDirection",parser:_},{code:210,name:"extrusionDirection",parser:_},{code:1,name:"text",parser:h},{code:10,name:"position",parser:_},{code:3,name:"styleName",parser:h},{code:100,name:"subclassMarker",parser:h},...V];class pl{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){ul(this,"parser",S(tu))}}ul(pl,"ForEntityName","TOLERANCE");var eu=((nt={})[nt.CREATED_BY_CURVE_FIT=1]="CREATED_BY_CURVE_FIT",nt[nt.TANGENT_DEFINED=2]="TANGENT_DEFINED",nt[nt.NOT_USED=4]="NOT_USED",nt[nt.CREATED_BY_SPLINE_FIT=8]="CREATED_BY_SPLINE_FIT",nt[nt.SPLINE_CONTROL_POINT=16]="SPLINE_CONTROL_POINT",nt[nt.FOR_POLYLINE=32]="FOR_POLYLINE",nt[nt.FOR_POLYGON=64]="FOR_POLYGON",nt[nt.POLYFACE=128]="POLYFACE",nt);let su=[{code:[335,343,344,91],name:"softPointers",isMultiple:!0,parser:h},{code:361,name:"sunId",parser:h},{code:431,name:"ambientLightColorName",parser:h},{code:421,name:"ambientLightColorInstance",parser:h},{code:63,name:"ambientLightColorIndex",parser:h},{code:142,name:"contrast",parser:h},{code:141,name:"brightness",parser:h},{code:282,name:"defaultLightingType",parser:h},{code:292,name:"isDefaultLighting",parser:O},{code:348,name:"visualStyleId",parser:h},{code:333,name:"shadePlotId",parser:h},{code:332,name:"backgroundId",parser:h},{code:61,name:"majorGridFrequency",parser:h},{code:170,name:"shadePlotMode",parser:h},{code:146,name:"elevation",parser:h},{code:79,name:"orthographicType",parser:h},{code:346,name:"ucsBaseId",parser:h},{code:345,name:"ucsId",parser:h},{code:112,name:"ucsYAxis",parser:_},{code:111,name:"ucsXAxis",parser:_},{code:110,name:"ucsOrigin",parser:_},{code:74,name:"iconFlag",parser:h},{code:71,name:"ucsPerViewport",parser:h},{code:281,name:"renderMode",parser:h},{code:1,name:"sheetName",parser:h},{code:340,name:"clippingBoundaryId",parser:h},{code:90,name:"statusBitFlags",parser:h},{code:331,name:"frozenLayerIds",isMultiple:!0,parser:h},{code:72,name:"circleZoomPercent",parser:h},{code:51,name:"viewTwistAngle",parser:h},{code:50,name:"snapAngle",parser:h},{code:45,name:"viewHeight",parser:h},{code:44,name:"backClipZ",parser:h},{code:43,name:"frontClipZ",parser:h},{code:42,name:"perspectiveLensLength",parser:h},{code:17,name:"targetPoint",parser:_},{code:16,name:"viewDirection",parser:_},{code:15,name:"gridSpacing",parser:_},{code:14,name:"snapSpacing",parser:_},{code:13,name:"snapBase",parser:_},{code:12,name:"displayCenter",parser:_},{code:69,name:"viewportId",parser:h},{code:68,name:"status",parser:h},{code:41,name:"height",parser:h},{code:40,name:"width",parser:h},{code:10,name:"viewportCenter",parser:_},{code:100,name:"subclassMarker",parser:h,pushContext:!0},...V];class bi{parseEntity(t,e){let s={};return S(su)(e,t,s),s}}function gl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}(yn="ForEntityName")in bi?Object.defineProperty(bi,yn,{value:"VIEWPORT",enumerable:!0,configurable:!0,writable:!0}):bi[yn]="VIEWPORT";let iu={brightness:50,constrast:50,fade:0},nu=[{code:14,name:"boundary",isMultiple:!0,parser:_},{code:91,name:"numberOfVertices",parser:h},{code:71,name:"boundaryType",parser:h},{code:360,name:"imageDefReactorHardId",parser:h},{code:283,name:"fade",parser:h},{code:282,name:"contrast",parser:h},{code:281,name:"brightness",parser:h},{code:280,name:"isClipping",parser:O},{code:70,name:"displayFlag",parser:h},{code:340,name:"imageDefHardId",parser:h},{code:13,name:"imageSize",parser:_},{code:12,name:"vDirection",parser:_},{code:11,name:"uDirection",parser:_},{code:10,name:"position",parser:_},{code:90,name:"classVersion",parser:h},{code:100,name:"subclassMarker",parser:h},...V];class ml{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){gl(this,"parser",S(nu,iu))}}gl(ml,"ForEntityName","WIPEOUT");(ee={})[ee.ShowImage=1]="ShowImage",ee[ee.ShowImageWhenNotAligned=2]="ShowImageWhenNotAligned",ee[ee.UseClippingBoundary=4]="UseClippingBoundary",ee[ee.Transparency=8]="Transparency";function yl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let ru=[{code:11,name:"direction",parser:_},{code:10,name:"position",parser:_},{code:100,name:"subclassMarker",parser:h},...V];class _l{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){yl(this,"parser",S(ru))}}yl(_l,"ForEntityName","XLINE");let au=0;function wl(i){if(!i)throw TypeError("entity cannot be undefined or null");i.handle||(i.handle=au++)}let ou=Object.fromEntries([hh,_i,mh,xh,bh,Ph,yi,Eh,Th,Oh,Ch,Fh,zh,Dh,xi,Wh,Hh,_h,Xh,$h,Kh,Jh,el,il,rl,ol,ll,dl,fi,ph,pl,kh,cr,bi,ml,_l].map(i=>[i.ForEntityName,new i]));function xl(i,t){let e=[];for(;!N(i,0,"EOF");){if(i.code===0){if(i.value==="ENDBLK"||i.value==="ENDSEC"){t.rewind();break}let s=ou[i.value];if(s){let n=i.value;i=t.next();let r=s.parseEntity(t,i);r.type=n,wl(r),e.push(r)}else t.debug}i=t.next()}return e}function fs(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}class _a{next(){if(!this.hasNext())return this._eof?this.debug:this.debug,{code:0,value:"EOF"};let t=parseInt(this._data[this._pointer++],10),e=wa(t,this._data[this._pointer++],this.debug),s={code:t,value:e};return N(s,0,"EOF")&&(this._eof=!0),this.lastReadGroup=s,s}peek(){if(!this.hasNext())throw this._eof?Error("Cannot call 'next' after EOF group has been read"):Error("Unexpected end of input: EOF group not read before end of file. Ended on code "+this._data[this._pointer]);let t={code:parseInt(this._data[this._pointer]),value:0};return t.value=wa(t.code,this._data[this._pointer+1],this.debug),t}rewind(t){t=t||1,this._pointer=this._pointer-2*t}hasNext(){return!this._eof&&!(this._pointer>this._data.length-2)}isEOF(){return this._eof}constructor(t,e=!1){fs(this,"_data",void 0),fs(this,"debug",void 0),fs(this,"_pointer",void 0),fs(this,"_eof",void 0),fs(this,"lastReadGroup",void 0),this._data=t,this.debug=e,this.lastReadGroup={code:0,value:0},this._pointer=0,this._eof=!1}}function wa(i,t,e=!1){return i<=9?t:i>=10&&i<=59?parseFloat(t.trim()):i>=60&&i<=99?parseInt(t.trim()):i>=100&&i<=109?t:i>=110&&i<=149?parseFloat(t.trim()):i>=160&&i<=179?parseInt(t.trim()):i>=210&&i<=239?parseFloat(t.trim()):i>=270&&i<=289?parseInt(t.trim()):i>=290&&i<=299?function(s){if(s==="0")return!1;if(s==="1")return!0;throw TypeError("String '"+s+"' cannot be cast to Boolean type")}(t.trim()):i>=300&&i<=369?t:i>=370&&i<=389?parseInt(t.trim()):i>=390&&i<=399?t:i>=400&&i<=409?parseInt(t.trim()):i>=410&&i<=419?t:i>=420&&i<=429?parseInt(t.trim()):i>=430&&i<=439?t:i>=440&&i<=459?parseInt(t.trim()):i>=460&&i<=469?parseFloat(t.trim()):i>=470&&i<=481||i===999||i>=1e3&&i<=1009?t:i>=1010&&i<=1059?parseFloat(t.trim()):i>=1060&&i<=1071?parseInt(t.trim()):t}function hu(i,t){let e=null,s={};for(;!N(i,0,"EOF")&&!N(i,0,"ENDSEC");)i.code===9?e=i.value:i.code===10?s[e]=we(t):s[e]=i.value,i=t.next();return s}let ce=[{code:100,name:"subclassMarker",parser:h},{code:330,name:"ownerObjectId",parser:h},{code:102,isMultiple:!0,parser(i,t){for(;!N(i,0,"EOF")&&!N(i,102,"}");)i=t.next()}},{code:5,name:"handle",parser:h}],lu=[{code:70,name:"flag",parser:h},{code:2,name:"appName",parser:h},{code:100,name:"subclassMarker",parser:h},...ce],cu=S(lu),du=S([{code:310,name:"bmpPreview",parser:h},{code:281,name:"scalability",parser:h},{code:280,name:"explodability",parser:h},{code:70,name:"insertionUnits",parser:h},{code:340,name:"layoutObjects",parser:h},{code:2,name:"name",parser:h},{code:100,name:"subclassMarker",parser:h},...ce]),uu=S([...lr.map(i=>({...i,parser:h})),{code:70,name:"standardFlag",parser:h},{code:2,name:"name",parser:h},{code:100,name:"subclassMarker",parser:h},{code:105,name:"handle",parser:h},...ce.filter(i=>i.code!==5)]),pu=S([{code:347,name:"materialObjectId",parser:h},{code:390,name:"plotStyleNameObjectId",parser:h},{code:370,name:"lineweight",parser:h},{code:290,name:"isPlotting",parser:O},{code:6,name:"lineType",parser:h},{code:62,name:"colorIndex",parser:h},{code:70,name:"standardFlag",parser:h},{code:2,name:"name",parser:h},{code:100,name:"subclassMarker",parser:h},...ce]),gu=S([{code:9,name:"text",parser:h},{code:45,name:"offsetY",parser:h},{code:44,name:"offsetX",parser:h},{code:50,name:"rotation",parser:h},{code:46,name:"scale",parser:h},{code:340,name:"styleObjectId",parser:h},{code:75,name:"shapeNumber",parser:h},{code:74,name:"elementTypeFlag",parser:h},{code:49,name:"elementLength",parser:h}],{elementTypeFlag:0,elementLength:0}),mu=S([{code:49,name:"pattern",parser(i,t){let e={};return gu(i,t,e),e},isMultiple:!0},{code:40,name:"totalPatternLength",parser:h},{code:73,name:"numberOfLineTypes",parser:h},{code:72,parser:h},{code:3,name:"description",parser:h},{code:70,name:"standardFlag",parser:h},{code:2,name:"name",parser:h},{code:100,name:"subclassMarker",parser:h},...ce]),yu=S([{code:1e3,name:"extendedFont",parser:h},{code:1001},{code:4,name:"bigFont",parser:h},{code:3,name:"font",parser:h},{code:42,name:"lastHeight",parser:h},{code:71,name:"textGenerationFlag",parser:h},{code:50,name:"obliqueAngle",parser:h},{code:41,name:"widthFactor",parser:h},{code:40,name:"fixedTextHeight",parser:h},{code:70,name:"standardFlag",parser:h},{code:2,name:"name",parser:h},{code:100,name:"subclassMarker",parser:h},...ce]),_u=[{code:13,name:"orthographicOrigin",parser:_},{code:71,name:"orthographicType",parser:h},{code:346,name:"baseUcsHandle",parser:h},{code:146,name:"elevation",parser:h},{code:79,name:"isOrthographic",parser:O},{code:12,name:"yAxis",parser:_},{code:11,name:"xAxis",parser:_},{code:10,name:"origin",parser:_},{code:70,name:"flag",parser:h},{code:2,name:"name",parser:h},{code:100,name:"subclassMarker",parser:h},...ce],wu=S(_u),xu=[{code:346,name:"baseUcsId",parser:h},{code:345,name:"ucsId",parser:h},{code:146,name:"elevation",parser:h},{code:79,name:"orthographicType",parser:h},{code:112,name:"ucsYAxis",parser:_},{code:111,name:"ucsXAxis",parser:_},{code:110,name:"ucsOrigin",parser:_},{code:361,name:"sunHardId",parser:h},{code:348,name:"styleHardId",parser:h},{code:334,name:"liveSectionSoftId",parser:h},{code:332,name:"backgroundSoftId",parser:h},{code:73,name:"isPlottable",parser:O},{code:72,name:"isUcsAssociated",parser:O},{code:281,name:"renderMode",parser:h},{code:71,name:"viewMode",parser:h},{code:50,name:"twistAngle",parser:h},{code:44,name:"backClippingPlane",parser:h},{code:43,name:"frontClippingPlane",parser:h},{code:42,name:"lensLength",parser:h},{code:12,name:"target",parser:_},{code:11,name:"direction",parser:_},{code:10,name:"center",parser:_},{code:41,name:"width",parser:h},{code:40,name:"height",parser:h},{code:70,name:"flag",parser:h},{code:2,name:"name",parser:h},{code:100,name:"subclassMarker",parser:h},...ce],fu=S(xu),bu=S([{code:[63,421,431],name:"ambientColor",parser:h},{code:142,name:"contrast",parser:h},{code:141,name:"brightness",parser:h},{code:282,name:"defaultLightingType",parser:h},{code:292,name:"isDefaultLightingOn",parser:O},{code:348,name:"visualStyleObjectId",parser:h},{code:333,name:"shadePlotObjectId",parser:h},{code:332,name:"backgroundObjectId",parser:h},{code:61,name:"majorGridLines",parser:h},{code:170,name:"shadePlotSetting",parser:h},{code:146,name:"elevation",parser:h},{code:79,name:"orthographicType",parser:h},{code:112,name:"ucsYAxis",parser:_},{code:111,name:"ucsXAxis",parser:_},{code:110,name:"ucsOrigin",parser:_},{code:74,name:"ucsIconSetting",parser:h},{code:71,name:"viewMode",parser:h},{code:281,name:"renderMode",parser:h},{code:1,name:"styleSheet",parser:h},{code:[331,441],name:"frozenLayers",parser:h,isMultiple:!0},{code:72,name:"circleSides",parser:h},{code:51,name:"viewTwistAngle",parser:h},{code:50,name:"snapRotationAngle",parser:h},{code:45,name:"viewHeight",parser:h},{code:44,name:"backClippingPlane",parser:h},{code:43,name:"frontClippingPlane",parser:h},{code:42,name:"lensLength",parser:h},{code:17,name:"viewTarget",parser:_},{code:16,name:"viewDirectionFromTarget",parser:_},{code:15,name:"gridSpacing",parser:_},{code:14,name:"snapSpacing",parser:_},{code:13,name:"snapBasePoint",parser:_},{code:12,name:"center",parser:_},{code:11,name:"upperRightCorner",parser:_},{code:10,name:"lowerLeftCorner",parser:_},{code:70,name:"standardFlag",parser:h},{code:2,name:"name",parser:h},{code:100,name:"subclassMarker",parser:h},...ce]),Iu={APPID:cu,BLOCK_RECORD:du,DIMSTYLE:uu,LAYER:pu,LTYPE:mu,STYLE:yu,UCS:wu,VIEW:fu,VPORT:bu},Pu=S([{code:70,name:"maxNumberOfEntries",parser:h},{code:100,name:"subclassMarker",parser:h},{code:330,name:"ownerObjectId",parser:h},{code:102,parser:jt},{code:102,parser:jt},{code:102,parser:jt},{code:360,isMultiple:!0},{code:5,name:"handle",parser:h},{code:2,name:"name",parser:h}]);function Su(i,t){var s;let e={};for(;!N(i,0,"EOF")&&!N(i,0,"ENDSEC");){if(N(i,0,"TABLE")){i=t.next();let n={entries:[]};Pu(i,t,n),e[n.name]=n}if(N(i,0)&&!N(i,0,"ENDTAB")){let n=i.value;i=t.next();let r=Iu[n];if(!r){t.debug,i=t.next();continue}let a={};r(i,t,a),(s=e[n])==null||s.entries.push(a)}i=t.next()}return e}function Eu(i,t){let e={};for(;!N(i,0,"EOF")&&!N(i,0,"ENDSEC");){if(N(i,0,"BLOCK")){let s=Au(i=t.next(),t);wl(s),s.name&&(e[s.name]=s)}i=t.next()}return e}function Au(i,t){let e={};for(;!N(i,0,"EOF");){if(N(i,0,"ENDBLK")){for(i=t.next();!N(i,0,"EOF");){if(N(i,100,"AcDbBlockEnd"))return e;i=t.next()}break}switch(i.code){case 1:e.xrefPath=i.value;break;case 2:e.name=i.value;break;case 3:e.name2=i.value;break;case 5:e.handle=i.value;break;case 8:e.layer=i.value;break;case 10:e.position=we(t);break;case 67:e.paperSpace=!!i.value&&i.value==1;break;case 70:i.value!==0&&(e.type=i.value);break;case 100:break;case 330:e.ownerHandle=i.value;break;case 0:e.entities=xl(i,t)}i=t.next()}return e}let dr=[{code:330,name:"ownerObjectId",parser:h},{code:102,parser:jt},{code:102,parser:jt},{code:102,parser:jt},{code:5,name:"handle",parser:h}],fl=[{code:333,name:"shadePlotId",parser:h},{code:149,name:"imageOriginY",parser:h},{code:148,name:"imageOriginX",parser:h},{code:147,name:"scaleFactor",parser:h},{code:78,name:"shadePlotCustomDPI",parser:h},{code:77,name:"shadePlotResolution",parser:h},{code:76,name:"shadePlotMode",parser:h},{code:75,name:"standardScaleType",parser:h},{code:7,name:"currentStyleSheet",parser:h},{code:74,name:"plotType",parser:h},{code:73,name:"plotRotation",parser:h},{code:72,name:"plotPaperUnit",parser:h},{code:70,name:"layoutFlag",parser:h},{code:143,name:"printScaleDenominator",parser:h},{code:142,name:"printScaleNumerator",parser:h},{code:141,name:"windowAreaYMax",parser:h},{code:140,name:"windowAreaXMax",parser:h},{code:49,name:"windowAreaYMin",parser:h},{code:48,name:"windowAreaXMin",parser:h},{code:47,name:"plotOriginY",parser:h},{code:46,name:"plotOriginX",parser:h},{code:45,name:"paperHeight",parser:h},{code:44,name:"paperWidth",parser:h},{code:43,name:"marginTop",parser:h},{code:42,name:"marginRight",parser:h},{code:41,name:"marginBottom",parser:h},{code:40,name:"marginLeft",parser:h},{code:6,name:"plotViewName",parser:h},{code:4,name:"paperSize",parser:h},{code:2,name:"configName",parser:h},{code:1,name:"pageSetupName",parser:h},{code:100,name:"subclassMarker",parser:h},...dr],Tu=[{code:346,name:"orthographicUcsId",parser:h},{code:345,name:"namedUcsId",parser:h},{code:331,name:"viewportId",parser:h},{code:330,name:"paperSpaceTableId",parser:h},{code:76,name:"orthographicType",parser:h},{code:17,name:"ucsYAxis",parser:_},{code:16,name:"ucsXAxis",parser:_},{code:13,name:"ucsOrigin",parser:_},{code:146,name:"elevation",parser:h},{code:15,name:"maxExtent",parser:_},{code:14,name:"minExtent",parser:_},{code:12,name:"insertionPoint",parser:_},{code:11,name:"maxLimit",parser:_},{code:10,name:"minLimit",parser:_},{code:71,name:"tabOrder",parser:h},{code:70,name:"controlFlag",parser:h},{code:1,name:"layoutName",parser:h},{code:100,name:"subclassMarker",parser:h},...fl],Mu=[{code:3,name:"entries",parser:(i,t)=>{let e={name:i.value};return(i=t.next()).code===350?e.objectSoftId=i.value:i.code===360?e.objectHardId=i.value:t.rewind(),e},isMultiple:!0},{code:281,name:"recordCloneFlag",parser:h},{code:280,name:"isHardOwned",parser:O},{code:100,name:"subclassMarker",parser:h},...dr],vu=[{code:40,name:"wcsToOCSTransform",parser:xa},{code:40,name:"ocsToWCSTransform",parser:xa},{code:41,name:"backClippingDistance",parser:h},{code:73,name:"isBackClipping",parser:O,pushContext:!0},{code:40,name:"frontClippingDistance",parser:h},{code:72,name:"isFrontClipping",parser:O,pushContext:!0},{code:71,name:"isClipBoundaryDisplayed",parser:O},{code:11,name:"position",parser:_},{code:210,name:"normal",parser:_},{code:10,name:"boundaryVertices",parser:_,isMultiple:!0},{code:70,name:"boundaryCount",parser:h},{code:100,name:"subclassMarker",parser:h},{code:100},...dr];function xa(i,t){let e=[];for(let s=0;s<3&&N(i,40);++s){let n=[];for(let r=0;r<4&&N(i,40);++r)n.push(i.value),i=t.next();e.push(n)}return t.rewind(),e}let ku=[{code:330,name:"imageDefReactorIdSoft",isMultiple:!0,parser:h},{code:90,name:"version",parser:h},{code:1,name:"fileName",parser:h},{code:10,name:"size",parser:_},{code:11,name:"sizeOfOnePixel",parser:_},{code:280,name:"isLoaded",parser:h},{code:281,name:"resolutionUnits",parser:h},{code:100,name:"subclassMarker",parser:h}],Lu={LAYOUT:Tu,PLOTSETTINGS:fl,DICTIONARY:Mu,SPATIAL_FILTER:vu,IMAGEDEF:ku};function Ou(i,t){let e=[];for(;i.code!==0||!["EOF","ENDSEC"].includes(i.value);){let s=i.value,n=Lu[s];if(i.code===0&&(n!=null&&n.length)){let r=S(n),a={name:s};r(i=t.next(),t,a)?(e.push(a),i=t.peek()):i=t.next()}else i=t.next()}return{byName:Xc(e,({name:s})=>s)}}function Ls(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}class Nu{constructor(){Ls(this,"encoding","utf-8"),Ls(this,"encodingFailureFatal",!1),Ls(this,"thumbnailImageFormat","base64")}}class Cu extends EventTarget{parseSync(t,e=!1){let s=new _a(t.split(/\r\n|\r|\n/g),e);if(!s.hasNext())throw Error("Empty file");return this.parseAll(s)}parseStream(t){let e="",s=this;return new Promise((n,r)=>{t.on("data",a=>{e+=a}),t.on("end",()=>{try{let a=e.split(/\r\n|\r|\n/g),o=new _a(a);if(!o.hasNext())throw Error("Empty file");n(s.parseAll(o))}catch(a){r(a)}}),t.on("error",a=>{r(a)})})}async parseFromUrl(t,e){let s=await fetch(t,e);if(!s.body)return null;let n=s.body.getReader(),r="";for(;;){let{done:a,value:o}=await n.read();if(a){r+=this._decoder.decode(new ArrayBuffer(0),{stream:!1});break}r+=this._decoder.decode(o,{stream:!0})}return this.parseSync(r)}parseAll(t){let e={header:{},blocks:{},entities:[],tables:{},objects:{byName:{},byTree:void 0}},s=t.next();for(;!N(s,0,"EOF");)N(s,0,"SECTION")&&(N(s=t.next(),2,"HEADER")?e.header=hu(s=t.next(),t):N(s,2,"CLASSES")?Lc(s=t.next(),t,e):N(s,2,"BLOCKS")?e.blocks=Eu(s=t.next(),t):N(s,2,"ENTITIES")?e.entities=xl(s=t.next(),t):N(s,2,"TABLES")?e.tables=Su(s=t.next(),t):N(s,2,"OBJECTS")?e.objects=Ou(s=t.next(),t):N(s,2,"THUMBNAILIMAGE")&&(e.thumbnailImage=function(n,r,a="base64"){let o,l="",c=0;for(;!N(n,0,"EOF")&&!N(n,0,"ENDSEC");)n.code===90?c=n.value:n.code===310&&(l+=n.value),n=r.next();if(a==="hex")o=l;else{let u=function(d){let g=d.length/2,p=new Uint8Array(g);for(let m=0;m<g;m++)p[m]=parseInt(d.substr(2*m,2),16);return p}(l);o=a==="buffer"?u:function(d){let g="";for(let p=0;p<d.length;p++)g+=String.fromCharCode(d[p]);return btoa(g)}(u)}return{size:c,data:o}}(s=t.next(),t,this._options.thumbnailImageFormat))),s=t.next();return e}constructor(t={}){super(),Ls(this,"_decoder",void 0),Ls(this,"_options",void 0);let e=new Nu;this._options=Object.assign(e,t),this._decoder=new TextDecoder(this._options.encoding,{fatal:this._options.encodingFailureFatal})}}(It={})[It.NOT_APPLICABLE=0]="NOT_APPLICABLE",It[It.KEEP_EXISTING=1]="KEEP_EXISTING",It[It.USE_CLONE=2]="USE_CLONE",It[It.XREF_VALUE_NAME=3]="XREF_VALUE_NAME",It[It.VALUE_NAME=4]="VALUE_NAME",It[It.UNMANGLE_NAME=5]="UNMANGLE_NAME";(Fe={})[Fe.NOUNIT=0]="NOUNIT",Fe[Fe.CENTIMETERS=2]="CENTIMETERS",Fe[Fe.INCH=5]="INCH";(xs={})[xs.PSLTSCALE=1]="PSLTSCALE",xs[xs.LIMCHECK=2]="LIMCHECK";(Re={})[Re.INCHES=0]="INCHES",Re[Re.MILLIMETERS=1]="MILLIMETERS",Re[Re.PIXELS=2]="PIXELS";(Pt={})[Pt.LAST_SCREEN_DISPLAY=0]="LAST_SCREEN_DISPLAY",Pt[Pt.DRAWING_EXTENTS=1]="DRAWING_EXTENTS",Pt[Pt.DRAWING_LIMITS=2]="DRAWING_LIMITS",Pt[Pt.VIEW_SPECIFIED=3]="VIEW_SPECIFIED",Pt[Pt.WINDOW_SPECIFIED=4]="WINDOW_SPECIFIED",Pt[Pt.LAYOUT_INFORMATION=5]="LAYOUT_INFORMATION";(se={})[se.AS_DISPLAYED=0]="AS_DISPLAYED",se[se.WIREFRAME=1]="WIREFRAME",se[se.HIDDEN=2]="HIDDEN",se[se.RENDERED=3]="RENDERED";(St={})[St.DRAFT=0]="DRAFT",St[St.PREVIEW=1]="PREVIEW",St[St.NORMAL=2]="NORMAL",St[St.PRESENTATION=3]="PRESENTATION",St[St.MAXIMUM=4]="MAXIMUM",St[St.CUSTOM=5]="CUSTOM";(ie={})[ie.NONE=0]="NONE",ie[ie.AbsoluteRotation=1]="AbsoluteRotation",ie[ie.TextEmbedded=2]="TextEmbedded",ie[ie.ShapeEmbedded=4]="ShapeEmbedded";(_n={})[_n.PaperSpace=1]="PaperSpace";(ze={})[ze.XrefDependent=16]="XrefDependent",ze[ze.XrefResolved=32]="XrefResolved",ze[ze.Referenced=64]="Referenced";(Et={})[Et.Off=0]="Off",Et[Et.Perspective=1]="Perspective",Et[Et.ClipFront=2]="ClipFront",Et[Et.ClipBack=4]="ClipBack",Et[Et.UcsFollow=8]="UcsFollow",Et[Et.ClipFrontByFrontZ=16]="ClipFrontByFrontZ";class Bu{parse(t){const e=new Cu,s=this.getDxfInfoFromBuffer(t);let n="";return s.version&&s.version.value<=23&&s.encoding?n=new TextDecoder(s.encoding).decode(t):n=new TextDecoder().decode(t),e.parseSync(n)}getDxfInfoFromBuffer(t){var c,u,d;const s=new TextDecoder("utf-8");let n=0,r="",a=null,o=null,l=!1;for(;n<t.byteLength;){const g=Math.min(n+65536,t.byteLength),p=t.slice(n,g);n=g;const y=(r+s.decode(p,{stream:!0})).split(/\r?\n/);r=y.pop()??"";for(let x=0;x<y.length;x++){const f=y[x].trim();if(f==="SECTION"&&((c=y[x+2])==null?void 0:c.trim())==="HEADER")l=!0;else if(f==="ENDSEC"&&l)return{version:a,encoding:o};if(l&&f==="$ACADVER"){const P=(u=y[x+2])==null?void 0:u.trim();P&&(a=new vt(P))}else if(l&&f==="$DWGCODEPAGE"){const P=(d=y[x+2])==null?void 0:d.trim();if(P){const I=Wn[P];o=Fa(I)}}if(a&&o)return{version:a,encoding:o}}}return{version:a,encoding:o}}}class fa{convert(t){const e=this.createEntity(t);return e&&this.processCommonAttrs(t,e),e}createEntity(t){return t.type=="3DFACE"?this.convertFace(t):t.type=="ARC"?this.convertArc(t):t.type=="ATTDEF"?this.convertAttributeDefinition(t):t.type=="ATTRIB"?this.convertAttribute(t):t.type=="CIRCLE"?this.convertCirle(t):t.type=="DIMENSION"?this.convertDimension(t):t.type=="ELLIPSE"?this.convertEllipse(t):t.type=="HATCH"?this.convertHatch(t):t.type=="IMAGE"?this.convertImage(t):t.type=="LEADER"?this.convertLeader(t):t.type=="LINE"?this.convertLine(t):t.type=="LWPOLYLINE"?this.convertLWPolyline(t):t.type=="MTEXT"?this.convertMText(t):t.type=="POLYLINE"?this.convertPolyline(t):t.type=="POINT"?this.convertPoint(t):t.type=="RAY"?this.convertRay(t):t.type=="SPLINE"?this.convertSpline(t):t.type=="ACAD_TABLE"?this.convertTable(t):t.type=="TEXT"?this.convertText(t):t.type=="SOLID"?this.convertSolid(t):t.type=="VIEWPORT"?this.convertViewport(t):t.type=="WIPEOUT"?this.convertWipeout(t):t.type=="XLINE"?this.convertXline(t):t.type=="INSERT"?this.convertBlockReference(t):null}convertFace(t){const e=new ki;return t.vertices.forEach((s,n)=>e.setVertexAt(n,s)),e}convertArc(t){const e=t.extrusionDirection??b.Z_AXIS;return new Ei(Mn(t.center,e),t.radius,v.degToRad(t.startAngle),v.degToRad(t.endAngle),e)}convertAttributeCommon(t,e){e.textString=t.text,e.height=t.textHeight,e.position.copy(t.startPoint),e.rotation=t.rotation,e.oblique=t.obliqueAngle??0,e.thickness=t.thickness,e.tag=t.tag,e.fieldLength=0,e.isInvisible=(t.attributeFlag&J.Invisible)!==0,e.isConst=(t.attributeFlag&J.Const)!==0,e.isVerifiable=(t.attributeFlag&J.Verifiable)!==0,e.isPreset=(t.attributeFlag&J.Preset)!==0,e.isReallyLocked=!!t.isReallyLocked,e.isMTextAttribute=(t.mtextFlag&zt.MultiLine)!==0,e.isConstMTextAttribute=(t.mtextFlag&zt.ConstMultiLine)!==0}convertAttribute(t){const e=new Ti;return this.convertAttributeCommon(t,e),e.styleName=t.textStyle,e.horizontalMode=t.horizontalJustification,e.verticalMode=t.verticalJustification,e.widthFactor=t.scale??1,e.lockPositionInBlock=t.lockPositionFlag,e}convertAttributeDefinition(t){const e=new Ai;return this.convertAttributeCommon(t,e),e.styleName=t.styleName,e.horizontalMode=t.halign,e.verticalMode=t.valign,e.widthFactor=t.xScale??1,e.prompt=t.prompt,e}convertCirle(t){const e=t.extrusionDirection??b.Z_AXIS;return new Mi(Mn(t.center,e),t.radius,e)}convertEllipse(t){const e=new b(t.majorAxisEndPoint),s=e.length();return new vi(t.center,t.extrusionDirection??b.Z_AXIS,e,s,s*t.axisRatio,t.startAngle,t.endAngle)}convertLine(t){const e=t.startPoint,s=t.endPoint;return new zs(new w(e.x,e.y,e.z||0),new w(s.x,s.y,s.z||0))}convertSpline(t){try{if(t.numberOfControlPoints>0&&t.numberOfKnots>0)return new Ds(t.controlPoints,t.knots,t.weights,t.degree,!!(t.flag&1));if(t.numberOfFitPoints>0)return new Ds(t.fitPoints,"Uniform",t.degree,!!(t.flag&1))}catch{}return null}convertPoint(t){const e=new Bi;return e.position=t.position,e}convertSolid(t){const e=new Ni;return t.points.forEach((s,n)=>e.setPointAt(n,s)),e.thickness=t.thickness,e}convertPolyline(t){var u;const e=!!(t.flag&1),s=!!(t.flag&8),n=!!(t.flag&16),r=!!(t.flag&64),a=!!(t.flag&32),o=[],l=[],c=[];if((u=t.vertices)==null||u.map(d=>{d.flag&eu.SPLINE_CONTROL_POINT||(r&&d.flag&128?d.flag&64?(o.push({x:d.x,y:d.y,z:d.z}),l.push(d.bulge??0)):d.faces&&d.faces.length>=3&&c.push([...d.faces]):(o.push({x:d.x,y:d.y,z:d.z}),l.push(d.bulge??0)))}),n){const d=t.meshMVertexCount,g=t.meshNVertexCount;return new Di(d,g,o,e,a)}else{if(r)return new ji(o,c);if(s){let d=Ms.SimplePoly;return t.flag&4&&(t.smoothType==ui.CUBIC?d=Ms.CubicSplinePoly:t.smoothType==ui.QUADRATIC&&(d=Ms.QuadSplinePoly)),new Si(d,o,e)}else{let d=$e.SimplePoly;return t.flag&2?d=$e.FitCurvePoly:t.flag&4&&(t.smoothType==ui.CUBIC?d=$e.CubicSplinePoly:t.smoothType==ui.QUADRATIC&&(d=$e.QuadSplinePoly)),new Pi(d,o,0,e,t.startWidth,t.endWidth,l)}}}convertLWPolyline(t){var n;const e=new Ci;e.closed=!!(t.flag&1);const s=t.constantWidth??-1;return(n=t.vertices)==null||n.forEach((r,a)=>{e.addVertexAt(a,new k(r.x,r.y),r.bulge,r.startWidth??s,r.endWidth??s)}),e}convertHatch(t){var n;const e=new Rs;if((n=t.definitionLines)==null||n.forEach(r=>{e.definitionLines.push({angle:v.degToRad(r.angle||0),base:r.base,offset:r.offset,dashLengths:r.numberOfDashLengths>0?r.dashLengths:[]})}),e.isSolidFill=t.solidFill==Pc.SolidFill,e.hatchStyle=t.hatchStyle,e.patternName=t.patternName,e.patternType=t.patternType,e.patternAngle=t.patternAngle==null?0:v.degToRad(t.patternAngle),e.patternScale=t.patternScale==null?0:t.patternScale,t.boundaryPaths.forEach(r=>{if(r.boundaryPathTypeFlag&2){const o=r,l=new Mt;l.closed=o.isClosed,o.vertices.forEach((c,u)=>{l.addVertexAt(u,{x:c.x,y:c.y,bulge:c.bulge})}),e.add(l)}else{const o=r,l=[];o.edges.forEach(u=>{if(u.type==1){const d=u;l.push(new Vt(d.start,d.end))}else if(u.type==2){const d=u;l.push(new ye(d.center,d.radius,v.degToRad(d.startAngle||0),v.degToRad(d.endAngle||0),!d.isCCW))}else if(u.type==3){const d=u;new Y().subVectors(d.end,d.center);const p=Math.sqrt(Math.pow(d.end.x,2)+Math.pow(d.end.y,2)),m=p*d.lengthOfMinorAxis;let y=v.degToRad(d.startAngle||0),x=v.degToRad(d.endAngle||0);const f=Math.atan2(d.end.y,d.end.x);d.isCCW||(y=Math.PI*2-y,x=Math.PI*2-x),l.push(new Bs({...d.center,z:0},p,m,y,x,!d.isCCW,f))}else if(u.type==4){const d=u;if(d.numberOfControlPoints>0&&d.numberOfKnots>0){const g=d.controlPoints.map(y=>({x:y.x,y:y.y,z:0}));let p=!0;const m=d.controlPoints.map(y=>(y.weight==null&&(p=!1),y.weight||1));l.push(new Dt(g,d.knots,p?m:void 0))}else if(d.numberOfFitData>0){const g=d.fitDatum.map(p=>({x:p.x,y:p.y,z:0}));l.push(new Dt(g,"Uniform"))}}});const c=Fs.buildFromEdges(l);c.length==0&&l.length>0?e.add(new Fs(l)):c.forEach(u=>e.add(u))}}),t.gradientFlag){const r=t;if(e.hatchObjectType=nr.GradientObject,e.gradientName=r.gradientName,e.gradientAngle=r.gradientRotation??0,e.gradientShift=r.gradientDefinition??0,e.gradientOneColorMode=r.gradientColorFlag==1,e.shadeTintValue=r.colorTint??0,r.gradientColors){const a=r.gradientColors.length;a>1?(e.gradientStartColor=r.gradientColors[0].rgb,e.gradientEndColor=r.gradientColors[1].rgb):a>0&&(e.gradientStartColor=r.gradientColors[0].rgb)}}return e}convertTable(t){const e=new Oi(t.name,t.rowCount,t.columnCount);return e.tableDataVersion=t.version,e.tableStyleId=t.tableStyleId,e.owningBlockRecordId=t.blockRecordHandle,t.directionVector&&(e.horizontalDirection=new b(t.directionVector)),e.attachmentPoint=t.attachmentPoint,e.position.copy(t.startPoint),e.tableValueFlag=t.tableValue,e.tableOverrideFlag=t.overrideFlag,e.borderColorOverrideFlag=t.borderColorOverrideFlag,e.borderLineweightOverrideFlag=t.borderLineWeightOverrideFlag,e.borderVisibilityOverrideFlag=t.borderVisibilityOverrideFlag,t.columnWidthArr.forEach((s,n)=>e.setColumnWidth(n,s)),t.rowHeightArr.forEach((s,n)=>e.setRowHeight(n,s)),t.cells.forEach((s,n)=>{e.setCell(n,s)}),e}convertText(t){const e=new es;return e.textString=t.text,e.styleName=t.styleName,e.height=t.textHeight,e.position.copy(t.startPoint),e.rotation=v.degToRad(t.rotation||0),e.oblique=t.obliqueAngle??0,e.thickness=t.thickness,e.horizontalMode=t.halign,e.verticalMode=t.valign,e.widthFactor=t.xScale??1,e}convertMText(t){const e=new Vs;return e.contents=t.text,t.styleName!=null&&(e.styleName=t.styleName),e.height=t.height,e.width=t.width,e.rotation=v.degToRad(t.rotation||0),e.location=t.insertionPoint,e.attachmentPoint=t.attachmentPoint,t.direction&&(e.direction=new b(t.direction)),e.drawingDirection=t.drawingDirection,e}convertLeader(t){const e=new Li;return t.vertices.forEach(s=>{e.appendVertex(s)}),e.hasArrowHead=t.isArrowheadEnabled,e.hasHookLine=t.isHooklineExists,e.isSplined=t.isSpline,e.dimensionStyle=t.styleName,e.annoType=t.leaderCreationFlag,e}convertDimension(t){if(t.subclassMarker=="AcDbAlignedDimension"){const e=t,s=new Ws(e.subDefinitionPoint1,e.subDefinitionPoint2,e.definitionPoint);return e.insertionPoint&&(s.dimBlockPosition={...e.insertionPoint,z:0}),s.rotation=v.degToRad(e.rotationAngle||0),this.processDimensionCommonAttrs(t,s),s}else if(t.subclassMarker=="AcDbRotatedDimension"){const e=t,s=new Yi(e.subDefinitionPoint1,e.subDefinitionPoint2,e.definitionPoint);return e.insertionPoint&&(s.dimBlockPosition={...e.insertionPoint,z:0}),s.rotation=v.degToRad(e.rotationAngle||0),this.processDimensionCommonAttrs(t,s),s}else if(t.subclassMarker=="AcDb3PointAngularDimension"){const e=t,s=new Gi(e.centerPoint,e.subDefinitionPoint1,e.subDefinitionPoint2,e.definitionPoint);return this.processDimensionCommonAttrs(t,s),s}else if(t.subclassMarker=="AcDbOrdinateDimension"){const e=t,s=new Ui(e.subDefinitionPoint1,e.subDefinitionPoint2);return this.processDimensionCommonAttrs(t,s),s}else if(t.subclassMarker=="AcDbRadialDimension"){const e=t,s=new Xi(e.definitionPoint,e.subDefinitionPoint,e.leaderLength);return this.processDimensionCommonAttrs(t,s),s}else if(t.subclassMarker=="AcDbDiametricDimension"){const e=t,s=new Hi(e.definitionPoint,e.subDefinitionPoint,e.leaderLength);return this.processDimensionCommonAttrs(t,s),s}return null}processImage(t,e){e.position.copy(t.position),e.brightness=t.brightness,e.contrast=t.contrast,e.fade=t.fade,e.imageSize.copy(t.imageSize),e.isShownClipped=(t.flags|4)>0,e.isImageShown=(t.flags|3)>0,e.isImageTransparent=(t.flags|8)>0,e.imageDefId=t.imageDefHandle,e.isClipped=t.isClipped,t.clippingBoundaryPath.forEach(s=>{e.clipBoundary.push(new k(s))}),e.width=Math.sqrt(t.uPixel.x**2+t.uPixel.y**2+t.uPixel.z**2)*t.imageSize.x,e.height=Math.sqrt(t.vPixel.x**2+t.vPixel.y**2+t.vPixel.z**2)*t.imageSize.y,e.rotation=Math.atan2(t.uPixel.y,t.uPixel.x)}convertImage(t){const e=new js;return this.processImage(t,e),e.clipBoundaryType=t.clippingBoundaryType,e}processWipeout(t,e){e.position.copy(t.position),e.brightness=t.brightness,e.contrast=t.contrast,e.fade=t.fade,e.imageSize.copy(t.imageSize),e.isShownClipped=(t.displayFlag|4)>0,e.isImageShown=(t.displayFlag|3)>0,e.isImageTransparent=(t.displayFlag|8)>0,e.imageDefId=t.imageDefHardId,e.isClipped=t.isClipping,t.boundary.forEach(s=>{e.clipBoundary.push(new k(s))}),e.clipBoundaryType=t.boundaryType,e.width=Math.sqrt(t.uDirection.x**2+t.uDirection.y**2+t.uDirection.z**2)*t.imageSize.x,e.height=Math.sqrt(t.vDirection.x**2+t.vDirection.y**2+t.vDirection.z**2)*t.imageSize.y,e.rotation=Math.atan2(t.uDirection.y,t.uDirection.x)}convertWipeout(t){const e=new zi;return this.processWipeout(t,e),e}convertViewport(t){const e=new Ri;return e.number=t.viewportId,e.centerPoint.copy(t.viewportCenter),e.height=t.height,e.width=t.width,e.viewCenter.copy(t.displayCenter),e.viewHeight=t.viewHeight,e}convertRay(t){const e=new Fi;return e.basePoint.copy(t.position),e.unitDir.copy(t.direction),e}convertXline(t){const e=new Vi;return e.basePoint.copy(t.position),e.unitDir.copy(t.direction),e}convertBlockReference(t){const e=new Ge(t.name);return t.insertionPoint&&e.position.copy(t.insertionPoint),e.scaleFactors.x=t.xScale||1,e.scaleFactors.y=t.yScale||1,e.scaleFactors.z=t.zScale||1,e.rotation=t.rotation!=null?v.degToRad(t.rotation):0,e.normal.copy(t.extrusionDirection??{x:0,y:0,z:1}),e}processDimensionCommonAttrs(t,e){e.dimBlockId=t.name,e.textPosition.copy(t.textPoint),e.textRotation=t.textRotation||0,t.textLineSpacingFactor&&(e.textLineSpacingFactor=t.textLineSpacingFactor),t.textLineSpacingStyle&&(e.textLineSpacingStyle=t.textLineSpacingStyle),e.dimensionStyleName=t.styleName,e.dimensionText=t.text||"",e.measurement=t.measurement,e.normal.copy(t.extrusionDirection??{x:0,y:0,z:1})}processCommonAttrs(t,e){e.layer=t.layer||"0",t.handle&&(e.objectId=t.handle.toString()),e.ownerId=t.ownerBlockRecordSoftId||"",t.lineType!=null&&(e.lineType=t.lineType),t.lineweight!=null&&(e.lineWeight=t.lineweight),t.lineTypeScale!=null&&(e.linetypeScale=t.lineTypeScale),t.color!=null&&e.color.setRGBValue(t.color),t.colorIndex!=null&&(e.color.colorIndex=t.colorIndex),t.colorName&&(e.color.colorName=t.colorName),t.isVisible!=null&&(e.visibility=!t.isVisible),t.transparency!=null&&(e.transparency=Qi.deserialize(t.transparency))}}class Fu{convertLayout(t,e){var r,a;const s=new qs;s.layoutName=t.layoutName,s.tabOrder=t.tabOrder,s.plotSettingsName=t.pageSetupName,s.plotCfgName=t.configName,s.canonicalMediaName=t.paperSize,s.plotViewName=t.plotViewName,s.currentStyleSheet=t.currentStyleSheet,s.plotPaperMargins={left:t.marginLeft,right:t.marginRight,top:t.marginTop,bottom:t.marginBottom},s.plotPaperSize.copy({x:t.paperWidth,y:t.paperHeight}),s.plotOrigin.copy({x:t.plotOriginX,y:t.plotOriginY}),s.plotWindowArea.min.copy({x:t.windowAreaXMin,y:t.windowAreaYMin}),s.plotWindowArea.max.copy({x:t.windowAreaXMax,y:t.windowAreaYMax}),s.customPrintScale={numerator:t.printScaleNumerator,denominator:t.printScaleDenominator},s.plotPaperUnits=t.plotPaperUnit,s.plotRotation=t.plotRotation,s.plotType=t.plotType,s.stdScaleType=t.standardScaleType,s.shadePlot=(()=>{switch(t.shadePlotMode){case 1:return qe.kWireframe;case 2:return qe.kHidden;case 3:return qe.kRendered;default:return qe.kAsDisplayed}})(),s.shadePlotResLevel=(()=>{switch(t.shadePlotResolution){case 1:return pe.kPreview;case 2:return pe.kNormal;case 3:return pe.kPresentation;case 4:return pe.kMaximum;case 5:return pe.kCustom;default:return pe.kDraft}})(),t.shadePlotCustomDPI!=null&&(s.shadePlotCustomDPI=t.shadePlotCustomDPI),t.shadePlotId&&(s.shadePlotId=t.shadePlotId);const n=t.layoutFlag??0;if(s.plotViewportBorders=(n&1)!==0,s.showPlotStyles=(n&2)!==0,s.plotCentered=(n&4)!==0,s.plotHidden=(n&8)!==0,s.useStandardScale=(n&16)!==0,s.plotPlotStyles=(n&32)!==0,s.scaleLineweights=(n&64)!==0,s.printLineweights=(n&128)!==0,s.drawViewportsFirst=(n&512)!==0,s.modelType=(n&1024)!==0,t.viewportId&&s.viewportArray.push(t.viewportId),t.layoutName==="Model"){const o=K.MODEL_SPACE_NAME.toUpperCase();(r=e.tables.BLOCK_RECORD)==null||r.entries.some(l=>l.name.toUpperCase()===o?(s.blockTableRecordId=l.handle,!0):!1)}else(a=e.tables.BLOCK_RECORD)==null||a.entries.some(o=>o.layoutObjects===t.handle?(s.blockTableRecordId=o.handle,!0):!1),s.blockTableRecordId||(s.blockTableRecordId=t.paperSpaceTableId);return t.minLimit&&s.limits.min.copy(t.minLimit),t.maxLimit&&s.limits.max.copy(t.maxLimit),t.minExtent&&s.extents.min.copy(t.minExtent),t.maxExtent&&s.extents.max.copy(t.maxExtent),this.processCommonAttrs(t,s),s}convertImageDef(t){const e=new Wo;return e.sourceFileName=t.fileName,this.processCommonAttrs(t,e),e}processCommonAttrs(t,e){e.objectId=t.handle,t.ownerObjectId!=null&&(e.ownerId=t.ownerObjectId)}}class bl{constructor(t){this.taskId=0,this.workers=new Map,this.pendingTasks=new Map,this.config={workerUrl:t.workerUrl,timeout:t.timeout??3e4,maxConcurrentWorkers:t.maxConcurrentWorkers??4}}async execute(t,e){const s=Date.now(),n=this.generateTaskId();try{return await this.executeInWorker(n,t,e||this.config.workerUrl)}catch(r){const a=Date.now()-s;return{success:!1,error:r instanceof Error?r.message:String(r),duration:a}}}async executeInWorker(t,e,s){const n=Date.now();return new Promise((r,a)=>{const o=this.getAvailableWorker(s),l=setTimeout(()=>{this.cleanupTask(t),this.releaseWorker(o),a(new Error(`Worker operation timed out after ${this.config.timeout}ms`))},this.config.timeout);this.pendingTasks.set(t,{resolve:d=>{clearTimeout(l),this.releaseWorker(o),r(d)},reject:d=>{clearTimeout(l),this.releaseWorker(o),a(d)},timeout:l});const c=d=>{const{id:g,success:p,data:m,error:y}=d.data;if(g!==t)return;this.cleanupTask(t);const x=Date.now()-n;r(p?{success:!0,data:m,duration:x}:{success:!1,error:y,duration:x})},u=d=>{this.cleanupTask(t),a(new Error(`Worker error: ${d.message}`))};o.addEventListener("message",c),o.addEventListener("error",u),o.postMessage({id:t,input:e})})}cleanupTask(t){const e=this.pendingTasks.get(t);e&&(clearTimeout(e.timeout),this.pendingTasks.delete(t))}generateTaskId(){return`task_${++this.taskId}_${Date.now()}`}detectWorkerSupport(){return typeof Worker<"u"}getAvailableWorker(t){for(const[s,n]of this.workers)if(!n.isBusy)return n.isBusy=!0,n.worker;if(this.workers.size<this.config.maxConcurrentWorkers){const s=new Worker(t,{type:"module"}),n=this.generateWorkerId(),r={worker:s,isBusy:!0,id:n,createdAt:new Date};return this.workers.set(n,r),s}const e=Array.from(this.workers.values()).sort((s,n)=>s.createdAt.getTime()-n.createdAt.getTime())[0];return e.isBusy=!0,e.worker}releaseWorker(t){for(const[e,s]of this.workers)if(s.worker===t){s.isBusy=!1;break}}generateWorkerId(){return`worker_${Date.now()}_${Math.random().toString(36).substr(2,9)}`}getStats(){return{totalWorkers:this.workers.size,busyWorkers:Array.from(this.workers.values()).filter(t=>t.isBusy).length,pendingTasks:this.pendingTasks.size,config:this.config}}destroy(){for(const[t,e]of this.pendingTasks)clearTimeout(e.timeout),e.reject(new Error("Framework destroyed"));this.pendingTasks.clear();for(const[t,e]of this.workers)e.worker.terminate();this.workers.clear()}}class Il{constructor(t){this.framework=new bl(t)}async execute(t,e){return this.framework.execute(t,e)}getStats(){return this.framework.getStats()}destroy(){this.framework.destroy()}}function Pl(i){return new Il(i)}class Ru{constructor(){this.setupMessageHandler()}setupMessageHandler(){self.onmessage=async t=>{const{id:e,input:s}=t.data;try{const n=await this.executeTask(s);this.sendResponse(e,!0,n)}catch(n){this.sendResponse(e,!1,void 0,n instanceof Error?n.message:String(n))}}}sendResponse(t,e,s,n){const r={id:t,success:e,data:s,error:n};self.postMessage(r)}}class Sl extends hr{constructor(t={}){super(t),t.parserWorkerUrl||(t.parserWorkerUrl="/assets/dxf-parser-worker.js")}async parse(t,e){const s=this.config,n=this.getParserWorkerTimeout(t,e);if(s.useWorker&&s.parserWorkerUrl){const r=Pl({workerUrl:s.parserWorkerUrl,timeout:n,maxConcurrentWorkers:1}),a=await r.execute(t);if(r.destroy(),a.success)return{model:a.data,data:{unknownEntityCount:0}};throw new Error(`Failed to parse drawing due to error: '${a.error}'`)}else return{model:new Bu().parse(t),data:{unknownEntityCount:0}}}getFonts(t){var r;const e=new Map,s=a=>{if(a){const o=a.lastIndexOf(".");return o>=0?a.substring(0,o).toLowerCase():a.toLowerCase()}};(r=t.tables.STYLE)==null||r.entries.forEach(a=>{const o=[];if(a.font){const l=s(a.font);l&&o.push(l)}if(a.bigFont){const l=s(a.bigFont);l&&o.push(l)}if(a.extendedFont){const l=s(a.extendedFont);l&&o.push(l)}e.set(a.name,o)});const n=new Set;return this.getFontsInBlock(t.entities,t.blocks,e,n),Array.from(n)}getFontsInBlock(t,e,s,n){const r=/\\f(.*?)\|/g;t.forEach(a=>{if(a.type=="MTEXT"){const o=a;[...o.text.matchAll(r)].forEach(u=>{n.add(u[1].toLowerCase())});const c=s.get(o.styleName);c==null||c.forEach(u=>n.add(u))}else if(a.type=="TEXT"){const o=a,l=s.get(o.styleName);l==null||l.forEach(c=>n.add(c))}else if(a.type=="INSERT"){const l=e[a.name];l&&l.entities&&this.getFontsInBlock(l.entities,e,s,n)}})}async processEntities(t,e,s,n,r){const a=new fa;let o=t.entities;const l=o.length,c=new Dn(l,100-n.value,s);this.config.convertByEntityType&&(o=this.groupAndFlattenByType(o));const u=new Map;for(let g=0;g<l;g++){const p=o[g];if(p.type==="ATTRIB"){const m=a.convert(p);if(m&&m.ownerId&&m.ownerId!=="0"){let y=u.get(m==null?void 0:m.ownerId);y==null&&(y=[],u.set(m.ownerId,y)),y.push(m)}}}const d=e.tables.blockTable.modelSpace;await c.processChunk(async(g,p)=>{let m=[],y=g<p?o[g].type:"";for(let f=g;f<p;f++){const P=o[f];if(!(P.ownerBlockRecordSoftId&&P.ownerBlockRecordSoftId!==d.objectId)&&P.type!=="ATTRIB"){const I=a.convert(P);if(I){if(this.config.convertByEntityType&&P.type!==y&&(d.appendEntity(m),m=[],y=P.type),P.type==="INSERT"){const M=u.get(I.objectId);M&&M.length>0&&M.forEach(A=>{I.appendAttributes(A)})}m.push(I)}}}d.appendEntity(m);let x=n.value+p/l*(100-n.value);x>100&&(x=100),r&&await r(x,"ENTITY","IN-PROGRESS")})}async processEntitiesInBlock(t,e,s=!1){const n=new fa,r=t.length,a=[],o=e.objectId,l=[];for(let c=0;c<r;c++){const u=t[c],d=n.convert(u);d&&(u.type==="ATTRIB"?l.push(d):(!s||u.ownerBlockRecordSoftId===o)&&a.push(d))}e.appendEntity(a),l.forEach(c=>{const u=e.getIdAt(c.ownerId);u&&u.appendAttributes(c)})}processBlocks(t,e){const s=t.blocks;for(const[n,r]of Object.entries(s)){let a=e.tables.blockTable.getAt(r.name);a||(a=new K,a.objectId=r.handle,a.name=n,a.origin.copy(r.position),e.tables.blockTable.add(a)),r.entities?this.processEntitiesInBlock(r.entities,a):a.isPaperSapce&&this.processEntitiesInBlock(t.entities,a,!0)}}processHeader(t,e){const s=t.header;s.$ACADVER&&(e.version=s.$ACADVER),e.cecolor.colorIndex=s.$CECOLOR||256,e.angBase=s.$ANGBASE||0,e.angDir=s.$ANGDIR||0,s.$AUNITS!=null&&(e.aunits=s.$AUNITS),e.celtype=s.$CELTYPE||At,e.celtscale=s.$CELTSCALE||1,e.ltscale=s.$LTSCALE||1,s.$EXTMAX&&(e.extmax=s.$EXTMAX),s.$EXTMIN&&(e.extmin=s.$EXTMIN),s.$INSUNITS!=null&&(e.insunits=s.$INSUNITS),e.osmode=s.$OSMODE||0,e.pdmode=s.$PDMODE||0,e.pdsize=s.$PDSIZE||0,e.textstyle=s.$TEXTSTYLE||tt}processBlockTables(t,e){var n;const s=(n=t.tables.BLOCK_RECORD)==null?void 0:n.entries;s&&s.length>0&&(e.tables.blockTable.removeAll(),s.forEach(r=>{const a=new K;a.objectId=r.handle,a.name=r.name,a.layoutId=r.layoutObjects,a.blockInsertUnits=r.insertionUnits,a.explodability=r.explodability,a.blockScaling=r.scalability,r.bmpPreview&&(a.bmpPreview=r.bmpPreview),e.tables.blockTable.add(a)}))}processObjects(t,e){const s=t.objects.byName,n=new Fu;if("LAYOUT"in s){const r=e.objects.layout;s.LAYOUT.forEach(a=>{const o=n.convertLayout(a,t);r.setAt(o.layoutName,o)})}if("IMAGEDEF"in s){const r=e.objects.imageDefinition;s.IMAGEDEF.forEach(a=>{const o=n.convertImageDef(a);r.setAt(o.objectId,o)})}}processViewports(t,e){var n;const s=(n=t.tables)==null?void 0:n.VPORT;if(s){this.processCommonTableAttrs(s,e.tables.viewportTable);const r=s.entries;r&&r.length>0&&r.forEach(a=>{const o=new or;this.processCommonTableEntryAttrs(a,o),a.circleSides&&(o.circleSides=a.circleSides),o.standardFlag=a.standardFlag,o.center.copy(a.center),o.lowerLeftCorner.copy(a.lowerLeftCorner),o.upperRightCorner.copy(a.upperRightCorner),a.snapBasePoint&&o.snapBase.copy(a.snapBasePoint),a.snapRotationAngle&&(o.snapAngle=a.snapRotationAngle),a.snapSpacing&&o.snapIncrements.copy(a.snapSpacing),a.majorGridLines&&(o.gridMajor=a.majorGridLines),a.gridSpacing&&o.gridIncrements.copy(a.gridSpacing),a.backgroundObjectId&&(o.backgroundObjectId=a.backgroundObjectId),o.gsView.center.copy(a.center),o.gsView.viewDirectionFromTarget.copy(a.viewDirectionFromTarget),o.gsView.viewTarget.copy(a.viewTarget),a.lensLength&&(o.gsView.lensLength=a.lensLength),a.frontClippingPlane&&(o.gsView.frontClippingPlane=a.frontClippingPlane),a.backClippingPlane&&(o.gsView.backClippingPlane=a.backClippingPlane),a.viewHeight&&(o.gsView.viewHeight=a.viewHeight),a.viewTwistAngle&&(o.gsView.viewTwistAngle=a.viewTwistAngle),a.frozenLayers&&(o.gsView.frozenLayers=a.frozenLayers),a.styleSheet&&(o.gsView.styleSheet=a.styleSheet),a.renderMode&&(o.gsView.renderMode=a.renderMode),a.viewMode&&(o.gsView.viewMode=a.viewMode),a.ucsIconSetting&&(o.gsView.ucsIconSetting=a.ucsIconSetting),a.ucsOrigin&&o.gsView.ucsOrigin.copy(a.ucsOrigin),a.ucsXAxis&&o.gsView.ucsXAxis.copy(a.ucsXAxis),a.ucsYAxis&&o.gsView.ucsYAxis.copy(a.ucsYAxis),a.orthographicType&&(o.gsView.orthographicType=a.orthographicType),a.shadePlotSetting&&(o.gsView.shadePlotSetting=a.shadePlotSetting),a.shadePlotObjectId&&(o.gsView.shadePlotObjectId=a.shadePlotObjectId),a.visualStyleObjectId&&(o.gsView.visualStyleObjectId=a.visualStyleObjectId),a.isDefaultLightingOn&&(o.gsView.isDefaultLightingOn=a.isDefaultLightingOn),a.defaultLightingType&&(o.gsView.defaultLightingType=a.defaultLightingType),a.brightness&&(o.gsView.brightness=a.brightness),a.contrast&&(o.gsView.contrast=a.contrast),a.ambientColor&&(o.gsView.ambientColor=a.ambientColor),e.tables.viewportTable.add(o)})}}processLayers(t,e){var n;const s=(n=t.tables)==null?void 0:n.LAYER;if(s){this.processCommonTableAttrs(s,e.tables.layerTable);const r=s.entries;r&&r.length>0&&r.forEach(a=>{const o=new Q;o.colorIndex=a.colorIndex;const l=new tn({name:a.name,standardFlags:a.standardFlag,linetype:a.lineType,lineWeight:a.lineweight,isOff:a.colorIndex<0,color:o,isPlottable:a.isPlotting});this.processCommonTableEntryAttrs(a,l),e.tables.layerTable.add(l)})}}processLineTypes(t,e){var n;const s=(n=t.tables)==null?void 0:n.LTYPE;if(s){this.processCommonTableAttrs(s,e.tables.linetypeTable);const r=s.entries;r&&r.length>0&&r.forEach(a=>{const o=new me(a);this.processCommonTableEntryAttrs(a,o),o.name=a.name,e.tables.linetypeTable.add(o)})}}processTextStyles(t,e){var n;const s=(n=t.tables)==null?void 0:n.STYLE;if(s){this.processCommonTableAttrs(s,e.tables.textStyleTable);const r=s.entries;r&&r.length>0&&r.forEach(a=>{const o=new en(a);this.processCommonTableEntryAttrs(a,o),e.tables.textStyleTable.add(o)})}}processDimStyles(t,e){var n;const s=(n=t.tables)==null?void 0:n.DIMSTYLE;if(s){this.processCommonTableAttrs(s,e.tables.dimStyleTable);const r=s.entries;r&&r.length>0&&r.forEach(a=>{const o={name:a.name,ownerId:a.ownerObjectId,dimpost:a.DIMPOST||"",dimapost:a.DIMAPOST||"",dimscale:a.DIMSCALE,dimasz:a.DIMASZ,dimexo:a.DIMEXO,dimdli:a.DIMDLI,dimexe:a.DIMEXE,dimrnd:a.DIMRND,dimdle:a.DIMDLE,dimtp:a.DIMTP,dimtm:a.DIMTM,dimtxt:a.DIMTXT,dimcen:a.DIMCEN,dimtsz:a.DIMTSZ,dimaltf:a.DIMALTF,dimlfac:a.DIMLFAC,dimtvp:a.DIMTVP,dimtfac:a.DIMTFAC,dimgap:a.DIMGAP,dimaltrnd:a.DIMALTRND,dimtol:a.DIMTOL==null||a.DIMTOL==0?0:1,dimlim:a.DIMLIM==null||a.DIMLIM==0?0:1,dimtih:a.DIMTIH==null||a.DIMTIH==0?0:1,dimtoh:a.DIMTOH==null||a.DIMTOH==0?0:1,dimse1:a.DIMSE1==null||a.DIMSE1==0?0:1,dimse2:a.DIMSE2==null||a.DIMSE2==0?0:1,dimtad:a.DIMTAD,dimzin:a.DIMZIN,dimazin:a.DIMAZIN,dimalt:a.DIMALT,dimaltd:a.DIMALTD,dimtofl:a.DIMTOFL,dimsah:a.DIMSAH,dimtix:a.DIMTIX,dimsoxd:a.DIMSOXD,dimclrd:a.DIMCLRD,dimclre:a.DIMCLRE,dimclrt:a.DIMCLRT,dimadec:a.DIMADEC||0,dimunit:a.DIMUNIT||2,dimdec:a.DIMDEC,dimtdec:a.DIMTDEC,dimaltu:a.DIMALTU,dimalttd:a.DIMALTTD,dimaunit:a.DIMAUNIT,dimfrac:a.DIMFRAC,dimlunit:a.DIMLUNIT,dimdsep:a.DIMDSEP?a.DIMDSEP.toString():".",dimtmove:a.DIMTMOVE||0,dimjust:a.DIMJUST,dimsd1:a.DIMSD1,dimsd2:a.DIMSD2,dimtolj:a.DIMTOLJ,dimtzin:a.DIMTZIN,dimaltz:a.DIMALTZ,dimalttz:a.DIMALTTZ,dimfit:a.DIMFIT||0,dimupt:a.DIMUPT,dimatfit:a.DIMATFIT,dimtxsty:a.DIMTXSTY||tt,dimldrblk:a.DIMLDRBLK||"",dimblk:a.DIMBLK||"",dimblk1:a.DIMBLK1||"",dimblk2:a.DIMBLK2||"",dimlwd:a.DIMLWD,dimlwe:a.DIMLWE},l=new He(o);this.processCommonTableEntryAttrs(a,l),e.tables.dimStyleTable.add(l)})}}processCommonTableAttrs(t,e){t.handle!=null&&(e.objectId=t.handle),t.ownerObjectId!=null&&(e.ownerId=t.ownerObjectId)}processCommonTableEntryAttrs(t,e){e.name="name"in t?t.name:"",t.handle!=null&&(e.objectId=t.handle),t.ownerObjectId!=null&&(e.ownerId=t.ownerObjectId)}groupAndFlattenByType(t){const e={},s=[];for(const n of t)e[n.type]||(e[n.type]=[],s.push(n.type)),e[n.type].push(n);return s.flatMap(n=>e[n])}}class El extends hr{constructor(t){super({}),this._database=t}async parse(){return{model:this._database,data:{unknownEntityCount:0}}}getFonts(){return[]}async processEntities(t,e,s,n,r){let a=t.tables.blockTable.modelSpace.newIterator().toArray();const o=a.length,l=new Dn(o,100-n.value,s);this.config.convertByEntityType&&(a=this.groupAndFlattenByType(a));const c=e.tables.blockTable.modelSpace;await l.processChunk(async(u,d)=>{let g=[],p=u<d?a[u].type:"";for(let m=u;m<d;m++){const y=a[m];this.config.convertByEntityType&&y.type!==p&&(this.triggerEvents(c,g),g=[],p=y.type),g.push(y)}if(this.triggerEvents(c,g),r){let m=n.value+d/o*(100-n.value);m>100&&(m=100),await r(m,"ENTITY","IN-PROGRESS")}})}processBlocks(){const t=this._database.tables.blockTable.newIterator();for(const e of t){const s=e.newIterator().toArray();this.triggerEvents(e,s)}}processHeader(){}processBlockTables(){}processObjects(){const t=this._database.objects.layout.newIterator();for(const s of t)this._database.events.dictObjetSet.dispatch({database:this._database,object:s,key:s.layoutName});const e=this._database.objects.imageDefinition.newIterator();for(const s of e)this._database.events.dictObjetSet.dispatch({database:this._database,object:s,key:s.objectId})}processViewports(){}processLayers(){this._database.tables.layerTable.newIterator().toArray().forEach(e=>{this._database.events.layerAppended.dispatch({database:this._database,layer:e})})}processLineTypes(){}processTextStyles(){}processDimStyles(){}groupAndFlattenByType(t){const e={},s=[];for(const n of t)e[n.type]||(e[n.type]=[],s.push(n.type)),e[n.type].push(n);return s.flatMap(n=>e[n])}triggerEvents(t,e){(t.isModelSapce||t.isPaperSapce)&&t.database.events.entityAppended.dispatch({database:t.database,entity:e})}}exports.ACAD_APPID=Pn;exports.AC_DB_SYSTEM_VARIABLE_NAMES=mc;exports.AcCmColor=Q;exports.AcCmColorMethod=E;exports.AcCmColorUtil=ue;exports.AcCmEntityColor=Tl;exports.AcCmErrors=yt;exports.AcCmEventDispatcher=Ml;exports.AcCmEventManager=Z;exports.AcCmLoader=Fl;exports.AcCmLoadingManager=ka;exports.AcCmObject=Aa;exports.AcCmPerformanceCollector=Rn;exports.AcCmTask=Ma;exports.AcCmTaskScheduler=va;exports.AcCmTransparency=Qi;exports.AcCmTransparencyMethod=ut;exports.AcDb2dPolyline=Pi;exports.AcDb2dVertex=Ln;exports.AcDb2dVertexType=Io;exports.AcDb3PointAngularDimension=Gi;exports.AcDb3dPolyline=Si;exports.AcDb3dVertex=On;exports.AcDb3dVertexType=Po;exports.AcDbAbstractViewTableRecord=ar;exports.AcDbAlignedDimension=Ws;exports.AcDbAngleUnits=jn;exports.AcDbArc=Ei;exports.AcDbArcDimension=Cn;exports.AcDbAttribute=Ti;exports.AcDbAttributeDefinition=Ai;exports.AcDbAttributeFlags=J;exports.AcDbAttributeMTextFlag=zt;exports.AcDbBaseWorker=Ru;exports.AcDbBatchProcessing=Dn;exports.AcDbBlockReference=Ge;exports.AcDbBlockScaling=Do;exports.AcDbBlockTable=Xo;exports.AcDbBlockTableRecord=K;exports.AcDbCircle=Mi;exports.AcDbCodePage=Wn;exports.AcDbCurve=rt;exports.AcDbDataGenerator=Ho;exports.AcDbDatabase=yc;exports.AcDbDatabaseConverter=hr;exports.AcDbDatabaseConverterManager=Rt;exports.AcDbDiametricDimension=Hi;exports.AcDbDictionary=ks;exports.AcDbDimArrowType=Uo;exports.AcDbDimStyleTable=Yo;exports.AcDbDimStyleTableRecord=He;exports.AcDbDimTextHorizontal=$o;exports.AcDbDimTextVertical=qo;exports.AcDbDimVerticalJustification=Qo;exports.AcDbDimZeroSuppression=Zo;exports.AcDbDimZeroSuppressionAngular=Ko;exports.AcDbDimension=oe;exports.AcDbDuplicateRecordCloning=Go;exports.AcDbDwgVersion=vt;exports.AcDbDxfCode=Fn;exports.AcDbDxfConverter=Sl;exports.AcDbDxfFiler=ba;exports.AcDbEllipse=vi;exports.AcDbEntity=gt;exports.AcDbFace=ki;exports.AcDbFileType=Es;exports.AcDbGradientPatternType=To;exports.AcDbHatch=Rs;exports.AcDbHatchObjectType=nr;exports.AcDbHatchPatternType=vs;exports.AcDbHatchStyle=Ao;exports.AcDbHostApplicationServices=Ii;exports.AcDbLayerTable=Jo;exports.AcDbLayerTableRecord=tn;exports.AcDbLayout=qs;exports.AcDbLayoutDictionary=Vo;exports.AcDbLayoutManager=jo;exports.AcDbLeader=Li;exports.AcDbLeaderAnnotationType=Mo;exports.AcDbLine=zs;exports.AcDbLineSpacingStyle=Wi;exports.AcDbLinetypeTable=th;exports.AcDbLinetypeTableRecord=me;exports.AcDbMText=Vs;exports.AcDbObject=he;exports.AcDbObjectIterator=Zs;exports.AcDbOpenMode=Ba;exports.AcDbOrdinateDimension=Ui;exports.AcDbOsnapMode=z;exports.AcDbPlotPaperUnits=Co;exports.AcDbPlotRotation=Bo;exports.AcDbPlotSettings=zo;exports.AcDbPlotShadePlotResLevel=pe;exports.AcDbPlotShadePlotType=qe;exports.AcDbPlotStdScaleType=Ro;exports.AcDbPlotType=Fo;exports.AcDbPoint=Bi;exports.AcDbPoly2dType=$e;exports.AcDbPoly3dType=Ms;exports.AcDbPolyFaceMesh=ji;exports.AcDbPolyFaceMeshFace=No;exports.AcDbPolyFaceMeshVertex=Oo;exports.AcDbPolygonMesh=Di;exports.AcDbPolygonMeshVertex=Lo;exports.AcDbPolyline=Ci;exports.AcDbRadialDimension=Xi;exports.AcDbRasterImage=js;exports.AcDbRasterImageClipBoundaryType=vo;exports.AcDbRasterImageDef=Wo;exports.AcDbRasterImageImageDisplayOpt=ko;exports.AcDbRay=Fi;exports.AcDbRegAppTable=nh;exports.AcDbRegAppTableRecord=Bn;exports.AcDbRegenerator=El;exports.AcDbRenderingCache=ss;exports.AcDbResultBuffer=Vn;exports.AcDbRotatedDimension=Yi;exports.AcDbSpline=Ds;exports.AcDbSymbolTable=le;exports.AcDbSymbolTableRecord=xe;exports.AcDbSysVarManager=Gs;exports.AcDbSystemVariables=R;exports.AcDbTable=Oi;exports.AcDbText=es;exports.AcDbTextHorizontalMode=So;exports.AcDbTextStyleTable=eh;exports.AcDbTextStyleTableRecord=en;exports.AcDbTextVerticalMode=Eo;exports.AcDbTrace=Ni;exports.AcDbUnitsValue=rr;exports.AcDbViewTable=sh;exports.AcDbViewTableRecord=xc;exports.AcDbViewport=Ri;exports.AcDbViewportTable=ih;exports.AcDbViewportTableRecord=or;exports.AcDbWipeout=zi;exports.AcDbWorkerApi=Il;exports.AcDbWorkerManager=bl;exports.AcDbXline=Vi;exports.AcDbXrecord=dc;exports.AcGeArea2d=ts;exports.AcGeBox2d=pt;exports.AcGeBox3d=C;exports.AcGeCatmullRomCurve3d=Ji;exports.AcGeCircArc2d=ye;exports.AcGeCircArc3d=je;exports.AcGeCurve2d=is;exports.AcGeEllipseArc2d=Bs;exports.AcGeEllipseArc3d=Je;exports.AcGeEuler=Hl;exports.AcGeGeometryUtil=po;exports.AcGeLine2d=Vt;exports.AcGeLine3d=_e;exports.AcGeLoop2d=Fs;exports.AcGeMathUtil=v;exports.AcGeMatrix2d=Us;exports.AcGeMatrix3d=G;exports.AcGeNurbsCurve=Bt;exports.AcGePlane=Ys;exports.AcGePoint2d=k;exports.AcGePoint3d=w;exports.AcGePolyline2d=Mt;exports.AcGeQuaternion=Ue;exports.AcGeShape2d=Jn;exports.AcGeSpline3d=Dt;exports.AcGeTol=Xs;exports.AcGeVector2d=Y;exports.AcGeVector3d=b;exports.AcGiArrowType=tr;exports.AcGiDefaultLightingType=ir;exports.AcGiLineWeight=We;exports.AcGiMTextAttachmentPoint=ot;exports.AcGiMTextFlowDirection=ae;exports.AcGiOrthographicType=sr;exports.AcGiRenderMode=er;exports.AcGiViewport=fo;exports.AcTrStringUtil=Bl;exports.ByBlock=Qe;exports.ByLayer=At;exports.DEBUG_MODE=Nl;exports.DEFAULT_LINE_TYPE=Ke;exports.DEFAULT_TEXT_STYLE=tt;exports.DEFAULT_TOL=qn;exports.DEG2RAD=Gn;exports.DefaultLoadingManager=La;exports.FLOAT_TOL=Ve;exports.MLIGHTCAD_APPID=In;exports.ORIGIN_POINT_2D=Vl;exports.ORIGIN_POINT_3D=$n;exports.RAD2DEG=Hn;exports.TAU=W;exports.TEMP_OBJECT_ID_PREFIX=pi;exports.acdbDisableOsnapMode=ic;exports.acdbEnableOsnapMode=sc;exports.acdbHasOsnapMode=ec;exports.acdbHostApplicationServices=zn;exports.acdbMaskToOsnapModes=Jl;exports.acdbOsnapModesToMask=Ql;exports.acdbToggleOsnapMode=tc;exports.basisFunction=Ns;exports.calculateCurveLength=yo;exports.ceilPowerOfTwo=Ka;exports.clamp=re;exports.clone=bs;exports.computeParameterValues=go;exports.createWorkerApi=Pl;exports.damp=Da;exports.deepClone=xn;exports.defaults=Hs;exports.degToRad=$a;exports.dwgCodePageToEncoding=Fa;exports.euclideanModulo=Un;exports.evaluateNurbsPoint=Ts;exports.floorPowerOfTwo=Qa;exports.generateAveragedKnots=mo;exports.generateChordKnots=Xl;exports.generateSqrtChordKnots=Yl;exports.generateUUID=Ra;exports.generateUniformKnots=Ul;exports.getOcsAngle=vn;exports.getOcsReferenceVector=Qn;exports.has=Ia;exports.intPartLength=Yn;exports.interpolateControlPoints=$l;exports.interpolateNurbsCurve=Kn;exports.inverseLerp=Va;exports.isBetween=Ja;exports.isBetweenAngle=to;exports.isEmpty=Pa;exports.isEqual=Ze;exports.isImperialUnits=pc;exports.isMetricUnits=uc;exports.isPointInPolygon=Zn;exports.isPolygonIntersect=uo;exports.isPowerOfTwo=Za;exports.lerp=Xn;exports.log=Ss;exports.mapLinear=za;exports.normalizeAngle=As;exports.pingpong=ja;exports.radToDeg=qa;exports.randFloat=Ua;exports.randFloatSpread=Xa;exports.randInt=Ha;exports.relativeEps=eo;exports.seededRandom=Ya;exports.setAcDbHostApplicationServicesProvider=Na;exports.setAcDbLayoutManagerFactory=Ca;exports.setLogLevel=Cl;exports.smootherstep=Ga;exports.smoothstep=Wa;exports.transformOcsPointToWcs=Mn;exports.transformWcsPointToOcs=Cs;
3
+ `}registerHandle(t){return this._handleMap.has(t)||(/^[0-9A-F]+$/i.test(t)?this._handleMap.set(t,t.toUpperCase()):(this._handleMap.set(t,this._nextHandle.toString(16).toUpperCase()),this._nextHandle+=1)),this._handleMap.get(t)}resolveHandle(t){if(t)return this.registerHandle(t)}writeGroup(t,e){if(e==null)return this;this._lines.push(String(Math.trunc(t)));const s=this.formatValue(e);return this._lines.push(s===""?"0":s),this}writeStart(t){return this.writeString(0,t)}writeSubclassMarker(t){return this.writeString(100,t)}writeString(t,e){return!e&&e!==""?this:this.writeGroup(t,e)}writeInt8(t,e){return e==null?this:this.writeGroup(t,Math.trunc(e))}writeInt16(t,e){return e==null?this:this.writeGroup(t,Math.trunc(e))}writeInt32(t,e){return e==null?this:this.writeGroup(t,Math.trunc(e))}writeInt64(t,e){return e==null?this:this.writeGroup(t,Math.trunc(e))}writeUInt16(t,e){return e==null?this:this.writeGroup(t,Math.max(0,e))}writeUInt32(t,e){return e==null?this:this.writeGroup(t,Math.max(0,e))}writeBoolean(t,e){return e==null?this:this.writeGroup(t,e?1:0)}writeBool(t,e){return this.writeBoolean(t,e)}writeDouble(t,e){return e==null||!Number.isFinite(e)?this:this.writeGroup(t,e)}writeAngle(t,e){return e==null||!Number.isFinite(e)?this:this.writeDouble(t,e*180/Math.PI)}writeHandle(t,e){const s=this.resolveHandle(e);return s?this.writeString(t,s):this}writeObjectId(t,e){return this.writeHandle(t,e)}writePoint2d(t,e){return e?(this.writeDouble(t,e.x),this.writeDouble(t+10,e.y),this):this}writePoint3d(t,e){return e?(this.writeDouble(t,e.x),this.writeDouble(t+10,e.y),this.writeDouble(t+20,e.z??0),this):this}writeVector3d(t,e){return e?(this.writeDouble(t,e.x),this.writeDouble(t+10,e.y),this.writeDouble(t+20,e.z??0),this):this}writeCmColor(t,e=62,s=420){if(!t)return this;const n=t.colorIndex;n!=null&&this.writeInt16(e,n);const r=t.RGB;return r!=null&&t.colorIndex==null&&this.writeInt32(s,r),this}writeTransparency(t,e=440){return t?this.writeInt32(e,t.serialize()):this}writeResultBuffer(t){if(!t)return this;for(const e of t)this.writeGroup(e.code,e.value);return this}startSection(t){return this.writeStart("SECTION"),this.writeString(2,t),this}endSection(){return this.writeStart("ENDSEC"),this}startTable(t){return this.writeStart("TABLE"),this.writeString(2,t),this}endTable(){return this.writeStart("ENDTAB"),this}formatValue(t){if(typeof t=="string")return this.sanitizeStringForDxfLine(t);if(typeof t=="boolean")return t?"1":"0";if(typeof t=="number"){if(!Number.isFinite(t))return"0";if(Number.isInteger(t))return String(t);const s=t.toFixed(this._precision).replace(/\.?0+$/,"");return s===""||s==="-"?"0":s}return String(t)}sanitizeStringForDxfLine(t){return t.replace(/\r\n|\r|\n/g," ").replace(/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]/g,"")}}function Qh(i,t){for(var e=0;e<t.length;e++){const s=t[e];if(typeof s!="string"&&!Array.isArray(s)){for(const n in s)if(n!=="default"&&!(n in i)){const r=Object.getOwnPropertyDescriptor(s,n);r&&Object.defineProperty(i,n,r.get?r:{enumerable:!0,get:()=>s[n]})}}}return Object.freeze(Object.defineProperty(i,Symbol.toStringTag,{value:"Module"}))}var P=(i=>(i[i.ByColor=1]="ByColor",i[i.ByACI=2]="ByACI",i[i.ByLayer=3]="ByLayer",i[i.ByBlock=4]="ByBlock",i[i.None=0]="None",i))(P||{});const wo={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074},xn=[0,16711680,16776960,65280,65535,255,16711935,16777215,8421504,12632256,16711680,16744319,13369344,13395558,10027008,10046540,8323072,8339263,4980736,4990502,16727808,16752511,13382400,13401958,10036736,10051404,8331008,8343359,4985600,4992806,16744192,16760703,13395456,13408614,10046464,10056268,8339200,8347455,4990464,4995366,16760576,16768895,13408512,13415014,10056192,10061132,8347392,8351551,4995328,4997670,16776960,16777087,13421568,13421670,10000384,10000460,8355584,8355647,5000192,5000230,12582656,14679935,10079232,11717734,7510016,8755276,6258432,7307071,3755008,4344870,8388352,12582783,6736896,10079334,5019648,7510092,4161280,6258495,2509824,3755046,4194048,10485631,3394560,8375398,2529280,6264908,2064128,5209919,1264640,3099686,65280,8388479,52224,6736998,38912,5019724,32512,4161343,19456,2509862,65343,8388511,52275,6737023,38950,5019743,32543,4161359,19475,2509871,65407,8388543,52326,6737049,38988,5019762,32575,4161375,19494,2509881,65471,8388575,52377,6737074,39026,5019781,32607,4161391,19513,2509890,65535,8388607,52428,6737100,39064,5019800,32639,4161407,19532,2509900,49151,8380415,39372,6730444,29336,5014936,24447,4157311,14668,2507340,32767,8372223,26316,6724044,19608,5010072,16255,4153215,9804,2505036,16383,8364031,13260,6717388,9880,5005208,8063,4149119,4940,2502476,255,8355839,204,6710988,152,5000344,127,4145023,76,2500172,4129023,10452991,3342540,8349388,2490520,6245528,2031743,5193599,1245260,3089996,8323327,12550143,6684876,10053324,4980888,7490712,4128895,6242175,2490444,3745356,12517631,14647295,10027212,11691724,7471256,8735896,6226047,7290751,3735628,4335180,16711935,16744447,13369548,13395660,9961624,9981080,8323199,8339327,4980812,4990540,16711871,16744415,13369497,13395634,9961586,9981061,8323167,8339311,4980793,4990530,16711807,16744383,13369446,13395609,9961548,9981042,8323135,8339295,4980774,4990521,16711743,16744351,13369395,13395583,9961510,9981023,8323103,8339279,4980755,4990511,3355443,5987163,8684676,11382189,14079702,16777215,0];let xe=class{static getColorByIndex(t){return xn[t]}static getIndexByColor(t){const e=xn.length-1;for(let s=1;s<e;++s)if(xn[s]===t)return s}static getColorByName(t){return wo[t.toLowerCase()]}static getNameByColor(t){for(const[e,s]of Object.entries(wo))if(s===t)return e}static getNameByIndex(t){const e=this.getColorByIndex(t);return this.getNameByColor(e)}},j=class le{constructor(t=P.ByLayer,e){this._colorMethod=t,this._colorMethod==P.ByColor&&e==null?this._value=16777215:this._colorMethod==P.ByACI?e==null?this._value=8:e===0?this._colorMethod=P.ByBlock:e===256?this._colorMethod=P.ByLayer:this._value=Math.max(0,Math.min(e,256)):this._value=e}get colorMethod(){return this._colorMethod}set colorMethod(t){this._colorMethod=t}get red(){const t=this.RGB;return t!=null?t>>16&255:void 0}get green(){const t=this.RGB;return t!=null?t>>8&255:void 0}get blue(){const t=this.RGB;return t!=null?t&255:void 0}get RGB(){switch(this._colorMethod){case P.ByColor:case P.ByBlock:case P.ByLayer:return this._value;case P.ByACI:return this._value?xe.getColorByIndex(this._value):this._value;default:return}}setRGB(t,e,s){const n=Math.max(0,Math.min(255,Math.round(t))),r=Math.max(0,Math.min(255,Math.round(e))),o=Math.max(0,Math.min(255,Math.round(s)));return this._value=n<<16|r<<8|o,this._colorMethod=P.ByColor,this}setRGBValue(t){return t==null||!Number.isFinite(t)?this:(this._value=t&16777215,this._colorMethod=P.ByColor,this)}setRGBFromCss(t){if(!t)return this;const e=t.trim().toLowerCase();if(e.startsWith("#")){let r=0,o=0,a=0;if(e.length===7)r=parseInt(e.substr(1,2),16),o=parseInt(e.substr(3,2),16),a=parseInt(e.substr(5,2),16);else if(e.length===4)r=parseInt(e[1]+e[1],16),o=parseInt(e[2]+e[2],16),a=parseInt(e[3]+e[3],16);else return this;return this.setRGB(r,o,a)}const s=e.match(/^rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)/);if(s){const r=parseInt(s[1],10),o=parseInt(s[2],10),a=parseInt(s[3],10);return this.setRGB(r,o,a)}const n=xe.getColorByName(t);return n!==void 0?this.setRGBValue(n):this}setScalar(t){return this.setRGB(t,t,t)}get hexColor(){const t=this.RGB;return t==null?void 0:"0x"+t.toString(16).padStart(6,"0").toUpperCase()}get cssColor(){const t=this.RGB;if(t!=null)return`rgb(${t>>16&255},${t>>8&255},${t&255})`}cssColorAlpha(t){const e=this.RGB;if(e!=null)return`rgba(${e>>16&255},${e>>8&255},${e&255},${t})`}get colorIndex(){return this._colorMethod===P.ByACI?this._value:this._colorMethod===P.ByLayer?256:this._colorMethod===P.ByBlock?0:void 0}set colorIndex(t){if(t==null)return;const e=Math.max(0,Math.min(256,Math.round(t)));e===0?(this._colorMethod=P.ByBlock,this._value=void 0):e===256?(this._colorMethod=P.ByLayer,this._value=void 0):(this._colorMethod=P.ByACI,this._value=e)}get isByColor(){return this._colorMethod===P.ByColor}get isByACI(){return this._colorMethod===P.ByACI}get isForeground(){return this._colorMethod===P.ByACI&&this._value===7}setForeground(){return this._colorMethod=P.ByACI,this._value=7,this}get isByLayer(){return this._colorMethod===P.ByLayer}setByLayer(t){return this._colorMethod=P.ByLayer,t==null?this._value=256:this._value=t,this}get isByBlock(){return this._colorMethod===P.ByBlock}setByBlock(t){return this._colorMethod=P.ByBlock,t==null?this._value=0:this._value=t,this}get colorName(){switch(this._colorMethod){case P.ByLayer:return"ByLayer";case P.ByBlock:return"ByBlock";case P.ByColor:return this._value?xe.getNameByColor(this._value):"";case P.ByACI:return this._value?xe.getNameByIndex(this._value):"";default:return}}set colorName(t){if(!t)return;const e=xe.getColorByName(t);e!==void 0&&(this._value=e,this._colorMethod=P.ByColor)}clone(){const t=new le;return t._colorMethod=this._colorMethod,t._value=this._value,t}copy(t){return this._colorMethod=t._colorMethod,this._value=t._value,this}equals(t){return this._colorMethod===t._colorMethod&&this._value===t._value}toString(){switch(this._colorMethod){case P.ByLayer:return"ByLayer";case P.ByBlock:return"ByBlock";case P.ByACI:return this._value!==void 0?String(this._value):"";case P.ByColor:return this._value?`${this.red},${this.green},${this.blue}`:"";default:return""}}static fromString(t){if(!t)return;const e=t.trim();if(/^bylayer$/i.test(e))return new le(P.ByLayer);if(/^byblock$/i.test(e))return new le(P.ByBlock);const s=e.match(/^rgb\s*:\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})$/i);if(s){const r=Number(s[1]),o=Number(s[2]),a=Number(s[3]),h=new le(P.ByColor);return h.setRGB(r,o,a),h}if(/^\d{1,3},\d{1,3},\d{1,3}$/.test(e)){const[r,o,a]=e.split(",").map(Number),h=new le(P.ByColor);return h.setRGB(r,o,a),h}if(/^\d+$/.test(e)){const r=parseInt(e,10);return new le(P.ByACI,r)}if(/^book\$/i.test(e)){const r=e.substring(e.indexOf("$")+1),o=xe.getColorByName(r);return o!=null?new le(P.ByColor,o):void 0}const n=xe.getColorByName(e);if(n!=null)return new le(P.ByColor,n)}};class Jh{constructor(t=P.ByColor,e=0){this._colorMethod=t,this._value=e}get colorMethd(){return this._colorMethod}get red(){return this._value>>16&255}set red(t){this._colorMethod=P.ByColor,this._value=this._value&65535|(t&255)<<16}get green(){return this._value>>8&255}set green(t){this._colorMethod=P.ByColor,this._value=this._value&16711935|(t&255)<<8}get blue(){return this._value&255}set blue(t){this._colorMethod=P.ByColor,this._value=this._value&16776960|t&255}setRGB(t,e,s){this._colorMethod=P.ByColor,this._value=(t&255)<<16|(e&255)<<8|s&255}get colorIndex(){return this._value}set colorIndex(t){this._colorMethod=P.ByACI,this._value=t}get layerIndex(){return this._value}set layerIndex(t){this._colorMethod=P.ByLayer,this._value=t}isByColor(){return this._colorMethod===P.ByColor}isByLayer(){return this._colorMethod===P.ByLayer}isByBlock(){return this._colorMethod===P.ByBlock}isByACI(){return this._colorMethod===P.ByACI}isNone(){return this._colorMethod===P.None}get rawValue(){return this._value}set rawValue(t){this._value=t}}const wt={get ILLEGAL_PARAMETERS(){return new ReferenceError("Illegal Parameters")},get ZERO_DIVISION(){return new Error("Zero division")},get UNRESOLVED_BOUNDARY_CONFLICT(){return new Error("Unresolved boundary conflict in boolean operation")},get INFINITE_LOOP(){return new Error("Infinite loop")},get CANNOT_INVOKE_ABSTRACT_METHOD(){return new Error("Abstract method cannot be invoked")},get OPERATION_IS_NOT_SUPPORTED(){return new Error("Operation is not supported")},get NOT_IMPLEMENTED(){return new Error("Not implemented yet")}};let tc=class{constructor(){this._listeners={}}addEventListener(t,e){this._listeners===void 0&&(this._listeners={});const s=this._listeners;s[t]===void 0&&(s[t]=[]),s[t].indexOf(e)===-1&&s[t].push(e)}hasEventListener(t,e){if(this._listeners===void 0)return!1;const s=this._listeners;return s[t]!==void 0&&s[t].indexOf(e)!==-1}removeEventListener(t,e){if(this._listeners===void 0)return;const s=this._listeners[t];if(s!==void 0){const n=s.indexOf(e);n!==-1&&s.splice(n,1)}}dispatchEvent(t){if(this._listeners===void 0)return;const e=this._listeners[t.type];if(e!==void 0){t.target=this;const s=e.slice(0);for(let n=0,r=s.length;n<r;n++)s[n].call(this,t)}}},Q=class{constructor(){this.listeners=[]}addEventListener(t){this.listeners.push(t)}removeEventListener(t){this.listeners=this.listeners.filter(e=>e!==t)}replaceEventListener(t){this.removeEventListener(t),this.addEventListener(t)}dispatch(t,...e){for(const s of this.listeners)s.call(null,t,...e)}};function Ms(i){return i===null||typeof i!="object"?i:Array.isArray(i)?[...i]:{...i}}function Nn(i){if(i===null||typeof i!="object")return i;if(i instanceof Date)return new Date(i.getTime());if(i instanceof RegExp)return new RegExp(i.source,i.flags);if(Array.isArray(i))return i.map(Nn);const t={};for(const e in i)Object.prototype.hasOwnProperty.call(i,e)&&(t[e]=Nn(i[e]));return t}function Qs(i,...t){for(const e of t)if(e)for(const s in e)Object.prototype.hasOwnProperty.call(e,s)&&i[s]===void 0&&(i[s]=e[s]);return i}function Go(i,t){return i!=null&&Object.prototype.hasOwnProperty.call(i,t)}function Uo(i){return i==null?!0:Array.isArray(i)||typeof i=="string"?i.length===0:i instanceof Map||i instanceof Set?i.size===0:typeof i=="object"?Object.keys(i).length===0:!1}function as(i,t){if(i===t)return!0;if(i==null||t==null)return i===t;if(typeof i!=typeof t)return!1;if(typeof i!="object")return i===t;if(Array.isArray(i)!==Array.isArray(t))return!1;if(Array.isArray(i)){if(i.length!==t.length)return!1;for(let n=0;n<i.length;n++)if(!as(i[n],t[n]))return!1;return!0}const e=Object.keys(i),s=Object.keys(t);if(e.length!==s.length)return!1;for(const n of e)if(!Object.prototype.hasOwnProperty.call(t,n)||!as(i[n],t[n]))return!1;return!0}var ec=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function sc(i){return i&&i.__esModule&&Object.prototype.hasOwnProperty.call(i,"default")?i.default:i}var Yo={exports:{}};(function(i){(function(t,e){i.exports?i.exports=e():t.log=e()})(ec,function(){var t=function(){},e="undefined",s=typeof window!==e&&typeof window.navigator!==e&&/Trident\/|MSIE /.test(window.navigator.userAgent),n=["trace","debug","info","warn","error"],r={},o=null;function a(y,b){var x=y[b];if(typeof x.bind=="function")return x.bind(y);try{return Function.prototype.bind.call(x,y)}catch{return function(){return Function.prototype.apply.apply(x,[y,arguments])}}}function h(){console.log&&(console.log.apply||Function.prototype.apply.apply(console.log,[console,arguments]))}function c(y){return y==="debug"&&(y="log"),typeof console===e?!1:y==="trace"&&s?h:console[y]!==void 0?a(console,y):console.log!==void 0?a(console,"log"):t}function d(){for(var y=this.getLevel(),b=0;b<n.length;b++){var x=n[b];this[x]=b<y?t:this.methodFactory(x,y,this.name)}if(this.log=this.debug,typeof console===e&&y<this.levels.SILENT)return"No console available for logging"}function u(y){return function(){typeof console!==e&&(d.call(this),this[y].apply(this,arguments))}}function p(y,b,x){return c(y)||u.apply(this,arguments)}function g(y,b){var x=this,I,S,L,A="loglevel";typeof y=="string"?A+=":"+y:typeof y=="symbol"&&(A=void 0);function H(F){var Y=(n[F]||"silent").toUpperCase();if(!(typeof window===e||!A)){try{window.localStorage[A]=Y;return}catch{}try{window.document.cookie=encodeURIComponent(A)+"="+Y+";"}catch{}}}function M(){var F;if(!(typeof window===e||!A)){try{F=window.localStorage[A]}catch{}if(typeof F===e)try{var Y=window.document.cookie,ke=encodeURIComponent(A),ve=Y.indexOf(ke+"=");ve!==-1&&(F=/^([^;]+)/.exec(Y.slice(ve+ke.length+1))[1])}catch{}return x.levels[F]===void 0&&(F=void 0),F}}function X(){if(!(typeof window===e||!A)){try{window.localStorage.removeItem(A)}catch{}try{window.document.cookie=encodeURIComponent(A)+"=; expires=Thu, 01 Jan 1970 00:00:00 UTC"}catch{}}}function R(F){var Y=F;if(typeof Y=="string"&&x.levels[Y.toUpperCase()]!==void 0&&(Y=x.levels[Y.toUpperCase()]),typeof Y=="number"&&Y>=0&&Y<=x.levels.SILENT)return Y;throw new TypeError("log.setLevel() called with invalid level: "+F)}x.name=y,x.levels={TRACE:0,DEBUG:1,INFO:2,WARN:3,ERROR:4,SILENT:5},x.methodFactory=b||p,x.getLevel=function(){return L??S??I},x.setLevel=function(F,Y){return L=R(F),Y!==!1&&H(L),d.call(x)},x.setDefaultLevel=function(F){S=R(F),M()||x.setLevel(F,!1)},x.resetLevel=function(){L=null,X(),d.call(x)},x.enableAll=function(F){x.setLevel(x.levels.TRACE,F)},x.disableAll=function(F){x.setLevel(x.levels.SILENT,F)},x.rebuild=function(){if(o!==x&&(I=R(o.getLevel())),d.call(x),o===x)for(var F in r)r[F].rebuild()},I=R(o?o.getLevel():"WARN");var et=M();et!=null&&(L=R(et)),d.call(x)}o=new g,o.getLogger=function(y){if(typeof y!="symbol"&&typeof y!="string"||y==="")throw new TypeError("You must supply a name when creating a logger.");var b=r[y];return b||(b=r[y]=new g(y,o.methodFactory)),b};var m=typeof window!==e?window.log:void 0;return o.noConflict=function(){return typeof window!==e&&window.log===o&&(window.log=m),o},o.getLoggers=function(){return r},o.default=o,o})})(Yo);var Xo=Yo.exports;const ic=sc(Xo),nc=Qh({__proto__:null,default:ic},[Xo]),rc=!0,Cs=nc;Cs.setLevel("debug");const oc=i=>{try{Cs.setLevel(i)}catch(t){Cs.setLevel("error"),Cs.error(t)}};let $o=class qo{constructor(t,e){this.events={attrChanged:new Q,modelChanged:new Q},this._changing=!1,this._previousAttributes={},this._pending=!1;const s=t||{};e&&Qs(s,e),this.attributes=s,this.changed={}}get(t){return this.attributes[t]}set(t,e,s){if(t==null)return this;let n;typeof t=="object"?(n=t,s=e):(n={},n[t]=e),s||(s={});const r=s.unset,o=s.silent,a=[],h=this._changing;this._changing=!0,h||(this._previousAttributes=Ms(this.attributes),this.changed={});const c=this.attributes,d=this.changed,u=this._previousAttributes;for(const p in n)e=n[p],as(c[p],e)||a.push(p),as(u[p],e)?delete d[p]:d[p]=e,r?delete c[p]:c[p]=e;if(!o){a.length&&(this._pending=s);for(let p=0;p<a.length;p++)this.events.attrChanged.dispatch({object:this,attrName:a[p],attrValue:c[a[p]],options:s})}if(h)return this;if(!o)for(;this._pending;)s=this._pending,this._pending=!1,this.events.modelChanged.dispatch({object:this,options:s});return this._pending=!1,this._changing=!1,this}has(t){return this.get(t)!=null}hasChanged(t){return t==null?!Uo(this.changed):Go(this.changed,t)}changedAttributes(t){if(!t)return this.hasChanged()?Ms(this.changed):{};const e=this._changing?this._previousAttributes:this.attributes,s={};for(const n in t){const r=t[n];as(e[n],r)||(s[n]=r)}return s}previous(t){return t==null||!this._previousAttributes?null:this._previousAttributes[t]}previousAttributes(){return Ms(this._previousAttributes)}clone(){const t=Ms(this.attributes);return new qo(t)}},Jn=class ks{constructor(){this.entries=new Map}static getInstance(){return ks.instance||(ks.instance=new ks),ks.instance}collect(t){this.entries.set(t.name,t)}printAll(){for(const[t,e]of this.entries);}clear(){this.entries.clear()}getAll(){return Array.from(this.entries.values())}getEntry(t){return this.entries.get(t)}remove(t){return this.entries.delete(t)}};class ac{static formatBytes(t,e=2){if(t===0)return"0 B";const s=1024,n=Math.max(0,e),r=["B","KB","MB","GB","TB"],o=Math.floor(Math.log(t)/Math.log(s)),a=t/Math.pow(s,o);return`${parseFloat(a.toFixed(n))} ${r[o]}`}}var yt=(i=>(i[i.ByLayer=0]="ByLayer",i[i.ByBlock=1]="ByBlock",i[i.ByAlpha=2]="ByAlpha",i[i.ErrorValue=3]="ErrorValue",i))(yt||{});let gn=class zt{constructor(t){t!==void 0?(this._method=yt.ByAlpha,this._alpha=zt.clampAlpha(t)):(this._method=yt.ByLayer,this._alpha=255)}get method(){return this._method}set method(t){this._method=t}get alpha(){return this._alpha}set alpha(t){this._alpha=zt.clampAlpha(t),this._method=yt.ByAlpha}get percentage(){if(this._method===yt.ByAlpha)return Math.round((1-this._alpha/255)*100)}set percentage(t){const e=Math.max(0,Math.min(100,t)),s=Math.round(255*(1-e/100));this.alpha=s}static clampAlpha(t){return Math.max(0,Math.min(255,Math.floor(t)))}get isByAlpha(){return this._method===yt.ByAlpha}get isByBlock(){return this._method===yt.ByBlock}get isByLayer(){return this._method===yt.ByLayer}get isClear(){return this.isByAlpha&&this._alpha===0}get isSolid(){return this.isByAlpha&&this._alpha===255}get isInvalid(){return this._method===yt.ErrorValue}serialize(){return this._method<<24|this._alpha}clone(){const t=new zt;return t._method=this._method,t._alpha=this._alpha,t}equals(t){return this._method===t._method&&this._alpha===t._alpha}toString(){return this.isByLayer?"ByLayer":this.isByBlock?"ByBlock":this._alpha.toString()}static fromString(t){const e=t.trim();if(/^bylayer$/i.test(e)){const r=new zt;return r._method=yt.ByLayer,r}if(/^byblock$/i.test(e)){const r=new zt;return r._method=yt.ByBlock,r}const s=Number(e);if(Number.isInteger(s)&&s>=0&&s<=255)return new zt(s);const n=new zt;return n._method=yt.ErrorValue,n}static deserialize(t){const e=t>>>24&255,s=t&255,n=Object.values(yt)[e]??yt.ErrorValue,r=new zt;return r._method=n,r._alpha=zt.clampAlpha(s),r}};class Zo{constructor(t){this.name=t}run(t){throw new Error("run() must be implemented by subclass")}}class Ko{constructor(){this.tasks=[],this.onProgress=()=>{},this.onComplete=()=>{},this.onError=()=>!1}scheduleTask(t){return new Promise((e,s)=>{const n=()=>{Promise.resolve(t()).then(e).catch(s)};typeof window<"u"&&typeof window.requestAnimationFrame=="function"?window.requestAnimationFrame(n):setTimeout(n,0)})}addTask(t){this.tasks.push(t)}setProgressCallback(t){this.onProgress=t}setCompleteCallback(t){this.onComplete=t}setErrorCallback(t){this.onError=t}async run(t){const e=this.tasks.length;let s=t;for(let n=0;n<e;n++){const r=this.tasks[n];try{s=await this.scheduleTask(async()=>{const o=await r.run(s);return this.onProgress((n+1)/e,r),o})}catch(o){if(this.onError({error:o,taskIndex:n,task:r}))return Promise.reject(o)}}this.onComplete(s)}}let Qo=class{constructor(t,e,s){this.isLoading=!1,this.itemsLoaded=0,this.itemsTotal=0,this.urlModifier=void 0,this.handlers=[],this.onStart=void 0,this.onLoad=t,this.onProgress=e,this.onError=s}itemStart(t){this.itemsTotal++,this.isLoading===!1&&this.onStart!==void 0&&this.onStart(t,this.itemsLoaded,this.itemsTotal),this.isLoading=!0}itemEnd(t){this.itemsLoaded++,this.onProgress!==void 0&&this.onProgress(t,this.itemsLoaded,this.itemsTotal),this.itemsLoaded===this.itemsTotal&&(this.isLoading=!1,this.onLoad!==void 0&&this.onLoad())}itemError(t){this.onError!==void 0&&this.onError(t)}resolveURL(t){return this.urlModifier?this.urlModifier(t):t}setURLModifier(t){return this.urlModifier=t,this}addHandler(t,e){return this.handlers.push(t,e),this}removeHandler(t){const e=this.handlers.indexOf(t);return e!==-1&&this.handlers.splice(e,2),this}getHandler(t){for(let e=0,s=this.handlers.length;e<s;e+=2){const n=this.handlers[e],r=this.handlers[e+1];if(n.global&&(n.lastIndex=0),n.test(t))return r}return null}};const Jo=new Qo;class lc{constructor(t){this.manager=t!==void 0?t:Jo,this.crossOrigin="anonymous",this.withCredentials=!1,this.path="",this.resourcePath="",this.requestHeader={}}loadAsync(t,e){return new Promise((s,n)=>{this.load(t,s,e,n)})}parse(t){}setCrossOrigin(t){return this.crossOrigin=t,this}setWithCredentials(t){return this.withCredentials=t,this}setPath(t){return this.path=t,this}setResourcePath(t){return this.resourcePath=t,this}setRequestHeader(t){return this.requestHeader=t,this}}var Ke=256,ta=[],bo=256,gi;for(;Ke--;)ta[Ke]=(Ke+256).toString(16).substring(1);function hc(i){var t=0,e=11;if(!gi||Ke+e>bo*2)for(gi="",Ke=0;t<bo;t++)gi+=ta[Math.random()*256|0];return gi.substring(Ke,Ke+++e)}const Ii="TEMP_";let Bn;function ea(i){Bn=i}class Ft{constructor(t,e){if(t=t||{},this._attrs=new $o(t,e),this._xDataMap=new Map,!this._attrs.get("objectId"))try{this._attrs.set("objectId",this.database.generateHandle())}catch{this._attrs.set("objectId",this.generateTemporaryHandle())}}generateTemporaryHandle(){return Ii+hc()}get attrs(){return this._attrs}getAttr(t){const e=this._attrs.get(t);if(e===void 0)throw new Error(`[AcDbObject] Attribute name '${t}' does't exist in this object!`);return e}getAttrWithoutException(t){return this._attrs.get(t)}setAttr(t,e){this._attrs.set(t,e)}get objectId(){return this.getAttr("objectId")}set objectId(t){this._attrs.set("objectId",t),t&&!t.startsWith(Ii)&&this.database.updateMaxHandle(t)}get isTemp(){const t=this.getAttrWithoutException("objectId");return!!t&&t.startsWith(Ii)}get ownerId(){return this.getAttr("ownerId")}set ownerId(t){this._attrs.set("ownerId",t)}get extensionDictionary(){return this.getAttrWithoutException("extensionDictionary")}set extensionDictionary(t){this._attrs.set("extensionDictionary",t)}get database(){if(this._database)return this._database;if(Bn)return Bn().workingDatabase;throw new Error("The current working database must be set before using it!")}set database(t){this._database=t}getXData(t){return this._xDataMap.get(t)}setXData(t){for(const e of t)e.code===Qn.ExtendedDataRegAppName&&this._xDataMap.set(e.value,t)}removeXData(t){this._xDataMap.delete(t)}createExtensionDictionary(){}close(){}clone(){const t=Object.create(Object.getPrototypeOf(this)),e=this,s=t;for(const n of Object.keys(e))n!=="_database"&&(s[n]=this.cloneValue(e[n]));return t.objectId=this.generateTemporaryHandle(),t}cloneValue(t){if(t==null||typeof t!="object")return t;if(t instanceof Date)return new Date(t.getTime());if(t instanceof RegExp)return new RegExp(t.source,t.flags);if(Array.isArray(t))return t.map(n=>this.cloneValue(n));if(t instanceof Map){const n=new Map;for(const[r,o]of t.entries())n.set(this.cloneValue(r),this.cloneValue(o));return n}if(t instanceof Set){const n=new Set;for(const r of t.values())n.add(this.cloneValue(r));return n}if(ArrayBuffer.isView(t)){if(t instanceof DataView)return new DataView(t.buffer.slice(0));const n=t.constructor;return new n(t)}if(t instanceof ArrayBuffer)return t.slice(0);if("clone"in t&&typeof t.clone=="function")return t.clone();const e=Object.create(Object.getPrototypeOf(t)),s=t;for(const n of Object.keys(s))e[n]=this.cloneValue(s[n]);return e}dxfOut(...t){const[e,s=!1]=t;if(e.writeHandle(5,this.objectId),e.writeObjectId(330,this.ownerId),e.writeObjectId(360,this.extensionDictionary),this.dxfOutFields(e),s)for(const n of this._xDataMap.values())e.writeResultBuffer(n);return this}dxfOutFields(t){return this}}let Rn;function sa(i){Rn=i}function tr(){return Oi.instance}const cn=class cn{constructor(){this._workingDatabase=null}get workingDatabase(){if(this._workingDatabase==null)throw new Error("The current working database must be set before using it!");return this._workingDatabase}set workingDatabase(t){this._workingDatabase=t}get layoutManager(){if(!this._layoutManager){if(!Rn)throw new Error("The layout manager factory must be registered before using it!");this._layoutManager=Rn()}return this._layoutManager}};cn.instance=new cn;let Oi=cn;ea(tr);var ia=(i=>(i.kForRead="kForRead",i.kForWrite="kForWrite",i))(ia||{});class er{constructor(t){if(this._values=[],t)for(const e of t)this._values.push({...e})}get length(){return this._values.length}at(t){return this._values[t]}add(t){this._values.push(t)}addRange(t){for(const e of t)this._values.push(e)}clear(){this._values.length=0}toArray(){return this._values.map(t=>({...t}))}clone(){return new er(this._values)}[Symbol.iterator](){return this._values[Symbol.iterator]()}}class sr{constructor(t,e,s){this._chunkSize=-1,this._minimumChunkSize=50,this._count=t,this._numerOfChunk=e<1?1:e,this._minimumChunkSize=s,this.calculateChunkSize()}get count(){return this._count}get numerOfChunk(){return this._numerOfChunk}get minimumChunkSize(){return this._minimumChunkSize}set minimumChunkSize(t){this._minimumChunkSize=t,this.calculateChunkSize()}get chunkSize(){return this._chunkSize}calculateChunkSize(){let t=this._count/this._numerOfChunk;t<this._minimumChunkSize&&(t=Math.min(this._minimumChunkSize,this._count)),this._chunkSize=t<1?this._count:Math.floor(t)}scheduleTask(t){return new Promise((e,s)=>{const n=()=>{Promise.resolve(t()).then(e).catch(s)};typeof window<"u"&&typeof window.requestAnimationFrame=="function"?window.requestAnimationFrame(n):setTimeout(n,0)})}async processChunk(t,e){if(this._count<=0){await(e==null?void 0:e());return}let s=0;const n=async()=>{const r=s,o=Math.min(s+this._chunkSize,this._count);await t(r,o),s=o,s<this._count&&await this.scheduleTask(n)};await n(),await(e==null?void 0:e())}}var Os=(i=>(i.DXF="dxf",i.DWG="dwg",i))(Os||{});class Vt{constructor(){this.events={registered:new Q,unregistered:new Q},this._converters=new Map,this.register("dxf",new Zh)}static createInstance(){return Vt._instance==null&&(Vt._instance=new Vt),this._instance}static get instance(){return Vt._instance||(Vt._instance=new Vt),Vt._instance}get fileTypes(){return this._converters.keys()}register(t,e){this._converters.set(t,e),this.events.registered.dispatch({fileType:t,converter:e})}get(t){return this._converters.get(t)}unregister(t){const e=this._converters.get(t);e&&(this._converters.delete(t),this.events.unregistered.dispatch({fileType:t,converter:e}))}}var ir=(i=>(i[i.DecimalDegrees=0]="DecimalDegrees",i[i.DegreesMinutesSeconds=1]="DegreesMinutesSeconds",i[i.Gradians=2]="Gradians",i[i.Radians=3]="Radians",i[i.SurveyorsUnits=4]="SurveyorsUnits",i))(ir||{});class es{static get instance(){return this._instance||(this._instance=new es),this._instance}constructor(){this._blocks=new Map}createKey(t,e){return`${t}_${e}`}set(t,e){return e=e.fastDeepClone(),this._blocks.set(t,e),e}get(t){let e=this._blocks.get(t);return e&&(e=e.fastDeepClone()),e}has(t){return this._blocks.has(t)}clear(){this._blocks.clear()}draw(t,e,s,n=[],r=!0,o,a){const h=[];if(e!=null){const c=this.createKey(e.name,s);let d;if(this.has(c))d=this.get(c);else{const u=e.newIterator();for(const p of u)p.color.isByBlock&&s?(fo.copy(p.color),p.color.setRGBValue(s),this.addEntity(p,h,t),p.color.copy(fo)):this.addEntity(p,h,t);d=t.group(h),d&&r&&J.name&&!J.name.startsWith("*U")&&this.set(c,d)}return d&&o&&(d.applyMatrix(o),a&&(a.x!=0||a.y!=0||a.z!=1)&&(o.setFromExtrusionDirection(a),d.applyMatrix(o))),d&&n&&n.length>0&&(d.bakeTransformToChildren(),n.forEach(u=>d.addChild(u))),d}else return t.group(h)}addEntity(t,e,s){const n=t.worldDraw(s);n&&(this.attachEntityInfo(n,t),e.push(n))}attachEntityInfo(t,e){t.objectId=e.objectId,t.ownerId=e.ownerId,t.layerName=e.layer,t.visible=e.visibility}}const fo=new j;var nr=(i=>(i[i.UTF8=0]="UTF8",i[i.US_ASCII=1]="US_ASCII",i[i.ISO_8859_1=2]="ISO_8859_1",i[i.ISO_8859_2=3]="ISO_8859_2",i[i.ISO_8859_3=4]="ISO_8859_3",i[i.ISO_8859_4=5]="ISO_8859_4",i[i.ISO_8859_5=6]="ISO_8859_5",i[i.ISO_8859_6=7]="ISO_8859_6",i[i.ISO_8859_7=8]="ISO_8859_7",i[i.ISO_8859_8=9]="ISO_8859_8",i[i.ISO_8859_9=10]="ISO_8859_9",i[i.CP437=11]="CP437",i[i.CP850=12]="CP850",i[i.CP852=13]="CP852",i[i.CP855=14]="CP855",i[i.CP857=15]="CP857",i[i.CP860=16]="CP860",i[i.CP861=17]="CP861",i[i.CP863=18]="CP863",i[i.CP864=19]="CP864",i[i.CP865=20]="CP865",i[i.CP869=21]="CP869",i[i.CP932=22]="CP932",i[i.MACINTOSH=23]="MACINTOSH",i[i.BIG5=24]="BIG5",i[i.CP949=25]="CP949",i[i.JOHAB=26]="JOHAB",i[i.CP866=27]="CP866",i[i.ANSI_1250=28]="ANSI_1250",i[i.ANSI_1251=29]="ANSI_1251",i[i.ANSI_1252=30]="ANSI_1252",i[i.GB2312=31]="GB2312",i[i.ANSI_1253=32]="ANSI_1253",i[i.ANSI_1254=33]="ANSI_1254",i[i.ANSI_1255=34]="ANSI_1255",i[i.ANSI_1256=35]="ANSI_1256",i[i.ANSI_1257=36]="ANSI_1257",i[i.ANSI_874=37]="ANSI_874",i[i.ANSI_932=38]="ANSI_932",i[i.ANSI_936=39]="ANSI_936",i[i.ANSI_949=40]="ANSI_949",i[i.ANSI_950=41]="ANSI_950",i[i.ANSI_1361=42]="ANSI_1361",i[i.UTF16=43]="UTF16",i[i.ANSI_1258=44]="ANSI_1258",i[i.UNDEFINED=255]="UNDEFINED",i))(nr||{});const cc=["utf-8","utf-8","iso-8859-1","iso-8859-2","iso-8859-3","iso-8859-4","iso-8859-5","iso-8859-6","iso-8859-7","iso-8859-8","iso-8859-9","utf-8","utf-8","utf-8","utf-8","utf-8","utf-8","utf-8","utf-8","utf-8","utf-8","utf-8","shift-jis","macintosh","big5","utf-8","utf-8","ibm866","windows-1250","windows-1251","windows-1252","gbk","windows-1253","windows-1254","windows-1255","windows-1256","windows-1257","windows-874","shift-jis","gbk","euc-kr","big5","utf-8","utf-16le","windows-1258"],na=i=>cc[i],Se="Continuous",Z="Standard",ce="Standard",de="Standard",dt="ByLayer",fe="ByBlock",Fn="mlightcad",zn="ACAD",ct=["00","01","02","03","04","05","06","07","08","09","0a","0b","0c","0d","0e","0f","10","11","12","13","14","15","16","17","18","19","1a","1b","1c","1d","1e","1f","20","21","22","23","24","25","26","27","28","29","2a","2b","2c","2d","2e","2f","30","31","32","33","34","35","36","37","38","39","3a","3b","3c","3d","3e","3f","40","41","42","43","44","45","46","47","48","49","4a","4b","4c","4d","4e","4f","50","51","52","53","54","55","56","57","58","59","5a","5b","5c","5d","5e","5f","60","61","62","63","64","65","66","67","68","69","6a","6b","6c","6d","6e","6f","70","71","72","73","74","75","76","77","78","79","7a","7b","7c","7d","7e","7f","80","81","82","83","84","85","86","87","88","89","8a","8b","8c","8d","8e","8f","90","91","92","93","94","95","96","97","98","99","9a","9b","9c","9d","9e","9f","a0","a1","a2","a3","a4","a5","a6","a7","a8","a9","aa","ab","ac","ad","ae","af","b0","b1","b2","b3","b4","b5","b6","b7","b8","b9","ba","bb","bc","bd","be","bf","c0","c1","c2","c3","c4","c5","c6","c7","c8","c9","ca","cb","cc","cd","ce","cf","d0","d1","d2","d3","d4","d5","d6","d7","d8","d9","da","db","dc","dd","de","df","e0","e1","e2","e3","e4","e5","e6","e7","e8","e9","ea","eb","ec","ed","ee","ef","f0","f1","f2","f3","f4","f5","f6","f7","f8","f9","fa","fb","fc","fd","fe","ff"];let So=1234567;const rr=Math.PI/180,or=180/Math.PI;function ra(){const i=Math.random()*4294967295|0,t=Math.random()*4294967295|0,e=Math.random()*4294967295|0,s=Math.random()*4294967295|0;return(ct[i&255]+ct[i>>8&255]+ct[i>>16&255]+ct[i>>24&255]+"-"+ct[t&255]+ct[t>>8&255]+"-"+ct[t>>16&15|64]+ct[t>>24&255]+"-"+ct[e&63|128]+ct[e>>8&255]+"-"+ct[e>>16&255]+ct[e>>24&255]+ct[s&255]+ct[s>>8&255]+ct[s>>16&255]+ct[s>>24&255]).toLowerCase()}function he(i,t,e){return Math.max(t,Math.min(e,i))}function ar(i,t){return(i%t+t)%t}function oa(i,t,e,s,n){return s+(i-t)*(n-s)/(e-t)}function aa(i,t,e){return i!==t?(e-i)/(t-i):0}function lr(i,t,e){return(1-e)*i+e*t}function la(i,t,e,s){return lr(i,t,1-Math.exp(-e*s))}function ha(i,t=1){return t-Math.abs(ar(i,t*2)-t)}function ca(i,t,e){return i<=t?0:i>=e?1:(i=(i-t)/(e-t),i*i*(3-2*i))}function da(i,t,e){return i<=t?0:i>=e?1:(i=(i-t)/(e-t),i*i*i*(i*(i*6-15)+10))}function ua(i,t){return i+Math.floor(Math.random()*(t-i+1))}function ga(i,t){return i+Math.random()*(t-i)}function pa(i){return i*(.5-Math.random())}function ma(i){i!==void 0&&(So=i);let t=So+=1831565813;return t=Math.imul(t^t>>>15,t|1),t^=t+Math.imul(t^t>>>7,t|61),((t^t>>>14)>>>0)/4294967296}function ya(i){return i*rr}function _a(i){return i*or}function xa(i){return(i&i-1)===0&&i!==0}function wa(i){return Math.pow(2,Math.ceil(Math.log(i)/Math.LN2))}function ba(i){return Math.pow(2,Math.floor(Math.log(i)/Math.LN2))}function Ns(i){const t=Math.PI*2;return(i%t+t)%t}function fa(i,t,e){return i>t&&i<e||i>e&&i<t}function Sa(i,t,e,s=!1){return i=Ns(i),t=Ns(t),e=Ns(e),s?t>e?i<=t&&i>=e:i<=t||i>=e:t<e?i>=t&&i<=e:i>=t||i<=e}function hr(i){return i=Math.abs(i),i<1?0:Math.ceil(Math.log10(Math.abs(i)+1))}function Ia(i,t=1e-7){const e=hr(i);return Math.max(Math.pow(10,e)*t,t)}const k={DEG2RAD:rr,RAD2DEG:or,generateUUID:ra,clamp:he,euclideanModulo:ar,mapLinear:oa,inverseLerp:aa,lerp:lr,damp:la,pingpong:ha,smoothstep:ca,smootherstep:da,randInt:ua,randFloat:ga,randFloatSpread:pa,seededRandom:ma,degToRad:ya,radToDeg:_a,isPowerOfTwo:xa,ceilPowerOfTwo:wa,floorPowerOfTwo:ba,normalizeAngle:Ns,isBetween:fa,isBetweenAngle:Sa,intPartLength:hr,relativeEps:Ia},Vn=class Aa{constructor(t,e){this.x=0,this.y=0;const s=+(t!==void 0)+ +(e!==void 0);if(s!==0){if(s===1&&t instanceof Array){this.x=t[0],this.y=t[1];return}if(s===1){const{x:n,y:r}=t;this.x=n,this.y=r;return}if(s===2){this.x=t,this.y=e;return}throw wt.ILLEGAL_PARAMETERS}}get width(){return this.x}set width(t){this.x=t}get height(){return this.y}set height(t){this.y=t}set(t,e){return this.x=t,this.y=e,this}setScalar(t){return this.x=t,this.y=t,this}setX(t){return this.x=t,this}setY(t){return this.y=t,this}setComponent(t,e){switch(t){case 0:this.x=e;break;case 1:this.y=e;break;default:throw new Error("index is out of range: "+t)}return this}getComponent(t){switch(t){case 0:return this.x;case 1:return this.y;default:throw new Error("index is out of range: "+t)}}clone(){return new Aa(this.x,this.y)}copy(t){return this.x=t.x,this.y=t.y,this}add(t){return this.x+=t.x,this.y+=t.y,this}addScalar(t){return this.x+=t,this.y+=t,this}addVectors(t,e){return this.x=t.x+e.x,this.y=t.y+e.y,this}addScaledVector(t,e){return this.x+=t.x*e,this.y+=t.y*e,this}sub(t){return this.x-=t.x,this.y-=t.y,this}subScalar(t){return this.x-=t,this.y-=t,this}subVectors(t,e){return this.x=t.x-e.x,this.y=t.y-e.y,this}multiply(t){return this.x*=t.x,this.y*=t.y,this}multiplyScalar(t){return this.x*=t,this.y*=t,this}divide(t){return this.x/=t.x,this.y/=t.y,this}divideScalar(t){return this.multiplyScalar(1/t)}applyMatrix2d(t){const e=this.x,s=this.y,n=t.elements;return this.x=n[0]*e+n[3]*s+n[6],this.y=n[1]*e+n[4]*s+n[7],this}min(t){return this.x=Math.min(this.x,t.x),this.y=Math.min(this.y,t.y),this}max(t){return this.x=Math.max(this.x,t.x),this.y=Math.max(this.y,t.y),this}clamp(t,e){return this.x=Math.max(t.x,Math.min(e.x,this.x)),this.y=Math.max(t.y,Math.min(e.y,this.y)),this}clampScalar(t,e){return this.x=Math.max(t,Math.min(e,this.x)),this.y=Math.max(t,Math.min(e,this.y)),this}clampLength(t,e){const s=this.length();return this.divideScalar(s||1).multiplyScalar(Math.max(t,Math.min(e,s)))}floor(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this}ceil(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this}round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this}roundToZero(){return this.x=Math.trunc(this.x),this.y=Math.trunc(this.y),this}negate(){return this.x=-this.x,this.y=-this.y,this}dot(t){return this.x*t.x+this.y*t.y}cross(t){return this.x*t.y-this.y*t.x}lengthSq(){return this.x*this.x+this.y*this.y}length(){return Math.sqrt(this.x*this.x+this.y*this.y)}manhattanLength(){return Math.abs(this.x)+Math.abs(this.y)}normalize(){return this.divideScalar(this.length()||1)}angle(){return Math.atan2(-this.y,-this.x)+Math.PI}angleTo(t){const e=Math.sqrt(this.lengthSq()*t.lengthSq());if(e===0)return Math.PI/2;const s=this.dot(t)/e;return Math.acos(Math.max(-1,Math.min(1,s)))}distanceTo(t){return Math.sqrt(this.distanceToSquared(t))}distanceToSquared(t){const e=this.x-t.x,s=this.y-t.y;return e*e+s*s}manhattanDistanceTo(t){return Math.abs(this.x-t.x)+Math.abs(this.y-t.y)}setLength(t){return this.normalize().multiplyScalar(t)}lerp(t,e){return this.x+=(t.x-this.x)*e,this.y+=(t.y-this.y)*e,this}lerpVectors(t,e,s){return this.x=t.x+(e.x-t.x)*s,this.y=t.y+(e.y-t.y)*s,this}equals(t){return t.x===this.x&&t.y===this.y}fromArray(t,e=0){return this.x=t[e],this.y=t[e+1],this}toArray(t=[],e=0){return t[e]=this.x,t[e+1]=this.y,t}rotateAround(t,e){const s=Math.cos(e),n=Math.sin(e),r=this.x-t.x,o=this.y-t.y;return this.x=r*s-o*n+t.x,this.y=r*n+o*s+t.y,this}random(){return this.x=Math.random(),this.y=Math.random(),this}relativeEps(t=1e-7){return Math.min(k.relativeEps(this.x,t),k.relativeEps(this.y,t))}*[Symbol.iterator](){yield this.x,yield this.y}};Vn.EMPTY=Object.freeze(new Vn(0,0));let $=Vn;const Dn=class Pa{constructor(t,e,s,n,r,o,a,h,c){this.elements=[1,0,0,0,1,0,0,0,1],t!=null&&e!=null&&s!=null&&n!=null&&r!=null&&o!=null&&a!=null&&h!=null&&c!=null&&this.set(t,e,s,n,r,o,a,h,c)}set(t,e,s,n,r,o,a,h,c){const d=this.elements;return d[0]=t,d[1]=n,d[2]=a,d[3]=e,d[4]=r,d[5]=h,d[6]=s,d[7]=o,d[8]=c,this}identity(){return this.set(1,0,0,0,1,0,0,0,1),this}copy(t){const e=this.elements,s=t.elements;return e[0]=s[0],e[1]=s[1],e[2]=s[2],e[3]=s[3],e[4]=s[4],e[5]=s[5],e[6]=s[6],e[7]=s[7],e[8]=s[8],this}extractBasis(t,e,s){return t.setFromMatrix3Column(this,0),e.setFromMatrix3Column(this,1),s.setFromMatrix3Column(this,2),this}setFromMatrix4(t){const e=t.elements;return this.set(e[0],e[4],e[8],e[1],e[5],e[9],e[2],e[6],e[10]),this}multiply(t){return this.multiplyMatrices(this,t)}premultiply(t){return this.multiplyMatrices(t,this)}multiplyMatrices(t,e){const s=t.elements,n=e.elements,r=this.elements,o=s[0],a=s[3],h=s[6],c=s[1],d=s[4],u=s[7],p=s[2],g=s[5],m=s[8],y=n[0],b=n[3],x=n[6],I=n[1],S=n[4],L=n[7],A=n[2],H=n[5],M=n[8];return r[0]=o*y+a*I+h*A,r[3]=o*b+a*S+h*H,r[6]=o*x+a*L+h*M,r[1]=c*y+d*I+u*A,r[4]=c*b+d*S+u*H,r[7]=c*x+d*L+u*M,r[2]=p*y+g*I+m*A,r[5]=p*b+g*S+m*H,r[8]=p*x+g*L+m*M,this}multiplyScalar(t){const e=this.elements;return e[0]*=t,e[3]*=t,e[6]*=t,e[1]*=t,e[4]*=t,e[7]*=t,e[2]*=t,e[5]*=t,e[8]*=t,this}determinant(){const t=this.elements,e=t[0],s=t[1],n=t[2],r=t[3],o=t[4],a=t[5],h=t[6],c=t[7],d=t[8];return e*o*d-e*a*c-s*r*d+s*a*h+n*r*c-n*o*h}invert(){const t=this.elements,e=t[0],s=t[1],n=t[2],r=t[3],o=t[4],a=t[5],h=t[6],c=t[7],d=t[8],u=d*o-a*c,p=a*h-d*r,g=c*r-o*h,m=e*u+s*p+n*g;if(m===0)return this.set(0,0,0,0,0,0,0,0,0);const y=1/m;return t[0]=u*y,t[1]=(n*c-d*s)*y,t[2]=(a*s-n*o)*y,t[3]=p*y,t[4]=(d*e-n*h)*y,t[5]=(n*r-a*e)*y,t[6]=g*y,t[7]=(s*h-c*e)*y,t[8]=(o*e-s*r)*y,this}transpose(){let t;const e=this.elements;return t=e[1],e[1]=e[3],e[3]=t,t=e[2],e[2]=e[6],e[6]=t,t=e[5],e[5]=e[7],e[7]=t,this}getNormalMatrix(t){return this.setFromMatrix4(t).invert().transpose()}transposeIntoArray(t){const e=this.elements;return t.elements[0]=e[0],t.elements[1]=e[3],t.elements[2]=e[6],t.elements[3]=e[1],t.elements[4]=e[4],t.elements[5]=e[7],t.elements[6]=e[2],t.elements[7]=e[5],t.elements[8]=e[8],this}setUvTransform(t,e,s,n,r,o,a){const h=Math.cos(r),c=Math.sin(r);return this.set(s*h,s*c,-s*(h*o+c*a)+o+t,-n*c,n*h,-n*(-c*o+h*a)+a+e,0,0,1),this}scale(t,e){return this.premultiply(wn.makeScale(t,e)),this}rotate(t){return this.premultiply(wn.makeRotation(-t)),this}translate(t,e){return this.premultiply(wn.makeTranslation(t,e)),this}makeTranslation(t,e){return t instanceof $?this.set(1,0,t.x,0,1,t.y,0,0,1):this.set(1,0,t,0,1,e,0,0,1),this}makeRotation(t){const e=Math.cos(t),s=Math.sin(t);return this.set(e,-s,0,s,e,0,0,0,1),this}makeScale(t,e){return this.set(t,0,0,0,e,0,0,0,1),this}equals(t){const e=this.elements,s=t.elements;for(let n=0;n<9;n++)if(e[n]!==s[n])return!1;return!0}fromArray(t,e=0){for(let s=0;s<9;s++)this.elements[s]=t[s+e];return this}toArray(t=[],e=0){const s=this.elements;return t[e]=s[0],t[e+1]=s[1],t[e+2]=s[2],t[e+3]=s[3],t[e+4]=s[4],t[e+5]=s[5],t[e+6]=s[6],t[e+7]=s[7],t[e+8]=s[8],t}clone(){return new Pa().fromArray(this.elements)}};Dn.IDENTITY=Object.freeze(new Dn);let Js=Dn;const wn=new Js,qe=1e-6,G=2*Math.PI,dc={x:0,y:0},cr={x:0,y:0,z:0};class ti{constructor(){this.equalPointTol=qe,this.equalVectorTol=qe}clone(){const t=new ti;return t.equalPointTol=this.equalPointTol,t.equalVectorTol=this.equalVectorTol,t}equalPoint2d(t,e){return new $(t).sub(e).length()<this.equalPointTol}equalPoint3d(t,e){return new _(t).sub(e).length()<this.equalPointTol}static equalToZero(t,e=qe){return t<e&&t>-e}static equal(t,e,s=qe){return Math.abs(t-e)<s}static great(t,e,s=qe){return t-e>s}static less(t,e,s=qe){return t-e<s}}const dr=new ti;class ss{constructor(t=0,e=0,s=0,n=1){this._x=t,this._y=e,this._z=s,this._w=n}static slerpFlat(t,e,s,n,r,o,a){let h=s[n+0],c=s[n+1],d=s[n+2],u=s[n+3];const p=r[o+0],g=r[o+1],m=r[o+2],y=r[o+3];if(a===0){t[e+0]=h,t[e+1]=c,t[e+2]=d,t[e+3]=u;return}if(a===1){t[e+0]=p,t[e+1]=g,t[e+2]=m,t[e+3]=y;return}if(u!==y||h!==p||c!==g||d!==m){let b=1-a;const x=h*p+c*g+d*m+u*y,I=x>=0?1:-1,S=1-x*x;if(S>Number.EPSILON){const A=Math.sqrt(S),H=Math.atan2(A,x*I);b=Math.sin(b*H)/A,a=Math.sin(a*H)/A}const L=a*I;if(h=h*b+p*L,c=c*b+g*L,d=d*b+m*L,u=u*b+y*L,b===1-a){const A=1/Math.sqrt(h*h+c*c+d*d+u*u);h*=A,c*=A,d*=A,u*=A}}t[e]=h,t[e+1]=c,t[e+2]=d,t[e+3]=u}static multiplyQuaternionsFlat(t,e,s,n,r,o){const a=s[n],h=s[n+1],c=s[n+2],d=s[n+3],u=r[o],p=r[o+1],g=r[o+2],m=r[o+3];return t[e]=a*m+d*u+h*g-c*p,t[e+1]=h*m+d*p+c*u-a*g,t[e+2]=c*m+d*g+a*p-h*u,t[e+3]=d*m-a*u-h*p-c*g,t}get x(){return this._x}set x(t){this._x=t,this._onChangeCallback()}get y(){return this._y}set y(t){this._y=t,this._onChangeCallback()}get z(){return this._z}set z(t){this._z=t,this._onChangeCallback()}get w(){return this._w}set w(t){this._w=t,this._onChangeCallback()}set(t,e,s,n){return this._x=t,this._y=e,this._z=s,this._w=n,this._onChangeCallback(),this}clone(){return new ss(this._x,this._y,this._z,this._w)}copy(t){return this._x=t.x,this._y=t.y,this._z=t.z,this._w=t.w,this._onChangeCallback(),this}setFromEuler(t,e=!0){const s=t.x,n=t.y,r=t.z,o=t.order,a=Math.cos,h=Math.sin,c=a(s/2),d=a(n/2),u=a(r/2),p=h(s/2),g=h(n/2),m=h(r/2);switch(o){case"XYZ":this._x=p*d*u+c*g*m,this._y=c*g*u-p*d*m,this._z=c*d*m+p*g*u,this._w=c*d*u-p*g*m;break;case"YXZ":this._x=p*d*u+c*g*m,this._y=c*g*u-p*d*m,this._z=c*d*m-p*g*u,this._w=c*d*u+p*g*m;break;case"ZXY":this._x=p*d*u-c*g*m,this._y=c*g*u+p*d*m,this._z=c*d*m+p*g*u,this._w=c*d*u-p*g*m;break;case"ZYX":this._x=p*d*u-c*g*m,this._y=c*g*u+p*d*m,this._z=c*d*m-p*g*u,this._w=c*d*u+p*g*m;break;case"YZX":this._x=p*d*u+c*g*m,this._y=c*g*u+p*d*m,this._z=c*d*m-p*g*u,this._w=c*d*u-p*g*m;break;case"XZY":this._x=p*d*u-c*g*m,this._y=c*g*u-p*d*m,this._z=c*d*m+p*g*u,this._w=c*d*u+p*g*m;break}return e===!0&&this._onChangeCallback(),this}setFromAxisAngle(t,e){const s=e/2,n=Math.sin(s);return this._x=t.x*n,this._y=t.y*n,this._z=t.z*n,this._w=Math.cos(s),this._onChangeCallback(),this}setFromRotationMatrix(t){const e=t.elements,s=e[0],n=e[4],r=e[8],o=e[1],a=e[5],h=e[9],c=e[2],d=e[6],u=e[10],p=s+a+u;if(p>0){const g=.5/Math.sqrt(p+1);this._w=.25/g,this._x=(d-h)*g,this._y=(r-c)*g,this._z=(o-n)*g}else if(s>a&&s>u){const g=2*Math.sqrt(1+s-a-u);this._w=(d-h)/g,this._x=.25*g,this._y=(n+o)/g,this._z=(r+c)/g}else if(a>u){const g=2*Math.sqrt(1+a-s-u);this._w=(r-c)/g,this._x=(n+o)/g,this._y=.25*g,this._z=(h+d)/g}else{const g=2*Math.sqrt(1+u-s-a);this._w=(o-n)/g,this._x=(r+c)/g,this._y=(h+d)/g,this._z=.25*g}return this._onChangeCallback(),this}setFromUnitVectors(t,e){let s=t.dot(e)+1;return s<Number.EPSILON?(s=0,Math.abs(t.x)>Math.abs(t.z)?(this._x=-t.y,this._y=t.x,this._z=0,this._w=s):(this._x=0,this._y=-t.z,this._z=t.y,this._w=s)):(this._x=t.y*e.z-t.z*e.y,this._y=t.z*e.x-t.x*e.z,this._z=t.x*e.y-t.y*e.x,this._w=s),this.normalize()}angleTo(t){return 2*Math.acos(Math.abs(he(this.dot(t),-1,1)))}rotateTowards(t,e){const s=this.angleTo(t);if(s===0)return this;const n=Math.min(1,e/s);return this.slerp(t,n),this}identity(){return this.set(0,0,0,1)}invert(){return this.conjugate()}conjugate(){return this._x*=-1,this._y*=-1,this._z*=-1,this._onChangeCallback(),this}dot(t){return this._x*t._x+this._y*t._y+this._z*t._z+this._w*t._w}lengthSq(){return this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w}length(){return Math.sqrt(this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w)}normalize(){let t=this.length();return t===0?(this._x=0,this._y=0,this._z=0,this._w=1):(t=1/t,this._x=this._x*t,this._y=this._y*t,this._z=this._z*t,this._w=this._w*t),this._onChangeCallback(),this}multiply(t){return this.multiplyQuaternions(this,t)}premultiply(t){return this.multiplyQuaternions(t,this)}multiplyQuaternions(t,e){const s=t._x,n=t._y,r=t._z,o=t._w,a=e._x,h=e._y,c=e._z,d=e._w;return this._x=s*d+o*a+n*c-r*h,this._y=n*d+o*h+r*a-s*c,this._z=r*d+o*c+s*h-n*a,this._w=o*d-s*a-n*h-r*c,this._onChangeCallback(),this}slerp(t,e){if(e===0)return this;if(e===1)return this.copy(t);const s=this._x,n=this._y,r=this._z,o=this._w;let a=o*t._w+s*t._x+n*t._y+r*t._z;if(a<0?(this._w=-t._w,this._x=-t._x,this._y=-t._y,this._z=-t._z,a=-a):this.copy(t),a>=1)return this._w=o,this._x=s,this._y=n,this._z=r,this;const h=1-a*a;if(h<=Number.EPSILON){const g=1-e;return this._w=g*o+e*this._w,this._x=g*s+e*this._x,this._y=g*n+e*this._y,this._z=g*r+e*this._z,this.normalize(),this}const c=Math.sqrt(h),d=Math.atan2(c,a),u=Math.sin((1-e)*d)/c,p=Math.sin(e*d)/c;return this._w=o*u+this._w*p,this._x=s*u+this._x*p,this._y=n*u+this._y*p,this._z=r*u+this._z*p,this._onChangeCallback(),this}slerpQuaternions(t,e,s){return this.copy(t).slerp(e,s)}random(){const t=2*Math.PI*Math.random(),e=2*Math.PI*Math.random(),s=Math.random(),n=Math.sqrt(1-s),r=Math.sqrt(s);return this.set(n*Math.sin(t),n*Math.cos(t),r*Math.sin(e),r*Math.cos(e))}equals(t){return t._x===this._x&&t._y===this._y&&t._z===this._z&&t._w===this._w}fromArray(t,e=0){return this._x=t[e],this._y=t[e+1],this._z=t[e+2],this._w=t[e+3],this._onChangeCallback(),this}toArray(t=[],e=0){return t[e]=this._x,t[e+1]=this._y,t[e+2]=this._z,t[e+3]=this._w,t}toJSON(){return this.toArray()}_onChange(t){return this._onChangeCallback=t,this}_onChangeCallback(){}*[Symbol.iterator](){yield this._x,yield this._y,yield this._z,yield this._w}}const mt=class Ta{constructor(t,e,s){this.x=0,this.y=0,this.z=0;const n=+(t!==void 0)+ +(e!==void 0)+ +(s!==void 0);if(n!==0){if(n===1&&t instanceof Array){this.x=t[0],this.y=t[1],this.z=t[2];return}if(n===1){const{x:r,y:o,z:a}=t;this.x=r,this.y=o,this.z=a||0;return}if(n===3){this.x=t,this.y=e,this.z=s;return}throw wt.ILLEGAL_PARAMETERS}}set(t,e,s){return s===void 0&&(s=this.z),this.x=t,this.y=e,this.z=s,this}setScalar(t){return this.x=t,this.y=t,this.z=t,this}setX(t){return this.x=t,this}setY(t){return this.y=t,this}setZ(t){return this.z=t,this}setComponent(t,e){switch(t){case 0:this.x=e;break;case 1:this.y=e;break;case 2:this.z=e;break;default:throw new Error("index is out of range: "+t)}return this}getComponent(t){switch(t){case 0:return this.x;case 1:return this.y;case 2:return this.z;default:throw new Error("index is out of range: "+t)}}clone(){return new Ta(this.x,this.y,this.z)}copy(t){return this.x=t.x,this.y=t.y,this.z=t.z||0,this}add(t){return this.x+=t.x,this.y+=t.y,this.z+=t.z||0,this}addScalar(t){return this.x+=t,this.y+=t,this.z+=t,this}addVectors(t,e){return this.x=t.x+e.x,this.y=t.y+e.y,this.z=t.z+e.z,this}addScaledVector(t,e){return this.x+=t.x*e,this.y+=t.y*e,this.z+=t.z*e,this}sub(t){return this.x-=t.x,this.y-=t.y,this.z-=t.z,this}subScalar(t){return this.x-=t,this.y-=t,this.z-=t,this}subVectors(t,e){return this.x=t.x-e.x,this.y=t.y-e.y,this.z=t.z-e.z,this}multiply(t){return this.x*=t.x,this.y*=t.y,this.z*=t.z,this}multiplyScalar(t){return this.x*=t,this.y*=t,this.z*=t,this}multiplyVectors(t,e){return this.x=t.x*e.x,this.y=t.y*e.y,this.z=t.z*e.z,this}applyEuler(t){return this.applyQuaternion(Io.setFromEuler(t))}applyAxisAngle(t,e){return this.applyQuaternion(Io.setFromAxisAngle(t,e))}applyMatrix3(t){const e=this.x,s=this.y,n=this.z,r=t.elements;return this.x=r[0]*e+r[3]*s+r[6]*n,this.y=r[1]*e+r[4]*s+r[7]*n,this.z=r[2]*e+r[5]*s+r[8]*n,this}applyNormalMatrix(t){return this.applyMatrix3(t).normalize()}applyMatrix4(t){const e=this.x,s=this.y,n=this.z,r=t.elements,o=1/(r[3]*e+r[7]*s+r[11]*n+r[15]);return this.x=(r[0]*e+r[4]*s+r[8]*n+r[12])*o,this.y=(r[1]*e+r[5]*s+r[9]*n+r[13])*o,this.z=(r[2]*e+r[6]*s+r[10]*n+r[14])*o,this}applyQuaternion(t){const e=this.x,s=this.y,n=this.z,r=t.x,o=t.y,a=t.z,h=t.w,c=2*(o*n-a*s),d=2*(a*e-r*n),u=2*(r*s-o*e);return this.x=e+h*c+o*u-a*d,this.y=s+h*d+a*c-r*u,this.z=n+h*u+r*d-o*c,this}transformDirection(t){const e=this.x,s=this.y,n=this.z,r=t.elements;return this.x=r[0]*e+r[4]*s+r[8]*n,this.y=r[1]*e+r[5]*s+r[9]*n,this.z=r[2]*e+r[6]*s+r[10]*n,this.normalize()}divide(t){return this.x/=t.x,this.y/=t.y,this.z/=t.z,this}divideScalar(t){return this.multiplyScalar(1/t)}min(t){return this.x=Math.min(this.x,t.x),this.y=Math.min(this.y,t.y),this.z=Math.min(this.z,t.z),this}max(t){return this.x=Math.max(this.x,t.x),this.y=Math.max(this.y,t.y),this.z=Math.max(this.z,t.z),this}clamp(t,e){return this.x=Math.max(t.x,Math.min(e.x,this.x)),this.y=Math.max(t.y,Math.min(e.y,this.y)),this.z=Math.max(t.z,Math.min(e.z,this.z)),this}clampScalar(t,e){return this.x=Math.max(t,Math.min(e,this.x)),this.y=Math.max(t,Math.min(e,this.y)),this.z=Math.max(t,Math.min(e,this.z)),this}clampLength(t,e){const s=this.length();return this.divideScalar(s||1).multiplyScalar(Math.max(t,Math.min(e,s)))}floor(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this.z=Math.floor(this.z),this}ceil(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this.z=Math.ceil(this.z),this}round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this.z=Math.round(this.z),this}roundToZero(){return this.x=Math.trunc(this.x),this.y=Math.trunc(this.y),this.z=Math.trunc(this.z),this}negate(){return this.x=-this.x,this.y=-this.y,this.z=-this.z,this}dot(t){return this.x*t.x+this.y*t.y+this.z*t.z}isParallelTo(t){const e=this.dot(t),s=this.length(),n=t.length();return Math.abs(e)===s*n}lengthSq(){return this.x*this.x+this.y*this.y+this.z*this.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}manhattanLength(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z)}normalize(){return this.divideScalar(this.length()||1)}setLength(t){return this.normalize().multiplyScalar(t)}lerp(t,e){return this.x+=(t.x-this.x)*e,this.y+=(t.y-this.y)*e,this.z+=(t.z-this.z)*e,this}lerpVectors(t,e,s){return this.x=t.x+(e.x-t.x)*s,this.y=t.y+(e.y-t.y)*s,this.z=t.z+(e.z-t.z)*s,this}cross(t){return this.crossVectors(this,t)}crossVectors(t,e){const s=t.x,n=t.y,r=t.z,o=e.x,a=e.y,h=e.z;return this.x=n*h-r*a,this.y=r*o-s*h,this.z=s*a-n*o,this}projectOnVector(t){const e=t.lengthSq();if(e===0)return this.set(0,0,0);const s=t.dot(this)/e;return this.copy(t).multiplyScalar(s)}projectOnPlane(t){return bn.copy(this).projectOnVector(t),this.sub(bn)}reflect(t){return this.sub(bn.copy(t).multiplyScalar(2*this.dot(t)))}angleTo(t){const e=Math.sqrt(this.lengthSq()*t.lengthSq());if(e===0)return Math.PI/2;const s=this.dot(t)/e;return Math.acos(Math.max(-1,Math.min(1,s)))}distanceTo(t){return Math.sqrt(this.distanceToSquared(t))}distanceToSquared(t){const e=this.x-t.x,s=this.y-t.y,n=this.z-t.z;return e*e+s*s+n*n}manhattanDistanceTo(t){return Math.abs(this.x-t.x)+Math.abs(this.y-t.y)+Math.abs(this.z-t.z)}setFromMatrixPosition(t){const e=t.elements;return this.x=e[12],this.y=e[13],this.z=e[14],this}setFromMatrixScale(t){const e=this.setFromMatrixColumn(t,0).length(),s=this.setFromMatrixColumn(t,1).length(),n=this.setFromMatrixColumn(t,2).length();return this.x=e,this.y=s,this.z=n,this}setFromMatrixColumn(t,e){return this.fromArray(t.elements,e*4)}setFromMatrix3Column(t,e){return this.fromArray(t.elements,e*3)}equals(t){return t.x===this.x&&t.y===this.y&&t.z===this.z}fromArray(t,e=0){return this.x=t[e],this.y=t[e+1],this.z=t[e+2],this}toArray(t=[],e=0){return t[e]=this.x,t[e+1]=this.y,t[e+2]=this.z,t}random(){return this.x=Math.random(),this.y=Math.random(),this.z=Math.random(),this}randomDirection(){const t=Math.random()*Math.PI*2,e=Math.random()*2-1,s=Math.sqrt(1-e*e);return this.x=s*Math.cos(t),this.y=e,this.z=s*Math.sin(t),this}*[Symbol.iterator](){yield this.x,yield this.y,yield this.z}};mt.ORIGIN=Object.freeze(new mt(0,0,0)),mt.X_AXIS=Object.freeze(new mt(1,0,0)),mt.NEGATIVE_X_AXIS=Object.freeze(new mt(-1,0,0)),mt.Y_AXIS=Object.freeze(new mt(0,1,0)),mt.NEGATIVE_Y_AXIS=Object.freeze(new mt(0,-1,0)),mt.Z_AXIS=Object.freeze(new mt(0,0,1)),mt.NEGATIVE_Z_AXIS=Object.freeze(new mt(0,0,-1));let _=mt;const bn=new _,Io=new ss,jn=class Ea{constructor(t,e,s,n,r,o,a,h,c,d,u,p,g,m,y,b){this.elements=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1],t!=null&&e!=null&&s!=null&&n!=null&&r!=null&&o!=null&&a!=null&&h!=null&&c!=null&&d!=null&&u!=null&&p!=null&&g!=null&&m!=null&&y!=null&&b!=null&&this.set(t,e,s,n,r,o,a,h,c,d,u,p,g,m,y,b)}set(t,e,s,n,r,o,a,h,c,d,u,p,g,m,y,b){const x=this.elements;return x[0]=t,x[4]=e,x[8]=s,x[12]=n,x[1]=r,x[5]=o,x[9]=a,x[13]=h,x[2]=c,x[6]=d,x[10]=u,x[14]=p,x[3]=g,x[7]=m,x[11]=y,x[15]=b,this}identity(){return this.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1),this}clone(){return new Ea().fromArray(this.elements)}copy(t){const e=this.elements,s=t.elements;return e[0]=s[0],e[1]=s[1],e[2]=s[2],e[3]=s[3],e[4]=s[4],e[5]=s[5],e[6]=s[6],e[7]=s[7],e[8]=s[8],e[9]=s[9],e[10]=s[10],e[11]=s[11],e[12]=s[12],e[13]=s[13],e[14]=s[14],e[15]=s[15],this}copyPosition(t){const e=this.elements,s=t.elements;return e[12]=s[12],e[13]=s[13],e[14]=s[14],this}setFromMatrix3(t){const e=t.elements;return this.set(e[0],e[3],e[6],0,e[1],e[4],e[7],0,e[2],e[5],e[8],0,0,0,0,1),this}setFromExtrusionDirection(t){if(dr.equalPoint3d(t,_.Z_AXIS))this.identity();else{const e=new _(1,0,0);Math.abs(t.x)<1/64&&Math.abs(t.y)<1/64?e.crossVectors(_.Y_AXIS,t).normalize():e.crossVectors(_.Z_AXIS,t).normalize();const s=t.clone().cross(e).normalize();this.set(e.x,e.y,e.z,0,s.x,s.y,s.z,0,t.x,t.y,t.z,0,0,0,0,1)}return this}extractBasis(t,e,s){return t.setFromMatrixColumn(this,0),e.setFromMatrixColumn(this,1),s.setFromMatrixColumn(this,2),this}makeBasis(t,e,s){return this.set(t.x,e.x,s.x,0,t.y,e.y,s.y,0,t.z,e.z,s.z,0,0,0,0,1),this}extractRotation(t){const e=this.elements,s=t.elements,n=1/is.setFromMatrixColumn(t,0).length(),r=1/is.setFromMatrixColumn(t,1).length(),o=1/is.setFromMatrixColumn(t,2).length();return e[0]=s[0]*n,e[1]=s[1]*n,e[2]=s[2]*n,e[3]=0,e[4]=s[4]*r,e[5]=s[5]*r,e[6]=s[6]*r,e[7]=0,e[8]=s[8]*o,e[9]=s[9]*o,e[10]=s[10]*o,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,this}makeRotationFromQuaternion(t){return this.compose(uc,t,gc)}lookAt(t,e,s){const n=this.elements;return bt.subVectors(t,e),bt.lengthSq()===0&&(bt.z=1),bt.normalize(),_e.crossVectors(s,bt),_e.lengthSq()===0&&(Math.abs(s.z)===1?bt.x+=1e-4:bt.z+=1e-4,bt.normalize(),_e.crossVectors(s,bt)),_e.normalize(),pi.crossVectors(bt,_e),n[0]=_e.x,n[4]=pi.x,n[8]=bt.x,n[1]=_e.y,n[5]=pi.y,n[9]=bt.y,n[2]=_e.z,n[6]=pi.z,n[10]=bt.z,this}multiply(t){return this.multiplyMatrices(this,t)}premultiply(t){return this.multiplyMatrices(t,this)}multiplyMatrices(t,e){const s=t.elements,n=e.elements,r=this.elements,o=s[0],a=s[4],h=s[8],c=s[12],d=s[1],u=s[5],p=s[9],g=s[13],m=s[2],y=s[6],b=s[10],x=s[14],I=s[3],S=s[7],L=s[11],A=s[15],H=n[0],M=n[4],X=n[8],R=n[12],et=n[1],F=n[5],Y=n[9],ke=n[13],ve=n[2],oi=n[6],ai=n[10],li=n[14],hi=n[3],ci=n[7],di=n[11],ui=n[15];return r[0]=o*H+a*et+h*ve+c*hi,r[4]=o*M+a*F+h*oi+c*ci,r[8]=o*X+a*Y+h*ai+c*di,r[12]=o*R+a*ke+h*li+c*ui,r[1]=d*H+u*et+p*ve+g*hi,r[5]=d*M+u*F+p*oi+g*ci,r[9]=d*X+u*Y+p*ai+g*di,r[13]=d*R+u*ke+p*li+g*ui,r[2]=m*H+y*et+b*ve+x*hi,r[6]=m*M+y*F+b*oi+x*ci,r[10]=m*X+y*Y+b*ai+x*di,r[14]=m*R+y*ke+b*li+x*ui,r[3]=I*H+S*et+L*ve+A*hi,r[7]=I*M+S*F+L*oi+A*ci,r[11]=I*X+S*Y+L*ai+A*di,r[15]=I*R+S*ke+L*li+A*ui,this}multiplyScalar(t){const e=this.elements;return e[0]*=t,e[4]*=t,e[8]*=t,e[12]*=t,e[1]*=t,e[5]*=t,e[9]*=t,e[13]*=t,e[2]*=t,e[6]*=t,e[10]*=t,e[14]*=t,e[3]*=t,e[7]*=t,e[11]*=t,e[15]*=t,this}determinant(){const t=this.elements,e=t[0],s=t[4],n=t[8],r=t[12],o=t[1],a=t[5],h=t[9],c=t[13],d=t[2],u=t[6],p=t[10],g=t[14],m=t[3],y=t[7],b=t[11],x=t[15];return m*(+r*h*u-n*c*u-r*a*p+s*c*p+n*a*g-s*h*g)+y*(+e*h*g-e*c*p+r*o*p-n*o*g+n*c*d-r*h*d)+b*(+e*c*u-e*a*g-r*o*u+s*o*g+r*a*d-s*c*d)+x*(-n*a*d-e*h*u+e*a*p+n*o*u-s*o*p+s*h*d)}transpose(){const t=this.elements;let e;return e=t[1],t[1]=t[4],t[4]=e,e=t[2],t[2]=t[8],t[8]=e,e=t[6],t[6]=t[9],t[9]=e,e=t[3],t[3]=t[12],t[12]=e,e=t[7],t[7]=t[13],t[13]=e,e=t[11],t[11]=t[14],t[14]=e,this}setPosition(t,e,s){const n=this.elements;return t instanceof _?(n[12]=t.x,n[13]=t.y,n[14]=t.z):(n[12]=t,n[13]=e,n[14]=s),this}invert(){const t=this.elements,e=t[0],s=t[1],n=t[2],r=t[3],o=t[4],a=t[5],h=t[6],c=t[7],d=t[8],u=t[9],p=t[10],g=t[11],m=t[12],y=t[13],b=t[14],x=t[15],I=u*b*c-y*p*c+y*h*g-a*b*g-u*h*x+a*p*x,S=m*p*c-d*b*c-m*h*g+o*b*g+d*h*x-o*p*x,L=d*y*c-m*u*c+m*a*g-o*y*g-d*a*x+o*u*x,A=m*u*h-d*y*h-m*a*p+o*y*p+d*a*b-o*u*b,H=e*I+s*S+n*L+r*A;if(H===0)return this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0);const M=1/H;return t[0]=I*M,t[1]=(y*p*r-u*b*r-y*n*g+s*b*g+u*n*x-s*p*x)*M,t[2]=(a*b*r-y*h*r+y*n*c-s*b*c-a*n*x+s*h*x)*M,t[3]=(u*h*r-a*p*r-u*n*c+s*p*c+a*n*g-s*h*g)*M,t[4]=S*M,t[5]=(d*b*r-m*p*r+m*n*g-e*b*g-d*n*x+e*p*x)*M,t[6]=(m*h*r-o*b*r-m*n*c+e*b*c+o*n*x-e*h*x)*M,t[7]=(o*p*r-d*h*r+d*n*c-e*p*c-o*n*g+e*h*g)*M,t[8]=L*M,t[9]=(m*u*r-d*y*r-m*s*g+e*y*g+d*s*x-e*u*x)*M,t[10]=(o*y*r-m*a*r+m*s*c-e*y*c-o*s*x+e*a*x)*M,t[11]=(d*a*r-o*u*r-d*s*c+e*u*c+o*s*g-e*a*g)*M,t[12]=A*M,t[13]=(d*y*n-m*u*n+m*s*p-e*y*p-d*s*b+e*u*b)*M,t[14]=(m*a*n-o*y*n-m*s*h+e*y*h+o*s*b-e*a*b)*M,t[15]=(o*u*n-d*a*n+d*s*h-e*u*h-o*s*p+e*a*p)*M,this}scale(t){const e=this.elements,s=t.x,n=t.y,r=t.z;return e[0]*=s,e[4]*=n,e[8]*=r,e[1]*=s,e[5]*=n,e[9]*=r,e[2]*=s,e[6]*=n,e[10]*=r,e[3]*=s,e[7]*=n,e[11]*=r,this}getMaxScaleOnAxis(){const t=this.elements,e=t[0]*t[0]+t[1]*t[1]+t[2]*t[2],s=t[4]*t[4]+t[5]*t[5]+t[6]*t[6],n=t[8]*t[8]+t[9]*t[9]+t[10]*t[10];return Math.sqrt(Math.max(e,s,n))}makeTranslation(t,e,s){return t instanceof _?this.set(1,0,0,t.x,0,1,0,t.y,0,0,1,t.z,0,0,0,1):this.set(1,0,0,t,0,1,0,e,0,0,1,s,0,0,0,1),this}makeRotationX(t){const e=Math.cos(t),s=Math.sin(t);return this.set(1,0,0,0,0,e,-s,0,0,s,e,0,0,0,0,1),this}makeRotationY(t){const e=Math.cos(t),s=Math.sin(t);return this.set(e,0,s,0,0,1,0,0,-s,0,e,0,0,0,0,1),this}makeRotationZ(t){const e=Math.cos(t),s=Math.sin(t);return this.set(e,-s,0,0,s,e,0,0,0,0,1,0,0,0,0,1),this}makeRotationAxis(t,e){const s=Math.cos(e),n=Math.sin(e),r=1-s,o=t.x,a=t.y,h=t.z,c=r*o,d=r*a;return this.set(c*o+s,c*a-n*h,c*h+n*a,0,c*a+n*h,d*a+s,d*h-n*o,0,c*h-n*a,d*h+n*o,r*h*h+s,0,0,0,0,1),this}makeScale(t,e,s){return this.set(t,0,0,0,0,e,0,0,0,0,s,0,0,0,0,1),this}makeShear(t,e,s,n,r,o){return this.set(1,s,r,0,t,1,o,0,e,n,1,0,0,0,0,1),this}compose(t,e,s){const n=this.elements,r=e.x,o=e.y,a=e.z,h=e.w,c=r+r,d=o+o,u=a+a,p=r*c,g=r*d,m=r*u,y=o*d,b=o*u,x=a*u,I=h*c,S=h*d,L=h*u,A=s.x,H=s.y,M=s.z;return n[0]=(1-(y+x))*A,n[1]=(g+L)*A,n[2]=(m-S)*A,n[3]=0,n[4]=(g-L)*H,n[5]=(1-(p+x))*H,n[6]=(b+I)*H,n[7]=0,n[8]=(m+S)*M,n[9]=(b-I)*M,n[10]=(1-(p+y))*M,n[11]=0,n[12]=t.x,n[13]=t.y,n[14]=t.z,n[15]=1,this}decompose(t,e,s){const n=this.elements;let r=is.set(n[0],n[1],n[2]).length();const o=is.set(n[4],n[5],n[6]).length(),a=is.set(n[8],n[9],n[10]).length();this.determinant()<0&&(r=-r),t.x=n[12],t.y=n[13],t.z=n[14],vt.copy(this);const h=1/r,c=1/o,d=1/a;return vt.elements[0]*=h,vt.elements[1]*=h,vt.elements[2]*=h,vt.elements[4]*=c,vt.elements[5]*=c,vt.elements[6]*=c,vt.elements[8]*=d,vt.elements[9]*=d,vt.elements[10]*=d,e.setFromRotationMatrix(vt),s.x=r,s.y=o,s.z=a,this}equals(t){const e=this.elements,s=t.elements;for(let n=0;n<16;n++)if(e[n]!==s[n])return!1;return!0}fromArray(t,e=0){for(let s=0;s<16;s++)this.elements[s]=t[s+e];return this}toArray(t=[],e=0){const s=this.elements;return t[e]=s[0],t[e+1]=s[1],t[e+2]=s[2],t[e+3]=s[3],t[e+4]=s[4],t[e+5]=s[5],t[e+6]=s[6],t[e+7]=s[7],t[e+8]=s[8],t[e+9]=s[9],t[e+10]=s[10],t[e+11]=s[11],t[e+12]=s[12],t[e+13]=s[13],t[e+14]=s[14],t[e+15]=s[15],t}};jn.IDENTITY=Object.freeze(new jn);let D=jn;const is=new _,vt=new D,uc=new _(0,0,0),gc=new _(1,1,1),_e=new _,pi=new _,bt=new _;let N=class La{constructor(t=void 0,e=void 0){this.min=t==null?new _(1/0,1/0,1/0):new _(t.x,t.y,t.z),this.max=e==null?new _(-1/0,-1/0,-1/0):new _(e.x,e.y,e.z)}set(t,e){return this.min.copy(t),this.max.copy(e),this}setFromArray(t){this.makeEmpty();for(let e=0,s=t.length;e<s;e+=3)this.expandByPoint(fn.fromArray(t,e));return this}setFromPoints(t){this.makeEmpty();for(let e=0,s=t.length;e<s;e++)this.expandByPoint(t[e]);return this}setFromCenterAndSize(t,e){const s=fn.copy(e).multiplyScalar(.5);return this.min.copy(t).sub(s),this.max.copy(t).add(s),this}clone(){return new La().copy(this)}copy(t){return this.min.copy(t.min),this.max.copy(t.max),this}makeEmpty(){return this.min.x=this.min.y=this.min.z=1/0,this.max.x=this.max.y=this.max.z=-1/0,this}isEmpty(){return this.max.x<this.min.x||this.max.y<this.min.y||this.max.z<this.min.z}getCenter(t){return this.isEmpty()?t.set(0,0,0):t.addVectors(this.min,this.max).multiplyScalar(.5)}getSize(t){return this.isEmpty()?t.set(0,0,0):t.subVectors(this.max,this.min)}get center(){return this.isEmpty()?new _(0,0,0):new _(0,0,0).addVectors(this.min,this.max).multiplyScalar(.5)}get size(){return this.isEmpty()?new _(0,0,0):new _(0,0,0).subVectors(this.max,this.min)}expandByPoint(t){return this.min.min(t),this.max.max(t),this}expandByVector(t){return this.min.sub(t),this.max.add(t),this}expandByScalar(t){return this.min.addScalar(-t),this.max.addScalar(t),this}containsPoint(t){return!(t.x<this.min.x||t.x>this.max.x||t.y<this.min.y||t.y>this.max.y||t.z<this.min.z||t.z>this.max.z)}containsBox(t){return this.min.x<=t.min.x&&t.max.x<=this.max.x&&this.min.y<=t.min.y&&t.max.y<=this.max.y&&this.min.z<=t.min.z&&t.max.z<=this.max.z}getParameter(t,e){return e.set((t.x-this.min.x)/(this.max.x-this.min.x),(t.y-this.min.y)/(this.max.y-this.min.y),(t.z-this.min.z)/(this.max.z-this.min.z))}intersectsBox(t){return!(t.max.x<this.min.x||t.min.x>this.max.x||t.max.y<this.min.y||t.min.y>this.max.y||t.max.z<this.min.z||t.min.z>this.max.z)}intersectsPlane(t){let e,s;return t.normal.x>0?(e=t.normal.x*this.min.x,s=t.normal.x*this.max.x):(e=t.normal.x*this.max.x,s=t.normal.x*this.min.x),t.normal.y>0?(e+=t.normal.y*this.min.y,s+=t.normal.y*this.max.y):(e+=t.normal.y*this.max.y,s+=t.normal.y*this.min.y),t.normal.z>0?(e+=t.normal.z*this.min.z,s+=t.normal.z*this.max.z):(e+=t.normal.z*this.max.z,s+=t.normal.z*this.min.z),e<=-t.constant&&s>=-t.constant}clampPoint(t,e){return e.copy(t).clamp(this.min,this.max)}distanceToPoint(t){return this.clampPoint(t,fn).distanceTo(t)}intersect(t){return this.min.max(t.min),this.max.min(t.max),this.isEmpty()&&this.makeEmpty(),this}union(t){return this.min.min(t.min),this.max.max(t.max),this}applyMatrix4(t){return this.isEmpty()?this:(Ut[0].set(this.min.x,this.min.y,this.min.z).applyMatrix4(t),Ut[1].set(this.min.x,this.min.y,this.max.z).applyMatrix4(t),Ut[2].set(this.min.x,this.max.y,this.min.z).applyMatrix4(t),Ut[3].set(this.min.x,this.max.y,this.max.z).applyMatrix4(t),Ut[4].set(this.max.x,this.min.y,this.min.z).applyMatrix4(t),Ut[5].set(this.max.x,this.min.y,this.max.z).applyMatrix4(t),Ut[6].set(this.max.x,this.max.y,this.min.z).applyMatrix4(t),Ut[7].set(this.max.x,this.max.y,this.max.z).applyMatrix4(t),this.setFromPoints(Ut),this)}translate(t){return this.min.add(t),this.max.add(t),this}equals(t){return t.min.equals(this.min)&&t.max.equals(this.max)}};const Ut=[new _,new _,new _,new _,new _,new _,new _,new _],fn=new _,Ao=new $;let _t=class Ma{constructor(t=void 0,e=void 0){this.min=t==null?new $(1/0,1/0):new $(t.x,t.y),this.max=e==null?new $(-1/0,-1/0):new $(e.x,e.y)}set(t,e){return this.min.copy(t),this.max.copy(e),this}setFromPoints(t){this.makeEmpty();for(let e=0,s=t.length;e<s;e++)this.expandByPoint(t[e]);return this}setFromCenterAndSize(t,e){const s=Ao.copy(e).multiplyScalar(.5);return this.min.copy(t).sub(s),this.max.copy(t).add(s),this}clone(){return new Ma().copy(this)}copy(t){return this.min.copy(t.min),this.max.copy(t.max),this}makeEmpty(){return this.min.x=this.min.y=1/0,this.max.x=this.max.y=-1/0,this}isEmpty(){return this.max.x<this.min.x||this.max.y<this.min.y}getCenter(t){return this.isEmpty()?t.set(0,0):t.addVectors(this.min,this.max).multiplyScalar(.5)}getSize(t){return this.isEmpty()?t.set(0,0):t.subVectors(this.max,this.min)}get center(){return this.isEmpty()?new $(0,0):new $(0,0).addVectors(this.min,this.max).multiplyScalar(.5)}get size(){return this.isEmpty()?new $(0,0):new $(0,0).subVectors(this.max,this.min)}expandByPoint(t){return this.min.min(t),this.max.max(t),this}expandByVector(t){return this.min.sub(t),this.max.add(t),this}expandByScalar(t){return this.min.addScalar(-t),this.max.addScalar(t),this}containsPoint(t){return!(t.x<this.min.x||t.x>this.max.x||t.y<this.min.y||t.y>this.max.y)}containsBox(t){return this.min.x<=t.min.x&&t.max.x<=this.max.x&&this.min.y<=t.min.y&&t.max.y<=this.max.y}getParameter(t,e){return e.set((t.x-this.min.x)/(this.max.x-this.min.x),(t.y-this.min.y)/(this.max.y-this.min.y))}intersectsBox(t){return!(t.max.x<this.min.x||t.min.x>this.max.x||t.max.y<this.min.y||t.min.y>this.max.y)}clampPoint(t,e){return e.copy(t).clamp(this.min,this.max)}distanceToPoint(t){return this.clampPoint(t,Ao).distanceTo(t)}intersect(t){return this.min.max(t.min),this.max.min(t.max),this.isEmpty()&&this.makeEmpty(),this}union(t){return this.min.min(t.min),this.max.max(t.max),this}translate(t){return this.min.add(t),this.max.add(t),this}equals(t){return t.min.equals(this.min)&&t.max.equals(this.max)}};const Po=new _,pc=new _,mc=new Js;class ei{constructor(t=new _(1,0,0),e=0){this.normal=t,this.constant=e}set(t,e){return this.normal.copy(t),this.constant=e,this}setComponents(t,e,s,n){return this.normal.set(t,e,s),this.constant=n,this}setFromNormalAndCoplanarPoint(t,e){return this.normal.copy(t),this.constant=-e.dot(this.normal),this}setFromCoplanarPoints(t,e,s){const n=Po.subVectors(s,e).cross(pc.subVectors(t,e)).normalize();return this.setFromNormalAndCoplanarPoint(n,t),this}copy(t){return this.normal.copy(t.normal),this.constant=t.constant,this}normalize(){const t=1/this.normal.length();return this.normal.multiplyScalar(t),this.constant*=t,this}negate(){return this.constant*=-1,this.normal.negate(),this}distanceToPoint(t){return this.normal.dot(t)+this.constant}projectPoint(t,e){return e.copy(t).addScaledVector(this.normal,-this.distanceToPoint(t))}intersectsBox(t){return t.intersectsPlane(this)}coplanarPoint(t){return t.copy(this.normal).multiplyScalar(-this.constant)}applyMatrix4(t,e){const s=e||mc.getNormalMatrix(t),n=this.coplanarPoint(Po).applyMatrix4(t),r=this.normal.applyMatrix3(s).normalize();return this.constant=-n.dot(r),this}translate(t){return this.constant-=t.dot(this.normal),this}equals(t){return t.normal.equals(this.normal)&&t.constant===this.constant}clone(){return new ei().copy(this)}}let v=class ka extends ${clone(){return new ka(this.x,this.y)}static pointArrayToNumberArray(t){const e=new Array(t.length*2);return t.forEach((s,n)=>{s.toArray(e,n*2)}),e}},w=class va extends _{clone(){return new va(this.x,this.y,this.z)}static pointArrayToNumberArray(t,e=!0){const s=e?3:2,n=new Array(t.length*s);return t.forEach((r,o)=>{r.toArray(n,o*s)}),n}};const To=new D,Eo=new ss,Ca=class Wn{constructor(t=0,e=0,s=0,n=Wn.DEFAULT_ORDER){this._x=t,this._y=e,this._z=s,this._order=n}get x(){return this._x}set x(t){this._x=t,this._onChangeCallback()}get y(){return this._y}set y(t){this._y=t,this._onChangeCallback()}get z(){return this._z}set z(t){this._z=t,this._onChangeCallback()}get order(){return this._order}set order(t){this._order=t,this._onChangeCallback()}set(t,e,s,n=this._order){return this._x=t,this._y=e,this._z=s,this._order=n,this._onChangeCallback(),this}clone(){return new Wn(this._x,this._y,this._z,this._order)}copy(t){return this._x=t._x,this._y=t._y,this._z=t._z,this._order=t._order,this._onChangeCallback(),this}setFromRotationMatrix(t,e=this._order,s=!0){const n=t.elements,r=n[0],o=n[4],a=n[8],h=n[1],c=n[5],d=n[9],u=n[2],p=n[6],g=n[10];switch(e){case"XYZ":this._y=Math.asin(he(a,-1,1)),Math.abs(a)<.9999999?(this._x=Math.atan2(-d,g),this._z=Math.atan2(-o,r)):(this._x=Math.atan2(p,c),this._z=0);break;case"YXZ":this._x=Math.asin(-he(d,-1,1)),Math.abs(d)<.9999999?(this._y=Math.atan2(a,g),this._z=Math.atan2(h,c)):(this._y=Math.atan2(-u,r),this._z=0);break;case"ZXY":this._x=Math.asin(he(p,-1,1)),Math.abs(p)<.9999999?(this._y=Math.atan2(-u,g),this._z=Math.atan2(-o,c)):(this._y=0,this._z=Math.atan2(h,r));break;case"ZYX":this._y=Math.asin(-he(u,-1,1)),Math.abs(u)<.9999999?(this._x=Math.atan2(p,g),this._z=Math.atan2(h,r)):(this._x=0,this._z=Math.atan2(-o,c));break;case"YZX":this._z=Math.asin(he(h,-1,1)),Math.abs(h)<.9999999?(this._x=Math.atan2(-d,c),this._y=Math.atan2(-u,r)):(this._x=0,this._y=Math.atan2(a,g));break;case"XZY":this._z=Math.asin(-he(o,-1,1)),Math.abs(o)<.9999999?(this._x=Math.atan2(p,c),this._y=Math.atan2(a,r)):(this._x=Math.atan2(-d,g),this._y=0);break}return this._order=e,s===!0&&this._onChangeCallback(),this}setFromQuaternion(t,e,s=!0){return To.makeRotationFromQuaternion(t),this.setFromRotationMatrix(To,e,s)}setFromVector3(t,e=this._order){return this.set(t.x,t.y,t.z,e)}reorder(t){return Eo.setFromEuler(this),this.setFromQuaternion(Eo,t)}equals(t){return t._x===this._x&&t._y===this._y&&t._z===this._z&&t._order===this._order}fromArray(t){return this._x=t[0],this._y=t[1],this._z=t[2],t[3]!==void 0&&(this._order=t[3]),this._onChangeCallback(),this}toArray(t=[],e=0){return t[e]=this._x,t[e+1]=this._y,t[e+2]=this._z,t[e+3]=this._order,t}_onChange(t){return this._onChangeCallback=t,this}_onChangeCallback(){}*[Symbol.iterator](){yield this._x,yield this._y,yield this._z,yield this._order}};Ca.DEFAULT_ORDER="XYZ";let yc=Ca;function ur(i,t,e=!1){const s=i.x,n=i.y;let r=!1;const o=t.length;for(let a=0,h=o-1;a<o;h=a++){const c=t[a].x,d=t[a].y,u=t[h].x,p=t[h].y;let g=d>n!=p>n;e&&(g=d>=n!=p>=n),g&&s<(u-c)*(n-d)/(p-d)+c&&(r=!r)}return r}function Oa(i,t){if(i.length===0||t.length===0)return!1;const e=new _t().setFromPoints(i),s=new _t().setFromPoints(t);if(!e.intersectsBox(s))return!1;for(let n=0;n<i.length;){if(ur(i[n],t,!0))return!0;n<i.length-1&&dr.equalPoint2d(i[n+1],i[n])&&++n,++n}return!1}const Na={isPointInPolygon:ur,isPolygonIntersect:Oa};function _c(i,t){const e=[],s=t-1,n=i;for(let r=0;r<=n;r++)e.push(0);for(let r=1;r<=s-n;r++)e.push(r);for(let r=0;r<=n;r++)e.push(s-n+1);return e}function xc(i,t){const e=t.length-1,s=i,n=[0];let r=0;for(let a=1;a<=e;a++){const h=t[a][0]-t[a-1][0],c=t[a][1]-t[a-1][1],d=t[a][2]-t[a-1][2],u=Math.sqrt(h*h+c*c+d*d);r+=u,n.push(r)}const o=[];for(let a=0;a<=s;a++)o.push(0);for(let a=1;a<=e-s;a++){const h=n[a]/r;o.push(h*(e-s+1))}for(let a=0;a<=s;a++)o.push(e-s+1);return o}function Ba(i,t="Uniform"){const e=i.length;if(e===0)return[];if(e===1)return[0];const s=e-1;if(t==="Uniform")return new Array(e).fill(0).map((o,a)=>a/s);const n=[0];let r=0;for(let o=1;o<=s;o++){const a=i[o][0]-i[o-1][0],h=i[o][1]-i[o-1][1],c=i[o][2]-i[o-1][2],d=Math.sqrt(a*a+h*h+c*c),u=t==="SqrtChord"?Math.sqrt(d):d;r+=u,n.push(r)}return r<1e-12?new Array(e).fill(0).map((o,a)=>a/s):n.map(o=>o/r)}function Ra(i,t){const e=t.length-1,s=i,n=e+s+1,r=new Array(n+1).fill(0),o=t[t.length-1];for(let a=n-s;a<=n;a++)r[a]=o;for(let a=1;a<=e-s;a++){let h=0;for(let c=a;c<a+s;c++)h+=t[c];r[a+s]=h/s}return r}function wc(i,t){const e=t.length-1,s=i,n=[0];let r=0;for(let a=1;a<=e;a++){const h=t[a][0]-t[a-1][0],c=t[a][1]-t[a-1][1],d=t[a][2]-t[a-1][2],u=Math.sqrt(h*h+c*c+d*d),p=Math.sqrt(u);r+=p,n.push(r)}const o=[];for(let a=0;a<=s;a++)o.push(0);for(let a=1;a<=e-s;a++){const h=n[a]/r;o.push(h*(e-s+1))}for(let a=0;a<=s;a++)o.push(e-s+1);return o}function Sn(i,t){const e=i.length,s=i.map(o=>o.slice()),n=t.slice();for(let o=0;o<e;o++){let a=o,h=Math.abs(s[o][o]);for(let c=o+1;c<e;c++){const d=Math.abs(s[c][o]);d>h&&(h=d,a=c)}if(h<1e-12)throw new Error("Interpolation matrix is singular.");if(a!==o){const c=s[o];s[o]=s[a],s[a]=c;const d=n[o];n[o]=n[a],n[a]=d}for(let c=o+1;c<e;c++){const d=s[c][o]/s[o][o];if(!(Math.abs(d)<1e-14)){for(let u=o;u<e;u++)s[c][u]-=d*s[o][u];n[c]-=d*n[o]}}}const r=new Array(e).fill(0);for(let o=e-1;o>=0;o--){let a=n[o];for(let h=o+1;h<e;h++)a-=s[o][h]*r[h];r[o]=a/s[o][o]}return r}function gr(i,t,e="Uniform",s,n){if(i.length===0)return{controlPoints:[],knots:[],weights:[]};const r=i.map(R=>[R[0],R[1],R[2]??0]),o=!!s,a=!!n,h=(o?1:0)+(a?1:0),c=r.length-1,d=c+h;if(d<t)throw new Error("Not enough points to interpolate a curve of this degree.");const u=Ba(r,e),p=u.slice();o&&p.unshift(u[0]),a&&p.push(u[u.length-1]);const g=Ra(t,p),m=d+1,y=new Array(m),b=new Array(m),x=new Array(m),I=new Array(m);let S=0;y[S]=new Array(m).fill(0),y[S][0]=1,b[S]=r[0][0],x[S]=r[0][1],I[S]=r[0][2],S++;for(let R=1;R<=c-1;R++){const et=u[R];y[S]=new Array(m).fill(0);for(let F=0;F<=d;F++)y[S][F]=js(F,t,et,g);b[S]=r[R][0],x[S]=r[R][1],I[S]=r[R][2],S++}if(y[S]=new Array(m).fill(0),y[S][d]=1,b[S]=r[c][0],x[S]=r[c][1],I[S]=r[c][2],S++,o){const R=g[t+1]-g[0],et=R!==0?t/R:0;y[S]=new Array(m).fill(0),y[S][0]=-et,y[S][1]=et,b[S]=(s==null?void 0:s[0])??0,x[S]=(s==null?void 0:s[1])??0,I[S]=(s==null?void 0:s[2])??0,S++}if(a){const R=g[d+t+1]-g[d],et=R!==0?t/R:0;y[S]=new Array(m).fill(0),y[S][d-1]=-et,y[S][d]=et,b[S]=(n==null?void 0:n[0])??0,x[S]=(n==null?void 0:n[1])??0,I[S]=(n==null?void 0:n[2])??0,S++}const L=Sn(y,b),A=Sn(y,x),H=Sn(y,I),M=new Array(m);for(let R=0;R<m;R++)M[R]=[L[R],A[R],H[R]];const X=new Array(m).fill(1);return{controlPoints:M,knots:g,weights:X}}function js(i,t,e,s){if(t===0)return e>=s[i]&&e<s[i+1]?1:0;const n=s[i+t]-s[i],r=s[i+t+1]-s[i+1],o=n>1e-10?(e-s[i])/n:0,a=r>1e-10?(s[i+t+1]-e)/r:0;return o*js(i,t-1,e,s)+a*js(i+1,t-1,e,s)}function Bs(i,t,e,s,n){const r=s.length-1,o=t;if(i=Math.max(e[o],Math.min(e[r+1],i)),Math.abs(i-e[r+1])<1e-8)return[...s[r]];if(Math.abs(i-e[o])<1e-8)return[...s[0]];const a=[0,0,0];let h=0;for(let c=0;c<=r;c++){const d=js(c,o,i,e),u=n[c]*d;a[0]+=s[c][0]*u,a[1]+=s[c][1]*u,a[2]+=s[c][2]*u,h+=u}if(Math.abs(h)<1e-10){const c=e[e.length-o-1];if(Math.abs(i-c)<1e-8)return[...s[r]];if(Math.abs(i-e[o])<1e-8)return[...s[0]]}return Math.abs(h)>=1e-10&&(a[0]/=h,a[1]/=h,a[2]/=h),a}function Fa(i,t,e,s){const n=i,r=t[n],o=t[t.length-n-1];let a=0;const h=1e3,c=(o-r)/h;let d=Bs(r,i,t,e,s);for(let y=1;y<=h;y++){const b=r+y*c,x=Bs(b,i,t,e,s),I=x[0]-d[0],S=x[1]-d[1],L=x[2]-d[2];a+=Math.sqrt(I*I+S*S+L*L),d=x}const u=Bs(o,i,t,e,s),p=u[0]-d[0],g=u[1]-d[1],m=u[2]-d[2];return a+=Math.sqrt(p*p+g*g+m*m),a}function bc(i,t=3,e="Uniform",s,n){return i.length===0?[]:gr(i,t,e,s,n).controlPoints}const Lo=new D,Mo=new _,fc=new _,Sc=new _,In=new w;function za(i){return new D().setFromExtrusionDirection(new _(i.x,i.y,i.z))}function pr(i){return Lo.setFromExtrusionDirection(new _(i.x,i.y,i.z)),Lo.extractBasis(Mo,fc,Sc),Mo.clone()}function Hn(i,t){return new w(i.x,i.y,i.z??0).applyMatrix4(za(t))}function Ws(i,t){return new w(i.x,i.y,i.z??0).applyMatrix4(za(t).invert())}function Gn(i,t,e){const s=Ws(i,e),n=Ws(t,e);return In.set(n.x-s.x,n.y-s.y,(n.z??0)-(s.z??0)),k.normalizeAngle(Math.atan2(In.y,In.x))}class Va{constructor(){this._boundingBoxNeedsUpdate=!1}get boundingBoxNeedUpdate(){return this._boundingBoxNeedsUpdate}}class mr extends Va{translate(t){return this.transform(new Js().makeTranslation(t.x,t.y))}get box(){return(this._box==null||this._boundingBoxNeedsUpdate)&&(this._box=this.calculateBoundingBox(),this._boundingBoxNeedsUpdate=!1),this._box}}let Pe=class Da extends mr{constructor(){super(),this._loops=[]}add(t){this._loops.push(t),this._boundingBoxNeedsUpdate=!0}get loops(){return this._loops}get outter(){if(this._loops.length>0)return this._loops[0]}calculateBoundingBox(){const t=this.outter;return t?t.box:new _t}transform(t){return this._loops.forEach(e=>{e.transform(t)}),this._boundingBoxNeedsUpdate=!0,this}clone(){const t=new Da;return this._loops.forEach(e=>{t.add(e.clone())}),t}getPoints(t){const e=[];for(let s=0;s<this.loops.length;++s){const n=this.loops[s].getPoints(t);e.push(n)}return e}buildHierarchy(){var t;const e=this.getPoints(100),s=this.calculateBoundaryBoxes(e),n=this.sortBoundaryBoxesByAreas(s),r=new Map,o=n.length;for(let h=0;h<o;h++)r.set(n[h],{index:n[h],children:[]});const a={index:-1,children:[]};for(let h=0;h<o;h++){const c=n[h],d=e[c],u=s[c];let p=h+1;for(;p<o;p++){const g=n[p],m=e[g];if(s[g].containsBox(u)&&Na.isPointInPolygon(d[k.randInt(0,d.length-1)],m)){(t=r.get(g))==null||t.children.push(r.get(c));break}}p===o&&a.children.push(r.get(c))}return a}get area(){if(this._loops.length===0)return 0;let t=0;for(let e=0;e<this._loops.length;e++){const s=this._loops[e].getPoints(128),n=this.polygonArea(s);e===0?t+=Math.abs(n):t-=Math.abs(n)}return t}polygonArea(t){const e=t.length;if(e<3)return 0;let s=0;for(let n=0,r=e-1;n<e;r=n++){const o=t[r],a=t[n];s+=o.x*a.y-a.x*o.y}return s*.5}calculateBoundaryBoxes(t){const e=[];return t.forEach(s=>{e.push(new _t().setFromPoints(s))}),e}sortBoundaryBoxesByAreas(t){const e=[];t.forEach((n,r)=>{const o=n.size,a=o.width*o.height;e.push({area:a,index:r})}),e.sort((n,r)=>n.area-r.area);const s=[];return e.forEach(n=>{s.push(n.index)}),s}},ds=class extends mr{constructor(){super(),this.arcLengthDivisions=100}get startPoint(){return this.getPoint(0)}get endPoint(){return this.getPoint(1)}get length(){return this.getLength()}getPoint(t){throw new Error("AcGeCurve2d: .getPoint() not implemented.")}getPointAt(t){const e=this.getUtoTmapping(t);return this.getPoint(e)}getPoints(t=5){const e=[];for(let s=0;s<=t;s++)e.push(this.getPoint(s/t));return e}getSpacedPoints(t=5){const e=[];for(let s=0;s<=t;s++)e.push(this.getPointAt(s/t));return e}getLength(){const t=this.getLengths();return t[t.length-1]}getLengths(t=this.arcLengthDivisions){const e=[];let s,n=this.getPoint(0),r=0;e.push(0);for(let o=1;o<=t;o++)s=this.getPoint(o/t),r+=s.distanceTo(n),e.push(r),n=s;return e}getUtoTmapping(t,e){const s=this.getLengths();let n=0;const r=s.length;let o;e?o=e:o=t*s[r-1];let a=0,h=r-1,c;for(;a<=h;)if(n=Math.floor(a+(h-a)/2),c=s[n]-o,c<0)a=n+1;else if(c>0)h=n-1;else{h=n;break}if(n=h,s[n]===o)return n/(r-1);const d=s[n],u=s[n+1]-d,p=(o-d)/u;return(n+p)/(r-1)}getTangent(t){let e=t-1e-4,s=t+1e-4;e<0&&(e=0),s>1&&(s=1);const n=this.getPoint(e),r=this.getPoint(s),o=new v;return o.copy(r).sub(n).normalize(),o}getTangentAt(t){const e=this.getUtoTmapping(t);return this.getTangent(e)}},Te=class Un extends ds{constructor(t,e,s,n,r){super();const o=+(t!==void 0)+ +(e!==void 0)+ +(s!==void 0)+ +(n!==void 0)+ +(r!==void 0);if(o==3)typeof t=="object"&&typeof e=="object"&&typeof s=="object"?this.createByThreePoints(t,e,s):this.createByStartEndPointsAndBulge(t,e,s);else if(o==5){const a=t;this.center=new v(a.x,a.y),this.radius=e,this._clockwise=r,this._startAngle=this._clockwise?this._mirrorAngle(k.normalizeAngle(s)):k.normalizeAngle(s),this._endAngle=this._clockwise?this._mirrorAngle(k.normalizeAngle(n)):k.normalizeAngle(n)}else throw wt.ILLEGAL_PARAMETERS}createByThreePoints(t,e,s){const n=(M,X)=>({x:(M.x+X.x)/2,y:(M.y+X.y)/2}),r=(M,X)=>(X.y-M.y)/(X.x-M.x),o=M=>-1/M,a=n(t,e),h=n(e,s),c=r(t,e),d=r(e,s),u=o(c),p=o(d),g=(M,X,R,et)=>{const F=(et-X)/(M-R),Y=M*F+X;return{x:F,y:Y}},m=a.y-u*a.x,y=h.y-p*h.x,b=g(u,m,p,y),x=Math.sqrt(Math.pow(t.x-b.x,2)+Math.pow(t.y-b.y,2)),I=(M,X)=>Math.atan2(M.y-X.y,M.x-X.x),S=I(t,b),L=I(e,b),A=I(s,b),H=A>S&&A<L||S>A&&S<L||L>A&&L<S;this.center=b,this.radius=x,this._clockwise=!H,this._startAngle=S,this._endAngle=A}createByStartEndPointsAndBulge(t,e,s){let n,r,o;s<0?(n=Math.atan(-s)*4,r=new $(t),o=new $(e)):(n=Math.atan(s)*4,r=new $(e),o=new $(t));const a=new $().subVectors(o,r),h=a.length(),c=new $().addVectors(r,a.multiplyScalar(.5)),d=Math.abs(h/2/Math.tan(n/2)),u=a.normalize(),p=s<0?-Math.PI/2:Math.PI/2,g=new $(u.x*Math.cos(p)-u.y*Math.sin(p),u.y*Math.cos(p)+u.x*Math.sin(p));let m;n<Math.PI?s<0?m=c.add(g.multiplyScalar(d)):m=c.add(g.multiplyScalar(-d)):s<0?m=c.add(g.multiplyScalar(-d)):m=c.add(g.multiplyScalar(d)),s<0?(this._startAngle=Math.atan2(r.y-m.y,r.x-m.x),this._endAngle=Math.atan2(o.y-m.y,o.x-m.x)):(this._startAngle=Math.atan2(o.y-m.y,o.x-m.x),this._endAngle=Math.atan2(r.y-m.y,r.x-m.x)),this._clockwise=s<0,this.center=m,this.radius=o.sub(m).length()}get center(){return this._center}set center(t){this._center=new v(t.x,t.y),this._boundingBoxNeedsUpdate=!0}get radius(){return this._radius}set radius(t){this._radius=t,this._boundingBoxNeedsUpdate=!0}get startAngle(){return this._clockwise?this._mirrorAngle(this._startAngle):this._startAngle}set startAngle(t){this._startAngle=this._clockwise?this._mirrorAngle(k.normalizeAngle(t)):k.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get endAngle(){return this._clockwise?this._mirrorAngle(this._endAngle):this._endAngle}set endAngle(t){const e=this.startAngle==0&&t==G?t:k.normalizeAngle(t);this._endAngle=this._clockwise?this._mirrorAngle(e):e,this._boundingBoxNeedsUpdate=!0}_mirrorAngle(t){return(360-t*180/Math.PI)%360*Math.PI/180}_getInternalAngle(t){return this._clockwise?this._mirrorAngle(t):t}get deltaAngle(){const t=this._getInternalAngle(this.startAngle),e=this._getInternalAngle(this.endAngle);return this.clockwise?k.normalizeAngle(t-e):k.normalizeAngle(e-t)}get clockwise(){return this._clockwise}set clockwise(t){this._clockwise=t,this._boundingBoxNeedsUpdate=!0}get startPoint(){return this.getPointAtAngle(this.startAngle)}get endPoint(){return this.getPointAtAngle(this.endAngle)}get midPoint(){const t=this._getInternalAngle(this.startAngle),e=this._clockwise?k.normalizeAngle(t-this.deltaAngle/2):k.normalizeAngle(t+this.deltaAngle/2),s=this._clockwise?this._mirrorAngle(e):e;return this.getPointAtAngle(s)}get closed(){const t=this._getInternalAngle(this.startAngle),e=this._getInternalAngle(this.endAngle);return Math.abs(e-t)/Math.PI%2==0}calculateBoundingBox(){const t=[this.startPoint,this.endPoint],e=[0,Math.PI/2,Math.PI,3*Math.PI/2];for(const r of e){const o=this._getInternalAngle(r);k.isBetweenAngle(o,this._getInternalAngle(this.startAngle),this._getInternalAngle(this.endAngle),this.clockwise)&&t.push(this.getPointAtAngle(r))}const s=t.map(r=>r.x),n=t.map(r=>r.y);return new _t(new v(Math.min(...s),Math.min(...n)),new v(Math.max(...s),Math.max(...n)))}get length(){return Math.abs(this.deltaAngle*this.radius)}transform(t){const e=t,s=this.center.clone().applyMatrix2d(e),n=this.startPoint.clone().applyMatrix2d(e);if(this.closed)return this.center=s,this.radius=s.distanceTo(n),this._startAngle=Math.atan2(n.y-s.y,n.x-s.x),this._endAngle=this._startAngle,this._clockwise=e.determinant()<0?!this._clockwise:this._clockwise,this._boundingBoxNeedsUpdate=!0,this;const r=this.midPoint.clone().applyMatrix2d(e),o=this.endPoint.clone().applyMatrix2d(e),a=new Un(n,r,o),h=e.determinant()<0?!this.clockwise:this.clockwise,c=d=>{const u=k.normalizeAngle(d);return h?this._mirrorAngle(u):u};return this.center=a.center,this.radius=a.radius,this.clockwise=h,this.startAngle=c(Math.atan2(n.y-a.center.y,n.x-a.center.x)),this.endAngle=c(Math.atan2(o.y-a.center.y,o.x-a.center.x)),this._boundingBoxNeedsUpdate=!0,this}clone(){return new Un(this.center.clone(),this.radius,this._startAngle,this._endAngle,this.clockwise)}getPointAtAngle(t){const e=this._getInternalAngle(t),s=this.center.x+this.radius*Math.cos(e),n=this.center.y+this.radius*Math.sin(e);return new v(s,n)}getPoints(t=100){const e=[];let s=this.deltaAngle,n=this._getInternalAngle(this.startAngle);if(this.closed&&(s=G,n=0),this.clockwise)for(let r=0;r<=t;r++){const o=n-s*(r/t),a=this._clockwise?this._mirrorAngle(o):o,h=this.getPointAtAngle(a);e.push(new v(h.x,h.y))}else for(let r=0;r<=t;r++){const o=n+s*(r/t),a=this._clockwise?this._mirrorAngle(o):o,h=this.getPointAtAngle(a);e.push(new v(h.x,h.y))}return e}};class Ic extends Va{translate(t){return this.transform(new D().makeTranslation(t.x,t.y,t.z))}get box(){return(this._box==null||this._boundingBoxNeedsUpdate)&&(this._box=this.calculateBoundingBox(),this._boundingBoxNeedsUpdate=!1),this._box}}class si extends Ic{}class Ee extends si{constructor(t,e){super(),this._start=new w(t),this._end=new w(e)}get startPoint(){return this._start}set startPoint(t){this._start.copy(t),this._boundingBoxNeedsUpdate=!0}get endPoint(){return this._end}set endPoint(t){this._end.copy(t),this._boundingBoxNeedsUpdate=!0}get direction(){return new _().subVectors(this.endPoint,this.startPoint).normalize()}get midPoint(){return new w((this._start.x+this._end.x)/2,(this._start.y+this._end.y)/2,(this._start.z+this._end.z)/2)}nearestPoint(t){return this.project(t)}get length(){return this.startPoint.distanceTo(this.endPoint)}isPointOnLine(t){return this.project(t).distanceTo(t)<1e-6}at(t,e){return this.delta(e).multiplyScalar(t).add(this._start)}atLength(t,e=!1){if(e){const s=this.delta(Ce).normalize();return new w(this._start).addScaledVector(s,t)}else{const s=this.delta(Ce).normalize();return new w(this._end).addScaledVector(s,t)}}extend(t,e=!1){if(e){const s=Ce.subVectors(this._start,this._end).normalize();this._start=new w(this._start).addScaledVector(s,t)}else{const s=this.delta(Ce).normalize();this._end=new w(this._end).addScaledVector(s,t)}return this._boundingBoxNeedsUpdate=!0,this}closestPointToPointParameter(t,e){ko.subVectors(t,this._start),mi.subVectors(this.endPoint,this.startPoint);const s=mi.dot(mi);let n=mi.dot(ko)/s;return e&&(n=k.clamp(n,0,1)),n}closestPointToPoint(t,e,s){const n=this.closestPointToPointParameter(t,e);return this.delta(s).multiplyScalar(n).add(this._start)}delta(t){return t.subVectors(this._end,this._start)}distanceSq(){return this._start.distanceToSquared(this._end)}distance(){return this._start.distanceTo(this._end)}project(t){const e=this.direction,s=Ce.subVectors(t,this.startPoint).dot(e);return new w().copy(e).multiplyScalar(s).add(this.startPoint)}perpPoint(t){const e=this.direction,s=this.startPoint,n=Ce.subVectors(t,s).dot(e),r=Ce.copy(e).multiplyScalar(n);return new w().addVectors(s,r)}calculateBoundingBox(){const t=new w(Math.min(this._start.x,this._end.x),Math.min(this._start.y,this._end.y),Math.min(this._start.z,this._end.z)),e=new w(Math.max(this._start.x,this._end.x),Math.max(this._start.y,this._end.y),Math.max(this._start.z,this._end.z));return new N(t,e)}transform(t){return this._start.applyMatrix4(t),this._end.applyMatrix4(t),this._boundingBoxNeedsUpdate=!0,this}get closed(){return!1}copy(t){return this.startPoint=t.startPoint,this.endPoint=t.endPoint,this._boundingBoxNeedsUpdate=!0,this}clone(){return new Ee(this._start.clone(),this._end.clone())}}const Ce=new _,ko=new _,mi=new _;class Ie extends si{static computeCenterPoint(t,e,s){const n=new _().addVectors(t,e).multiplyScalar(.5),r=new _().addVectors(t,s).multiplyScalar(.5),o=new _().subVectors(e,t),a=new _().subVectors(s,t),h=new _().crossVectors(o,a).normalize();if(h.lengthSq()===0)return null;const c=new _().crossVectors(o,h).normalize(),d=new _().crossVectors(a,h).normalize(),u=c.clone().multiplyScalar(Number.MAX_SAFE_INTEGER),p=d.clone().multiplyScalar(Number.MAX_SAFE_INTEGER),g=new Ee(n,n.clone().add(u)),m=new Ee(r,r.clone().add(p)),y=new _;return g.closestPointToPoint(m.startPoint,!0,y)?y:null}static createByThreePoints(t,e,s){const n=Ie.computeCenterPoint(t,e,s);if(n){const r=n.distanceTo(t),o=new _().subVectors(t,n),a=new _().subVectors(e,n),h=Math.atan2(o.y,o.x),c=Math.atan2(a.y,a.x);return new Ie(n,r,h,c,_.Z_AXIS)}}constructor(t,e,s,n,r,o=_.X_AXIS){super(),this.center=t,this.radius=e,this.startAngle=s,this.endAngle=n,this.normal=r,this.refVec=o,(n-s)%G==0?(this.startAngle=0,this.endAngle=G):(this.startAngle=s,this.endAngle=n)}get center(){return this._center}set center(t){this._center=new w(t.x,t.y,t.z||0),this._boundingBoxNeedsUpdate=!0}get radius(){return this._radius}set radius(t){if(t<0)throw wt.ILLEGAL_PARAMETERS;this._radius=t,this._boundingBoxNeedsUpdate=!0}get startAngle(){return this._startAngle}set startAngle(t){this._startAngle=k.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get endAngle(){return this._endAngle}set endAngle(t){this._endAngle=this.startAngle==0&&t==G?t:k.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get deltaAngle(){return k.normalizeAngle(this.endAngle-this.startAngle)}get isLargeArc(){return Math.abs(this.deltaAngle)>Math.PI?1:0}get clockwise(){return this.deltaAngle<=0}get normal(){return this._normal}set normal(t){this._normal=new _(t.x,t.y,t.z),this._normal.normalize(),this._boundingBoxNeedsUpdate=!0}get refVec(){return this._refVec}set refVec(t){this._refVec=new _(t.x,t.y,t.z),this._refVec.normalize(),this._boundingBoxNeedsUpdate=!0}get startPoint(){return this.getPointAtAngle(this._startAngle)}get endPoint(){return this.getPointAtAngle(this._endAngle)}get midPoint(){let t=this.startAngle,e=this.deltaAngle;this.closed&&(t=0,e=G);const s=t+e*.5;return this.getPointAtAngle(s)}get length(){return this.closed?2*Math.PI*this.radius:Math.abs(this.deltaAngle*this.radius)}get area(){return this.closed?Math.PI*this.radius*this.radius:Math.abs(this.deltaAngle*this.radius*this.radius)}nearestPoint(t){const e=new _(t.x,t.y,t.z||0),s=this.center,n=this.normal,r=e.clone().sub(s).dot(n),o=e.clone().sub(n.clone().multiplyScalar(r)).clone().sub(s);if(o.lengthSq()===0)return this.startPoint.clone();o.normalize().multiplyScalar(this.radius);const a=s.clone().add(o),h=this.getAngle(a.clone()),c=this.startAngle,d=this.deltaAngle;let u=k.normalizeAngle(h-c);u<0&&(u=0),u>d&&(u=d);const p=this.getPointAtAngle(c+u),g=p.distanceTo(e),m=this.startPoint.distanceTo(e),y=this.endPoint.distanceTo(e);return m<g&&m<=y?this.startPoint.clone():y<g&&y<m?this.endPoint.clone():p}tangentPoints(t){const e=[],s=new _(t.x,t.y,t.z||0),n=this.center,r=this.normal,o=this.radius,a=s.clone().sub(n).dot(r),h=s.clone().sub(r.clone().multiplyScalar(a)),c=n.clone(),d=h.clone().sub(c).length();if(d<o)return e;const u=Math.acos(o/d),p=this.getAngle(h.clone()),g=[p+u,p-u];for(const m of g){const y=k.normalizeAngle(m-this.startAngle);y>=0&&y<=this.deltaAngle&&e.push(this.getPointAtAngle(this.startAngle+y))}return e}nearestTangentPoint(t){const e=this.tangentPoints(t);if(e.length===0)return null;const s=new w(t.x,t.y,t.z||0);return e.length===1||e[0].distanceTo(s)<e[1].distanceTo(s)?e[0]:e[1]}calculateBoundingBox(){const t=[this.startAngle,this.endAngle];for(let h=0;h<2*Math.PI;h+=Math.PI/2)k.isBetweenAngle(h,this.startAngle,this.endAngle)&&t.push(h);let e=1/0,s=1/0,n=1/0,r=-1/0,o=-1/0,a=-1/0;for(const h of t){const c=this.getPointAtAngle(h);c.x<e&&(e=c.x),c.y<s&&(s=c.y),c.z<n&&(n=c.z),c.x>r&&(r=c.x),c.y>o&&(o=c.y),c.z>a&&(a=c.z)}return new N({x:e,y:s,z:n},{x:r,y:o,z:a})}get closed(){return Math.abs(this.endAngle-this.startAngle)/Math.PI%2==0}getPoints(t){const e=[];let s=this.deltaAngle,n=this.startAngle;this.closed&&(s=G,n=0);for(let r=0;r<=t;r++){const o=n+s*(r/t),a=this.getPointAtAngle(o);e.push(a)}return e}transform(t){const e=this.center.clone().applyMatrix4(t),s=this.startPoint.clone().applyMatrix4(t),n=this.endPoint.clone().applyMatrix4(t),r=this.getPointAtAngle(this.closed?Math.PI/2:this.startAngle+this.deltaAngle/2).clone().applyMatrix4(t),o=new _(s).sub(e).normalize(),a=e.distanceTo(s);let h=new _().crossVectors(new _(s).sub(e),new _(r).sub(e)).normalize();h.lengthSq()===0&&(h=this.normal.clone().transformDirection(t));const c=d=>{const u=new _(d).sub(e);return Math.atan2(u.dot(vo.crossVectors(h,o)),u.dot(o))};return this.center=e,this.radius=a,this.normal=h,this.refVec=o,this.startAngle=0,this.endAngle=this.closed?G:c(n),this._boundingBoxNeedsUpdate=!0,this}copy(t){return this.center=t.center,this.radius=t.radius,this.startAngle=t.startAngle,this.endAngle=t.endAngle,this.normal=t.normal,this.refVec=t.refVec,this._boundingBoxNeedsUpdate=!0,this}clone(){return new Ie(this.center.clone(),this.radius,this.startAngle,this.endAngle,this.normal,this.refVec)}getAngle(t){return t.sub(this.center),Math.atan2(t.dot(vo.crossVectors(this.refVec,this.normal)),t.dot(this.refVec))}getPointAtAngle(t){const e=this.normal,s=this.refVec,n={x:e.y*s.z-e.z*s.y,y:e.z*s.x-e.x*s.z,z:e.x*s.y-e.y*s.x},r=this.center,o=this.radius;return new w(r.x+o*(s.x*Math.cos(t)+n.x*Math.sin(t)),r.y+o*(s.y*Math.cos(t)+n.y*Math.sin(t)),r.z+o*(s.z*Math.cos(t)+n.z*Math.sin(t)))}get plane(){const t=new _(this.center).distanceTo(cr);return new ei(this.normal,t)}}const vo=new _;let Hs=class Ai extends ds{constructor(t,e,s,n=0,r=G,o=!1,a=0){super(),this.center=t,this.majorAxisRadius=e,this.minorAxisRadius=s,(r-n)%G==0?(this.startAngle=0,this.endAngle=G):(this.startAngle=n,this.endAngle=r),this.clockwise=o,this.rotation=a}get center(){return this._center}set center(t){this._center=new w(t.x,t.y,t.z||0),this._boundingBoxNeedsUpdate=!0}get majorAxisRadius(){return this._majorAxisRadius}set majorAxisRadius(t){if(t<0)throw wt.ILLEGAL_PARAMETERS;this._majorAxisRadius=t,this._boundingBoxNeedsUpdate=!0}get minorAxisRadius(){return this._minorAxisRadius}set minorAxisRadius(t){if(t<0)throw wt.ILLEGAL_PARAMETERS;this._minorAxisRadius=t,this._boundingBoxNeedsUpdate=!0}get startAngle(){return this._startAngle}set startAngle(t){this._startAngle=k.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get endAngle(){return this._endAngle}set endAngle(t){this._endAngle=this.startAngle==0&&t==G?t:k.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get clockwise(){return this._clockwise}set clockwise(t){this._clockwise=t,this._boundingBoxNeedsUpdate=!0}get rotation(){return this._rotation}set rotation(t){this._rotation=t,this._boundingBoxNeedsUpdate=!0}get deltaAngle(){return k.normalizeAngle(this.endAngle-this.startAngle)}get isLargeArc(){return Math.abs(this.deltaAngle)>Math.PI?1:0}calculateBoundingBox(){let t=1/0,e=1/0,s=-1/0,n=-1/0;for(let r=0;r<=100;r++){const o=this.getPoint(r/100);t=Math.min(t,o.x),e=Math.min(e,o.y),s=Math.max(s,o.x),n=Math.max(n,o.y)}return new _t({x:t,y:e},{x:s,y:n})}get closed(){return this.deltaAngle==0}getPoint(t){const e=Math.PI*2;let s=this.endAngle-this.startAngle;const n=Math.abs(s)<Number.EPSILON;for(;s<0;)s+=e;for(;s>e;)s-=e;s<Number.EPSILON&&(n?s=0:s=e),this.clockwise===!0&&!n&&(s===e?s=-e:s=s-e);const r=this.startAngle+t*s;let o=this.center.x+this.majorAxisRadius*Math.cos(r),a=this.center.y+this.minorAxisRadius*Math.sin(r);if(this.rotation!==0){const h=Math.cos(this.rotation),c=Math.sin(this.rotation),d=o-this.center.x,u=a-this.center.y;o=d*h-u*c+this.center.x,a=d*c+u*h+this.center.y}return new v(o,a)}transform(t){const e=t,s=new v(this.center).applyMatrix2d(e),n=new w(s.x,s.y,this.center.z),r=this.getPointAtAngle(0).clone().applyMatrix2d(e),o=this.getPointAtAngle(Math.PI/2).clone().applyMatrix2d(e),a=new v(r).sub(s),h=new v(o).sub(s),c=a.length(),d=h.length(),u=Math.atan2(a.y,a.x),p=a.clone().normalize(),g=h.clone().normalize(),m=x=>{const I=new v(x).sub(s),S=I.dot(p),L=I.dot(g);return k.normalizeAngle(Math.atan2(L/d,S/c))},y=e.determinant()<0?!this.clockwise:this.clockwise,b=this.closed?new Ai(n,c,d,0,G,y,u):new Ai(n,c,d,m(this.startPoint.clone().applyMatrix2d(e)),m(this.endPoint.clone().applyMatrix2d(e)),y,u);return this.center=b.center,this.majorAxisRadius=b.majorAxisRadius,this.minorAxisRadius=b.minorAxisRadius,this._startAngle=b._startAngle,this._endAngle=b._endAngle,this._clockwise=b._clockwise,this.rotation=b.rotation,this._boundingBoxNeedsUpdate=!0,this}getPointAtAngle(t){return this.getPoint(this.closed?t/G:k.normalizeAngle(t-this.startAngle)/this.deltaAngle)}copy(t){return this.center=t.center,this.majorAxisRadius=t.majorAxisRadius,this.minorAxisRadius=t.minorAxisRadius,this.startAngle=t.startAngle,this.endAngle=t.endAngle,this.clockwise=t.clockwise,this.rotation=t.rotation,this}clone(){return new Ai(this.center,this.majorAxisRadius,this.minorAxisRadius,this.startAngle,this.endAngle,this.clockwise,this.rotation)}};class ls extends si{constructor(t,e,s,n,r,o=0,a=G){super(),this.center=t,this.normal=e,this.majorAxis=s,this.majorAxisRadius=n,this.minorAxisRadius=r;const h=Math.abs(a-o);Math.abs(h-G)<1e-10||Math.abs(h-2*G)<1e-10?(this.startAngle=0,this.endAngle=G):(this.startAngle=o,this.endAngle=a)}get center(){return this._center}set center(t){this._center=new w(t.x,t.y,t.z||0),this._boundingBoxNeedsUpdate=!0}get majorAxisRadius(){return this._majorAxisRadius}set majorAxisRadius(t){if(t<0)throw wt.ILLEGAL_PARAMETERS;this._majorAxisRadius=t,this._boundingBoxNeedsUpdate=!0}get minorAxisRadius(){return this._minorAxisRadius}set minorAxisRadius(t){if(t<0)throw wt.ILLEGAL_PARAMETERS;this._minorAxisRadius=t,this._boundingBoxNeedsUpdate=!0}get startAngle(){return this._startAngle}set startAngle(t){this._startAngle=k.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get endAngle(){return this._endAngle}set endAngle(t){this._endAngle=this.startAngle==0&&t==G?t:k.normalizeAngle(t),this._boundingBoxNeedsUpdate=!0}get deltaAngle(){const t=this.endAngle-this.startAngle;return Math.abs(t-G)<1e-10?G:k.normalizeAngle(t)}get isLargeArc(){return Math.abs(this.deltaAngle)>Math.PI?1:0}get clockwise(){return this.deltaAngle<=0}get normal(){return this._normal}set normal(t){this._normal=new _(t.x,t.y,t.z),this._normal.normalize(),this._boundingBoxNeedsUpdate=!0}get majorAxis(){return this._majorAxis}set majorAxis(t){this._majorAxis=new _(t.x,t.y,t.z),this._majorAxis.normalize(),this._boundingBoxNeedsUpdate=!0}get minorAxis(){return new _().crossVectors(this.normal,this.majorAxis).normalize()}get startPoint(){return this.getPointAtAngle(this._startAngle)}get endPoint(){return this.getPointAtAngle(this._endAngle)}get midPoint(){let t=this.startAngle,e=this.deltaAngle;(this.closed||Math.abs(e-G)<1e-10)&&(t=0,e=G);const s=t+e/2;return this.getPointAtAngle(s)}get isCircular(){return ti.equal(this.majorAxisRadius,this.minorAxisRadius)}get length(){if(this.isCircular)return this.majorAxisRadius*Math.abs(this.deltaAngle);const t=1e3,e=this.deltaAngle/t;let s=0,n=this.getPointAtAngle(this.startAngle);for(let r=1;r<=t;r++){const o=this.startAngle+r*e,a=this.getPointAtAngle(o),h=a.x-n.x,c=a.y-n.y,d=a.z-n.z;s+=Math.sqrt(h*h+c*c+d*d),n=a}return s}get area(){const t=this.majorAxisRadius,e=this.minorAxisRadius,s=this.startAngle,n=s+this.deltaAngle;if(Math.abs(this.deltaAngle-G)<1e-10)return Math.PI*t*e;const r=t*e/2*(n-s-(Math.sin(n)*Math.cos(n)-Math.sin(s)*Math.cos(s)));return Math.abs(r)}calculateBoundingBox(){if(this.majorAxis.equals(_.X_AXIS)||this.majorAxis.equals(_.Y_AXIS)||this.majorAxis.isParallelTo(_.X_AXIS)||this.majorAxis.isParallelTo(_.Y_AXIS)){const t=[this.startAngle,this.endAngle];for(let h=0;h<2*Math.PI;h+=Math.PI/2)k.isBetweenAngle(h,this.startAngle,this.endAngle)&&t.push(h);let e=1/0,s=1/0,n=1/0,r=-1/0,o=-1/0,a=-1/0;for(const h of t){const c=this.getPointAtAngle(h);c.x<e&&(e=c.x),c.y<s&&(s=c.y),c.z<n&&(n=c.z),c.x>r&&(r=c.x),c.y>o&&(o=c.y),c.z>a&&(a=c.z)}return new N({x:e,y:s,z:n},{x:r,y:o,z:a})}else{let t=1/0,e=1/0,s=1/0,n=-1/0,r=-1/0,o=-1/0;for(let a=0;a<=100;a++){const h=this.startAngle+this.deltaAngle*(a/100),c=this.getPointAtAngle(h);t=Math.min(t,c.x),e=Math.min(e,c.y),s=Math.min(s,c.z),n=Math.max(n,c.x),r=Math.max(r,c.y),o=Math.max(o,c.z)}return new N({x:t,y:e,z:s},{x:n,y:r,z:o})}}get closed(){return this.deltaAngle==0}getPoints(t=100){const e=[];let s=this.deltaAngle,n=this.startAngle;this.closed&&(s=G,n=0);for(let r=0;r<=t;r++){const o=n+s*(r/t),a=this.getPointAtAngle(o);e.push(a)}return e}getPointAtAngle(t){const e=Math.cos(t),s=Math.sin(t),n=this.minorAxis.clone().multiplyScalar(this.minorAxisRadius).multiplyScalar(s),r=this.majorAxis.clone().multiplyScalar(e*this.majorAxisRadius).add(n);return new w(this.center.x+r.x,this.center.y+r.y,this.center.z+r.z)}contains(t){const e=new _(t).sub(this.center),s=e.dot(this.majorAxis),n=e.dot(this.minorAxis),r=s/this.majorAxisRadius,o=n/this.minorAxisRadius;return r*r+o*o<=1}transform(t){const e=t,s=this.center.clone().applyMatrix4(e),n=this.getPointAtAngle(0).clone().applyMatrix4(e),r=this.getPointAtAngle(Math.PI/2).clone().applyMatrix4(e),o=new _(n).sub(s),a=new _(r).sub(s),h=o.length(),c=a.length(),d=o.clone().normalize(),u=new _().crossVectors(o,a).normalize();let p=new _().crossVectors(u,d).normalize();p.dot(a)<0&&(u.negate(),p=new _().crossVectors(u,d).normalize());const g=y=>{const b=new _(y).sub(s),x=b.dot(d),I=b.dot(p);return k.normalizeAngle(Math.atan2(I/c,x/h))},m=this.closed?new ls(s,u,d,h,c,0,G):new ls(s,u,d,h,c,g(this.startPoint.clone().applyMatrix4(e)),g(this.endPoint.clone().applyMatrix4(e)));return this.center=m.center,this.normal=m.normal,this.majorAxis=m.majorAxis,this.majorAxisRadius=m.majorAxisRadius,this.minorAxisRadius=m.minorAxisRadius,this._startAngle=m._startAngle,this._endAngle=m._endAngle,this._boundingBoxNeedsUpdate=!0,this}copy(t){return this.center=t.center,this.normal=t.normal,this.majorAxis=t.majorAxis,this.majorAxisRadius=t.majorAxisRadius,this.minorAxisRadius=t.minorAxisRadius,this.startAngle=t.startAngle,this.endAngle=t.endAngle,this._boundingBoxNeedsUpdate=!0,this}clone(){return new ls(this.center,this.normal,this.majorAxis,this.majorAxisRadius,this.minorAxisRadius,this.startAngle,this.endAngle)}get plane(){const t=new _(this.center).distanceTo(cr);return new ei(this.normal,t)}}class at extends ds{constructor(t=null,e=!1){super(),this._vertices=t||new Array,this._closed=e}get vertices(){return this._vertices}get numberOfVertices(){return this._vertices.length}get closed(){return this._closed}get startPoint(){if(this.numberOfVertices>0){const t=this._vertices[0];return new v(t.x,t.y)}throw new Error("Start point does not exist in an empty polyline.")}get endPoint(){const t=this.numberOfVertices;if(t>0)if(this.closed){const e=this._vertices[0];return new v(e.x,e.y)}else{const e=this._vertices[t-1];return new v(e.x,e.y)}throw new Error("End point does not exist in an empty polyline.")}get length(){let t=0;const e=this._vertices.length;for(let s=0;s<e;++s){const n=this._vertices[s];let r=null;if(s<e-1?r=this._vertices[s+1]:s==e-1&&this.closed&&(r=this._vertices[0]),r)if(n.bulge){const o=new Te(n,r,n.bulge);t+=o.length}else t+=new v(n.x,n.y).distanceTo(r)}return t}set closed(t){this._closed=t,this._boundingBoxNeedsUpdate=!0}addVertexAt(t,e){t<=0?this._vertices.unshift(e):this._vertices.splice(t,0,e),this._boundingBoxNeedsUpdate=!0}removeVertexAt(t){if(t<0||t>=this._vertices.length)throw new Error(`Index ${t} is out of bounds. Valid range is 0 to ${this._vertices.length-1}.`);this._vertices.splice(t,1),this._boundingBoxNeedsUpdate=!0}reset(t,e){t?e!==void 0&&e>=0&&e<this._vertices.length&&(this._vertices=this._vertices.slice(0,e),this._boundingBoxNeedsUpdate=!0):(this._vertices=new Array,this._boundingBoxNeedsUpdate=!0)}getPointAt(t){const e=this._vertices[t];return new v(e.x,e.y)}calculateBoundingBox(){const t=this.getPoints(100);return new _t().setFromPoints(t)}transform(t){const e=t.determinant()<0;return this._vertices.forEach(s=>{const n=new v(s).applyMatrix2d(t);s.x=n.x,s.y=n.y,e&&s.bulge!=null&&(s.bulge=-s.bulge)}),this._boundingBoxNeedsUpdate=!0,this}clone(){return new at(this._vertices.map(t=>({...t})),this._closed)}getPoints3d(t,e){const s=[];return this.getPoints(t).forEach(n=>s.push(new w().set(n.x,n.y,e))),s}getPoints(t){const e=[],s=this._vertices.length;for(let n=0;n<s;++n){const r=this._vertices[n];if(r.bulge){let o=null;if(n<s-1?o=this._vertices[n+1]:n==s-1&&this.closed&&(o=this._vertices[0]),o){const a=new Te(r,o,r.bulge).getPoints(t),h=a.length;for(let c=0;c<h;++c){const d=a[c];e.push(new v(d.x,d.y))}}}else e.push(new v(r.x,r.y)),n==s-1&&this.closed&&e.push(e[0])}return e}}class Wt extends ds{constructor(t,e){super(),this._start=new v(t),this._end=new v(e)}get startPoint(){return this._start}set startPoint(t){this._start.copy(t),this._boundingBoxNeedsUpdate=!0}get endPoint(){return this._end}set endPoint(t){this._end.copy(t),this._boundingBoxNeedsUpdate=!0}getPoints(){return[this.startPoint,this.endPoint]}get length(){return this.startPoint.distanceTo(this.endPoint)}calculateBoundingBox(){const t=new v(Math.min(this._start.x,this._end.x),Math.min(this._start.y,this._end.y)),e=new v(Math.max(this._start.x,this._end.x),Math.max(this._start.y,this._end.y));return new _t(t,e)}transform(t){return this._start.applyMatrix2d(t),this._end.applyMatrix2d(t),this._boundingBoxNeedsUpdate=!0,this}get closed(){return!1}copy(t){return this.startPoint=t.startPoint,this.endPoint=t.endPoint,this._boundingBoxNeedsUpdate=!0,this}clone(){return new Wt(this._start.clone(),this._end.clone())}}let Gs=class Bt extends ds{constructor(t=[]){super(),this._curves=t}get curves(){return this._curves}static buildFromEdges(t,e=.001){if(t.length===0)return[];const s=[...t],n=[],r=e*e,o=(a,h)=>{const c=a.x-h.x,d=a.y-h.y;return c*c+d*d<=r};for(;s.length>0;){const a=[],h=s.shift();a.push(h);const c=Bt.getEdgeStartPoint(h);let d=Bt.getEdgeEndPoint(h);if(!o(c,d))for(;s.length>0;){const u=Bt.findConnectingEdge(s,d,r);if(u.index<0)break;let p=s.splice(u.index,1)[0];if(u.reverse&&(p=Bt.reverseEdge(p)),a.push(p),d=Bt.getEdgeEndPoint(p),o(d,c))break}n.push(new Bt(a))}return n}add(t){this._curves.push(t),this._boundingBoxNeedsUpdate=!0}get numberOfEdges(){return this._curves.length}get startPoint(){if(this._curves.length>0){const t=this._curves[0].startPoint;return new v(t.x,t.y)}throw new Error("Start point does not exist in an empty loop.")}get endPoint(){return this.startPoint}get length(){let t=0;return this._curves.forEach(e=>{t+=e.length}),t}calculateBoundingBox(){const t=this.getPoints(100),e=new _t;return e.setFromPoints(t),e}transform(t){const e=new D().set(t.elements[0],t.elements[3],0,t.elements[6],t.elements[1],t.elements[4],0,t.elements[7],0,0,1,0,0,0,0,1);return this._curves.forEach(s=>{s instanceof Ht?s.transform(e):s.transform(t)}),this._boundingBoxNeedsUpdate=!0,this}clone(){return new Bt(this._curves.map(t=>t.clone()))}get closed(){return!0}getPoints(t){const e=[];return this.curves.forEach(s=>{s.getPoints(t).forEach(n=>{e.push(new v(n.x,n.y))})}),e}static findConnectingEdge(t,e,s){let n=-1,r=!1,o=Number.POSITIVE_INFINITY;for(let a=0;a<t.length;a++){const h=t[a],c=Bt.getEdgeStartPoint(h),d=Bt.getEdgeEndPoint(h),u=e.x-c.x,p=e.y-c.y,g=u*u+p*p;g<o&&(o=g,n=a,r=!1);const m=e.x-d.x,y=e.y-d.y,b=m*m+y*y;b<o&&(o=b,n=a,r=!0)}return o>s?{index:-1,reverse:!1}:{index:n,reverse:r}}static getEdgeStartPoint(t){const e=t.startPoint;return new v(e.x,e.y)}static getEdgeEndPoint(t){const e=t.endPoint;return new v(e.x,e.y)}static reverseEdge(t){return t instanceof Wt?new Wt(t.endPoint,t.startPoint):t instanceof Te?new Te(t.center,t.radius,t.endAngle,t.startAngle,!t.clockwise):t instanceof Hs?new Hs(t.center,t.majorAxisRadius,t.minorAxisRadius,t.endAngle,t.startAngle,!t.clockwise,t.rotation):t instanceof Ht?Bt.reverseSplineEdge(t):t}static reverseSplineEdge(t){const e=[...t.controlPoints].reverse(),s=t.knots,n=s[0],r=s[s.length-1],o=s.map(c=>n+r-c).reverse(),a=t.weights,h=a.length>0?[...a].reverse():void 0;return new Ht(e,o,h,t.degree,t.closed)}};class An{constructor(){this.c0=0,this.c1=0,this.c2=0,this.c3=0}init(t,e,s,n){this.c0=t,this.c1=s,this.c2=-3*t+3*e-2*s-n,this.c3=2*t-2*e+s+n}initCatmullRom(t,e,s,n,r){this.init(e,s,r*(s-t),r*(n-e))}initNonuniformCatmullRom(t,e,s,n,r,o,a){let h=(e-t)/r-(s-t)/(r+o)+(s-e)/o,c=(s-e)/o-(n-e)/(o+a)+(n-s)/a;h*=o,c*=o,this.init(e,s,h,c)}calc(t){const e=t*t,s=e*t;return this.c0+this.c1*t+this.c2*e+this.c3*s}}class pn extends si{constructor(t=[],e=!1,s="centripetal",n=.5){super(),this.isCatmullRomCurve3d=!0,this.type="CatmullRomCurve3d",this._tmp=new _,this._px=new An,this._py=new An,this._pz=new An,this._points=t.map(r=>new w(r)),this._closed=e,this._curveType=s,this._tension=n}get points(){return this._points}get closed(){return this._closed}get curveType(){return this._curveType}get tension(){return this._tension}get startPoint(){return this._points.length>0?this._points[0]:new w}get endPoint(){return this._points.length>0?this._points[this._points.length-1]:new w}get length(){if(this._points.length<2)return 0;let t=0;for(let e=1;e<this._points.length;e++)t+=this._points[e-1].distanceTo(this._points[e]);return this._closed&&this._points.length>2&&(t+=this._points[this._points.length-1].distanceTo(this._points[0])),t}getPoint(t,e=new w){const s=e,n=this._points,r=n.length;if(r===0)return s.set(0,0,0);if(r===1)return s.copy(n[0]);const o=(r-(this._closed?0:1))*t;let a=Math.floor(o),h=o-a;this._closed?a+=a>0?0:(Math.floor(Math.abs(a)/r)+1)*r:h===0&&a===r-1&&(a=r-2,h=1);let c,d;this._closed||a>0?c=n[(a-1)%r]:(this._tmp.subVectors(n[0],n[1]).add(n[0]),c=new w(this._tmp.x,this._tmp.y,this._tmp.z));const u=n[a%r],p=n[(a+1)%r];if(this._closed||a+2<r?d=n[(a+2)%r]:(this._tmp.subVectors(n[r-1],n[r-2]).add(n[r-1]),d=new w(this._tmp.x,this._tmp.y,this._tmp.z)),this._curveType==="centripetal"||this._curveType==="chordal"){const g=this._curveType==="chordal"?.5:.25;let m=Math.pow(c.distanceToSquared(u),g),y=Math.pow(u.distanceToSquared(p),g),b=Math.pow(p.distanceToSquared(d),g);y<1e-4&&(y=1),m<1e-4&&(m=y),b<1e-4&&(b=y),this._px.initNonuniformCatmullRom(c.x,u.x,p.x,d.x,m,y,b),this._py.initNonuniformCatmullRom(c.y,u.y,p.y,d.y,m,y,b),this._pz.initNonuniformCatmullRom(c.z,u.z,p.z,d.z,m,y,b)}else this._curveType==="catmullrom"&&(this._px.initCatmullRom(c.x,u.x,p.x,d.x,this._tension),this._py.initCatmullRom(c.y,u.y,p.y,d.y,this._tension),this._pz.initCatmullRom(c.z,u.z,p.z,d.z,this._tension));return s.set(this._px.calc(h),this._py.calc(h),this._pz.calc(h)),s}getPoints(t){const e=[];for(let s=0;s<=t;s++)e.push(this.getPoint(s/t));return e}setPoints(t){this._points=t.map(e=>new w(e)),this._boundingBoxNeedsUpdate=!0}setClosed(t){this._closed!==t&&(this._closed=t,this._boundingBoxNeedsUpdate=!0)}setCurveType(t){this._curveType=t}setTension(t){this._tension=t}clone(){return new pn(this._points.map(t=>t.clone()),this._closed,this._curveType,this._tension)}transform(t){return this._points=this._points.map(e=>{const s=new w;return s.copy(e),s.applyMatrix4(t),s}),this._boundingBoxNeedsUpdate=!0,this}calculateBoundingBox(){if(this._points.length===0)return new N;const t=new N;return this._points.forEach(e=>{t.expandByPoint(e)}),t}}let Rt=class vs{constructor(t,e,s,n){this._degree=t,this._knots=[...e],this._controlPoints=s.map(r=>({x:r.x,y:r.y,z:r.z})),this._weights=n?[...n]:new Array(s.length).fill(1)}degree(){return this._degree}knots(){return[...this._knots]}controlPoints(){return this._controlPoints.map(t=>({x:t.x,y:t.y,z:t.z}))}weights(){return[...this._weights]}clone(){return new vs(this._degree,this._knots,this._controlPoints,this._weights)}point(t){const e=this._controlPoints.map(s=>[s.x,s.y,s.z]);return Bs(t,this._degree,this._knots,e,this._weights)}length(){const t=this._controlPoints.map(e=>[e.x,e.y,e.z]);return Fa(this._degree,this._knots,t,this._weights)}static byKnotsControlPointsWeights(t,e,s,n){return new vs(t,e,s,n)}static byPoints(t,e,s="Uniform",n,r){const o=gr(t,e,s,n,r),a=o.controlPoints.map(h=>({x:h[0],y:h[1],z:h[2]}));return new vs(e,o.knots,a,o.weights)}getParameterRange(){const t=this._knots[this._degree],e=this._knots[this._knots.length-this._degree-1];return{start:t,end:e}}getPoints(t){const e=[],{start:s,end:n}=this.getParameterRange();for(let r=0;r<=t;r++){const o=s+(n-s)*(r/t);e.push(this.point(o))}return e}isClosed(t=1e-6){const{start:e,end:s}=this.getParameterRange(),n=this.point(e),r=this.point(s),o=n[0]-r[0],a=n[1]-r[1],h=n[2]-r[2];return Math.sqrt(o*o+a*a+h*h)<t}static createFitPointsForClosedCurve(t){if(t.length<4)throw new Error("At least 4 points are required for a closed NURBS curve");const e=new pn(t,!0,"centripetal"),s=Math.max(50,t.length*2);return e.getPoints(s)}static createClosedCurve(t,e,s="Chord"){const n=this.createFitPointsForClosedCurve(t).map(r=>[r.x,r.y,r.z]);return vs.byPoints(n,e,s)}},Ht=class Pi extends si{constructor(t,e,s,n,r,o){super();const a=arguments.length;if(this._degree=3,this._closed=!1,Array.isArray(e)){if(a<2||a>5)throw wt.ILLEGAL_PARAMETERS;this._controlPoints=t;let h,c=3,d=!1;if(a>=3&&(Array.isArray(s)?(h=s,a>=4&&(c=n||3),a>=5&&(d=r)):s!==void 0&&(c=s||3,a>=4&&(d=n))),s===void 0&&a>=4&&(c=n||3,a>=5&&(d=r)),this._degree=c,this._closed=d,this._controlPoints.length<this._degree+1)throw wt.ILLEGAL_PARAMETERS;this._nurbsCurve=Rt.byKnotsControlPointsWeights(this._degree,e,this._controlPoints,h)}else{if(a<2||a>6)throw wt.ILLEGAL_PARAMETERS;this._fitPoints=t,this._knotParameterization=e,a>=3&&(this._degree=s||3);const h=typeof n=="boolean";a>=4&&h&&(this._closed=n),h?(a>=5&&(this._startTangent=r),a>=6&&(this._endTangent=o)):(a>=4&&(this._startTangent=n),a>=5&&(this._endTangent=r)),this._closed&&(this._startTangent=void 0,this._endTangent=void 0);const c=(this._startTangent?1:0)+(this._endTangent?1:0);if(this._fitPoints.length+c<this._degree+1)throw wt.ILLEGAL_PARAMETERS;if(this._closed)this._nurbsCurve=Rt.createClosedCurve(this._fitPoints,this._degree,this._knotParameterization);else{const d=this.toNurbsPoints(this._fitPoints);this._nurbsCurve=Rt.byPoints(d,this._degree,this._knotParameterization,this._startTangent?this.toNurbsPoint(this._startTangent):void 0,this._endTangent?this.toNurbsPoint(this._endTangent):void 0)}this._controlPoints=this.toGePoints(this._nurbsCurve.controlPoints().map(d=>[d.x,d.y,d.z||0]))}}buildCurve(){if(this._fitPoints&&this._knotParameterization){if(this._closed){const t=Rt.createFitPointsForClosedCurve(this._fitPoints),e=this.toNurbsPoints(t);this._nurbsCurve=Rt.byPoints(e,this._degree,this._knotParameterization)}else{const t=this.toNurbsPoints(this._fitPoints);this._nurbsCurve=Rt.byPoints(t,this._degree,this._knotParameterization,this._startTangent?this.toNurbsPoint(this._startTangent):void 0,this._endTangent?this.toNurbsPoint(this._endTangent):void 0)}this._controlPoints=this.toGePoints(this._nurbsCurve.controlPoints().map(t=>[t.x,t.y,t.z||0]))}else if(this._controlPoints)if(this._closed){const t=Rt.createFitPointsForClosedCurve(this._controlPoints),e=this.toNurbsPoints(t);this._nurbsCurve=Rt.byPoints(e,this._degree,this._knotParameterization),this._controlPoints=this.toGePoints(this._nurbsCurve.controlPoints().map(s=>[s.x,s.y,s.z||0]))}else{const t=this._nurbsCurve.knots(),e=this._nurbsCurve.weights();this._nurbsCurve=Rt.byKnotsControlPointsWeights(this._degree,t,this._controlPoints,e)}}setClosed(t){this._closed!==t&&(this._closed=t,this._boundingBoxNeedsUpdate=!0,this.buildCurve())}get degree(){return this._degree}get knotParameterization(){return this._knotParameterization}get controlPoints(){return this._controlPoints.map(t=>({x:t.x,y:t.y,z:t.z||0}))}get fitPoints(){var t;return(t=this._fitPoints)==null?void 0:t.map(e=>({x:e.x,y:e.y,z:e.z||0}))}get knots(){return[...this._nurbsCurve.knots()]}get weights(){return[...this._nurbsCurve.weights()]}get startPoint(){const t=this._nurbsCurve.knots(),e=this._nurbsCurve.degree(),s=t[e],n=this._nurbsCurve.point(s);return new w(n[0],n[1],n[2])}get endPoint(){const t=this._nurbsCurve.knots(),e=this._nurbsCurve.degree(),s=t[t.length-e-1],n=this._nurbsCurve.point(s);return new w(n[0],n[1],n[2])}get length(){return this._nurbsCurve.length()}getFitPointAt(t){if(!this._fitPoints)throw new Error("No fit points in this spline");const e=this._fitPoints.length,s=t<0||t>=e?e-1:t,n=this._fitPoints[s];return{x:n.x,y:n.y,z:n.z||0}}getControlPointAt(t){const e=this._controlPoints.length,s=t<0||t>=e?e-1:t;return this._controlPoints[s]}getPoints(t=100){const e=this._nurbsCurve,s=[],n=e.knots(),r=this._nurbsCurve.degree(),o=n[r],a=n[n.length-r-1],h=(a-o)/(t-1);for(let c=0;c<t;c++){const d=c===t-1?a:o+c*h,u=e.point(d);s.push(new w(u[0],u[1],u[2]))}return s}getCurvePoints(t,e){const s=[],n=t.knots(),r=t.degree(),o=n[r],a=(n[n.length-r-1]-o)/(e-1);for(let h=0;h<e;h++){const c=o+h*a;s.push(t.point(c))}return s}calculateBoundingBox(){const t=this.getPoints(100);return new N().setFromPoints(t)}get closed(){return this._closed}set closed(t){this.setClosed(t)}transform(t){if(this._fitPoints&&this._knotParameterization)this._fitPoints=this._fitPoints.map(e=>new w(e).applyMatrix4(t)),this._startTangent&&(this._startTangent=new w(this._startTangent).transformDirection(t)),this._endTangent&&(this._endTangent=new w(this._endTangent).transformDirection(t)),this.buildCurve();else{const e=this._nurbsCurve.knots(),s=this._nurbsCurve.weights();this._controlPoints=this._controlPoints.map(n=>new w(n).applyMatrix4(t)),this._nurbsCurve=Rt.byKnotsControlPointsWeights(this._degree,e,this._controlPoints,s.length>0?s:void 0)}return this._boundingBoxNeedsUpdate=!0,this}clone(){return this._fitPoints&&this._knotParameterization?new Pi(this._fitPoints.map(t=>({x:t.x,y:t.y,z:t.z||0})),this._knotParameterization,this._degree,this._closed,this._startTangent?{x:this._startTangent.x,y:this._startTangent.y,z:this._startTangent.z||0}:void 0,this._endTangent?{x:this._endTangent.x,y:this._endTangent.y,z:this._endTangent.z||0}:void 0):new Pi(this._controlPoints.map(t=>({x:t.x,y:t.y,z:t.z||0})),this._nurbsCurve.knots(),this._nurbsCurve.weights(),this._degree,this._closed)}toNurbsPoints(t){const e=new Array(t.length);return t.forEach((s,n)=>{e[n]=[s.x,s.y,s.z||0]}),e}toGePoints(t){const e=new Array(t.length);return t.forEach((s,n)=>{e[n]={x:s[0],y:s[1],z:s[2]}}),e}toNurbsPoint(t){return[t.x,t.y,t.z||0]}static createClosedSpline(t,e="Uniform",s=3){if(t.length<s+1)throw new Error(`At least ${s+1} points are required for a degree ${s} closed spline`);return new Pi(t,e,s,!0)}};var yr=(i=>(i.ClosedFilled="",i.Dot="_DOT",i.DotSmall="_DOTSMALL",i.DotBlank="_DOTBLANK",i.Origin="_ORIGIN",i.Origin2="_ORIGIN2",i.Open="_OPEN",i.Open90="_OPEN90",i.Open30="_OPEN30",i.Closed="_CLOSED",i.Small="_SMALL",i.None="_NONE",i.Oblique="_OBLIQUE",i.BoxFilled="_BOXFILLED",i.Box="_BOXBLANK",i.ClosedBlank="_CLOSEDBLANK",i.DatumBlank="_DATUMBLANK",i.DatumFilled="_DATUMFILLED",i.Integral="_INTEGRAL",i.ArchTick="_ARCHTICK",i))(yr||{}),Qe=(i=>(i[i.ByBlock=-2]="ByBlock",i[i.ByDIPs=-4]="ByDIPs",i[i.ByLayer=-1]="ByLayer",i[i.ByLineWeightDefault=-3]="ByLineWeightDefault",i[i.LineWeight000=0]="LineWeight000",i[i.LineWeight005=5]="LineWeight005",i[i.LineWeight009=9]="LineWeight009",i[i.LineWeight013=13]="LineWeight013",i[i.LineWeight015=15]="LineWeight015",i[i.LineWeight018=18]="LineWeight018",i[i.LineWeight020=20]="LineWeight020",i[i.LineWeight025=25]="LineWeight025",i[i.LineWeight030=30]="LineWeight030",i[i.LineWeight035=35]="LineWeight035",i[i.LineWeight040=40]="LineWeight040",i[i.LineWeight050=50]="LineWeight050",i[i.LineWeight053=53]="LineWeight053",i[i.LineWeight060=60]="LineWeight060",i[i.LineWeight070=70]="LineWeight070",i[i.LineWeight080=80]="LineWeight080",i[i.LineWeight090=90]="LineWeight090",i[i.LineWeight100=100]="LineWeight100",i[i.LineWeight106=106]="LineWeight106",i[i.LineWeight120=120]="LineWeight120",i[i.LineWeight140=140]="LineWeight140",i[i.LineWeight158=158]="LineWeight158",i[i.LineWeight200=200]="LineWeight200",i[i.LineWeight211=211]="LineWeight211",i))(Qe||{}),Dt=(i=>(i[i.LEFT_TO_RIGHT=1]="LEFT_TO_RIGHT",i[i.RIGHT_TO_LEFT=2]="RIGHT_TO_LEFT",i[i.TOP_TO_BOTTOM=3]="TOP_TO_BOTTOM",i[i.BOTTOM_TO_TOP=4]="BOTTOM_TO_TOP",i[i.BY_STYLE=5]="BY_STYLE",i))(Dt||{}),ot=(i=>(i[i.TopLeft=1]="TopLeft",i[i.TopCenter=2]="TopCenter",i[i.TopRight=3]="TopRight",i[i.MiddleLeft=4]="MiddleLeft",i[i.MiddleCenter=5]="MiddleCenter",i[i.MiddleRight=6]="MiddleRight",i[i.BottomLeft=7]="BottomLeft",i[i.BottomCenter=8]="BottomCenter",i[i.BottomRight=9]="BottomRight",i))(ot||{}),_r=(i=>(i[i.OPTIMIZED_2D=0]="OPTIMIZED_2D",i[i.WIREFRAME=1]="WIREFRAME",i[i.HIDDEN_LINE=2]="HIDDEN_LINE",i[i.FLAT_SHADED=3]="FLAT_SHADED",i[i.GOURAUD_SHADED=4]="GOURAUD_SHADED",i[i.FLAT_SHADED_WITH_WIREFRAME=5]="FLAT_SHADED_WITH_WIREFRAME",i[i.GOURAUD_SHADED_WITH_WIREFRAME=6]="GOURAUD_SHADED_WITH_WIREFRAME",i))(_r||{}),xr=(i=>(i[i.NON_ORTHOGRAPHIC=0]="NON_ORTHOGRAPHIC",i[i.TOP=1]="TOP",i[i.BOTTOM=2]="BOTTOM",i[i.FRONT=3]="FRONT",i[i.BACK=4]="BACK",i[i.LEFT=5]="LEFT",i[i.RIGHT=6]="RIGHT",i))(xr||{}),wr=(i=>(i[i.ONE_DISTANT_LIGHT=0]="ONE_DISTANT_LIGHT",i[i.TWO_DISTANT_LIGHTS=1]="TWO_DISTANT_LIGHTS",i))(wr||{});let ja=class Wa{constructor(){this._number=-1,this._id="",this._groupId="",this._centerPoint=new w,this._height=0,this._width=0,this._viewCenter=new w,this._viewHeight=0}get number(){return this._number}set number(t){this._number=t}get id(){return this._id}set id(t){this._id=t}get groupId(){return this._groupId}set groupId(t){this._groupId=t}get centerPoint(){return this._centerPoint}set centerPoint(t){this._centerPoint.copy(t)}get height(){return this._height}set height(t){this._height=t}get width(){return this._width}set width(t){this._width=t}get box(){const t=new _t;return t.setFromCenterAndSize(this.centerPoint,{x:this.width,y:this.height}),t}get viewCenter(){return this._viewCenter}set viewCenter(t){this._viewCenter.copy(t)}get viewHeight(){return this._viewHeight}set viewHeight(t){this._viewHeight=t}get viewWidth(){return this.viewHeight*(this.width/this.height)}get viewBox(){const t=new _t;return t.setFromCenterAndSize(this.viewCenter,{x:this.viewWidth,y:this.viewHeight}),t}clone(){const t=new Wa;return t.id=this.id,t.groupId=this.groupId,t.number=this.number,t.centerPoint.copy(this.centerPoint),t.height=this.height,t.width=this.width,t.viewCenter.copy(this.viewCenter),t.viewHeight=this.viewHeight,t}copy(t){return this.id=t.id,this.groupId=t.groupId,this.number=t.number,this.centerPoint.copy(t.centerPoint),this.height=t.height,this.width=t.width,this.viewCenter.copy(t.viewCenter),this.viewHeight=t.viewHeight,this}};const Cr=class Cr extends Ft{constructor(){super(...arguments),this._visibility=!0,this._transparency=new gn}get type(){return this.constructor.typeName}get layer(){return this._layer==null&&(this._layer=this.database.clayer??"0"),this._layer}set layer(t){this._layer=t}get color(){return this._color==null&&(this._color=new j,this.database.cecolor&&this._color.copy(this.database.cecolor)),this._color}set color(t){this._color==null&&(this._color=new j),this._color.copy(t)}get resolvedColor(){var e;let t=this.color;if(t.isByLayer){const s=this.getLayerColor();s&&s.RGB!=null&&(t=s)}else if(t.isByBlock){const s=this.database.cecolor;if(s&&(t=s,t.isByLayer)){const n=this.database.clayer||this.layer,r=this.database.tables.layerTable.getAt(n);((e=r==null?void 0:r.color)==null?void 0:e.RGB)!=null&&(t=r.color)}}return t}get rgbColor(){const e=this.resolvedColor.RGB;return e??16777215}get lineType(){var t;return this._lineType==null&&(this._lineType=((t=this.database)==null?void 0:t.celtype)??dt),this._lineType}set lineType(t){t?t.toUpperCase()==="BYLAYER"?this._lineType=dt:t.toUpperCase()==="BYBLOCK"?this._lineType=fe:this._lineType=t:this._lineType=dt}get lineWeight(){return this._lineWeight==null&&(this._lineWeight=this.database.celweight??Qe.ByLayer),this._lineWeight}set lineWeight(t){this._lineWeight=t}get linetypeScale(){return this._linetypeScale==null&&(this._linetypeScale=this.database.celtscale??-1),this._linetypeScale}set linetypeScale(t){this._linetypeScale=t}get visibility(){return this._visibility}set visibility(t){this._visibility=t}get transparency(){return this._transparency}set transparency(t){this._transparency=t.clone()}dxfOutFields(t){t.writeSubclassMarker("AcDbEntity"),t.writeString(8,this.layer),t.writeString(6,this.lineType),t.writeDouble(48,this.linetypeScale),t.writeInt16(60,this.visibility?0:1),t.writeCmColor(this.color),t.writeInt16(370,this.lineWeight),t.writeTransparency(this.transparency);const e=this.database.tables.blockTable.getIdAt(this.ownerId);return e!=null&&e.isPaperSapce&&t.writeInt16(67,1),this}resolveEffectiveProperties(){this._layer==null&&(this._layer=this.database.clayer??"0"),this._color==null&&(this._color=new j,this.database.cecolor&&this._color.copy(this.database.cecolor)),this._lineType==null&&(this._lineType=this.database.celtype??dt),this._linetypeScale==null&&(this._linetypeScale=this.database.celtscale??-1),this._lineWeight==null&&(this._lineWeight=this.database.celweight??Qe.ByLayer)}get properties(){return{type:this.type,groups:[this.getGeneralProperties()]}}subGetGripPoints(){return new Array}subGetOsnapPoints(t,e,s,n,r,o){}transformBy(t){return this}erase(){return this.database.tables.blockTable.removeEntity(this.objectId)}worldDraw(t,e){const s=t.subEntityTraits;s.color=this.resolvedColor,s.rgbColor=this.rgbColor,s.lineType=this.lineStyle,s.lineTypeScale=this.linetypeScale,s.lineWeight=this.lineWeight,s.transparency=this.transparency,s.layer=this.layer,s.drawOrder=0,"thickness"in this&&(s.thickness=this.thickness);const n=this.subWorldDraw(t,e);return this.attachEntityInfo(n),n}triggerModifiedEvent(){this.database.events.entityModified.dispatch({database:this.database,entity:this})}getGeneralProperties(){return{groupName:"general",properties:[{name:"handle",type:"int",editable:!1,accessor:{get:()=>this.objectId}},{name:"color",type:"color",editable:!0,accessor:{get:()=>this.color,set:t=>{this.color.copy(t)}}},{name:"layer",type:"string",editable:!0,accessor:{get:()=>this.layer,set:t=>{this.layer=t}}},{name:"linetype",type:"linetype",editable:!0,accessor:{get:()=>this.lineType,set:t=>{this.lineType=t}}},{name:"linetypeScale",type:"float",editable:!0,accessor:{get:()=>this.linetypeScale,set:t=>{this.linetypeScale=t}}},{name:"lineWeight",type:"lineweight",editable:!0,accessor:{get:()=>this.lineWeight,set:t=>{this.lineWeight=t}}},{name:"transparency",type:"transparency",editable:!0,accessor:{get:()=>this.transparency,set:t=>{this.transparency=t}}}]}}get lineStyle(){var n;const{type:t,name:e}=this.getLineType(),s=(n=this.database)==null?void 0:n.tables.linetypeTable.getAt(e);return s?{type:t,...s.linetype}:{type:t,name:e,standardFlag:0,description:"",totalPatternLength:0}}getLineType(){if(this.lineType==dt){const t=this.database.tables.layerTable.getAt(this.layer);if(t&&t.linetype)return{type:"ByLayer",name:t.linetype}}else return this.lineType==fe?{type:"ByBlock",name:Se}:{type:"UserSpecified",name:this.lineType};return{type:"UserSpecified",name:Se}}getLayerColor(){const t=this.database.tables.layerTable.getAt(this.layer);return t!=null?t.color:null}attachEntityInfo(t){t&&(t.objectId=this.objectId,this.attrs.has("ownerId")&&(t.ownerId=this.ownerId),t.layerName=this.layer,t.visible=this.visibility)}};Cr.typeName="Entity";let lt=Cr;const Or=class Or extends lt{};Or.typeName="Curve";let ht=Or;var rs=(i=>(i[i.SimplePoly=0]="SimplePoly",i[i.FitCurvePoly=1]="FitCurvePoly",i[i.QuadSplinePoly=2]="QuadSplinePoly",i[i.CubicSplinePoly=3]="CubicSplinePoly",i))(rs||{});const Nr=class Nr extends ht{get dxfTypeName(){return"POLYLINE"}constructor(t,e,s=0,n=!1,r=0,o=0,a=null){super(),this._polyType=t,this._elevation=s;const h=a&&(a==null?void 0:a.length)===e.length,c=e.map((d,u)=>({x:d.x,y:d.y,bulge:h?a[u]:void 0}));this._geo=new at(c,n)}get polyType(){return this._polyType}set polyType(t){this._polyType=t}get elevation(){return this._elevation}set elevation(t){this._elevation=t}get closed(){return this._geo.closed}set closed(t){this._geo.closed=t}get numberOfVertices(){return this._geo.numberOfVertices}getPointAt(t){return this._geo.getPointAt(t)}getBulgeAt(t){const e=this._geo.vertices[t];return(e==null?void 0:e.bulge)||0}get geometricExtents(){const t=this._geo.box;return new N({x:t.min.x,y:t.min.y,z:this._elevation},{x:t.max.x,y:t.max.y,z:this._elevation})}subGetGripPoints(){const t=new Array;for(let e=0;e<this._geo.numberOfVertices;++e){const s=this._geo.getPointAt(e);t.push(new w(s.x,s.y,0))}return t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:for(let r=0;r<this._geo.numberOfVertices;++r){const o=this._geo.getPointAt(r);n.push(new w(o.x,o.y,0))}break}}transformBy(t){const e=t.determinant()<0;let s=this._elevation;return this._geo.vertices.forEach(n=>{const r=new w(n.x,n.y,this._elevation).applyMatrix4(t);n.x=r.x,n.y=r.y,s=r.z,e&&n.bulge!=null&&(n.bulge=-n.bulge)}),this._elevation=s,this._geo._boundingBoxNeedsUpdate=!0,this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"vertices",type:"array",editable:!1,itemSchema:{properties:[{name:"x",type:"float",editable:!0},{name:"y",type:"float",editable:!0}]},accessor:{get:()=>this._geo.vertices}},{name:"elevation",type:"float",editable:!0,accessor:{get:()=>this.elevation,set:t=>{this.elevation=t}}},{name:"length",type:"float",editable:!1,accessor:{get:()=>this._geo.length}}]},{groupName:"others",properties:[{name:"closed",type:"float",editable:!0,accessor:{get:()=>this.closed,set:t=>{this.closed=t}}}]}]}}subWorldDraw(t){const e=[];return this._geo.getPoints(100).forEach(n=>e.push(new w().set(n.x,n.y,this.elevation))),t.lines(e)}dxfOut(t,e=!1){super.dxfOut(t,e);for(let s=0;s<this.numberOfVertices;++s)t.writeStart("VERTEX"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDb2dVertex"),t.writePoint3d(10,{x:this.getPointAt(s).x,y:this.getPointAt(s).y,z:this.elevation}),t.writeDouble(42,this.getBulgeAt(s)),t.writeInt16(70,0);return t.writeStart("SEQEND"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),this}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDb2dPolyline");let e=this.closed?1:0;return this.polyType===1&&(e|=2),this.polyType===2&&(e|=4),this.polyType===3&&(e|=8),t.writeInt16(66,this.numberOfVertices>0?1:0),t.writeInt16(70,e),t.writeDouble(10,0),t.writeDouble(20,0),t.writeDouble(30,this.elevation),this}};Nr.typeName="2dPolyline";let Ni=Nr;var Ha=(i=>(i[i.Vertex=0]="Vertex",i[i.CurveFitVertex=1]="CurveFitVertex",i[i.SplineFitVertex=8]="SplineFitVertex",i[i.SplineCtlVertex=9]="SplineCtlVertex",i))(Ha||{});const Br=class Br extends lt{get dxfTypeName(){return"VERTEX"}constructor(){super(),this._position=new w,this._bulge=0,this._startWidth=0,this._endWidth=0,this._vertexType=0}get position(){return this._position}set position(t){this._position.copy(t)}get bulge(){return this._bulge}set bulge(t){this._bulge=t}get startWidth(){return this._startWidth}set startWidth(t){this._startWidth=t}get endWidth(){return this._endWidth}set endWidth(t){this._endWidth=t}get vertexType(){return this._vertexType}set vertexType(t){this._vertexType=t}get geometricExtents(){return new N().expandByPoint(this._position)}subGetGripPoints(){const t=new Array;return t.push(this._position),t}subGetOsnapPoints(t,e,s,n){n.push(this._position)}transformBy(t){return this._position.applyMatrix4(t),this}subWorldDraw(t){}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDb2dVertex"),t.writePoint2d(10,this.position),t.writeDouble(40,this.startWidth),t.writeDouble(41,this.endWidth),t.writeDouble(42,this.bulge),t.writeInt16(70,this.vertexType),this}};Br.typeName="2dVertex";let Yn=Br;var Rs=(i=>(i[i.SimplePoly=0]="SimplePoly",i[i.QuadSplinePoly=1]="QuadSplinePoly",i[i.CubicSplinePoly=2]="CubicSplinePoly",i))(Rs||{});const Rr=class Rr extends ht{get dxfTypeName(){return"POLYLINE"}constructor(t,e,s=!1){super(),this._polyType=t,this._geo=new at(e,s)}get polyType(){return this._polyType}set polyType(t){this._polyType=t}get closed(){return this._geo.closed}set closed(t){this._geo.closed=t}get numberOfVertices(){return this._geo.numberOfVertices}getPointAt(t){const e=this._geo.vertices[t];return new w(e.x,e.y,e.z||0)}get geometricExtents(){const t=this._geo.vertices.map(e=>new w(e.x,e.y,e.z||0));return new N().setFromPoints(t)}subGetGripPoints(){const t=new Array;for(let e=0;e<this._geo.numberOfVertices;++e){const s=this._geo.getPointAt(e);t.push(new w(s.x,s.y,0))}return t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:for(let r=0;r<this._geo.numberOfVertices;++r)n.push(this.getPointAt(r));break}}transformBy(t){return this._geo.vertices.forEach(e=>{const s=new w(e.x,e.y,e.z||0).applyMatrix4(t);e.x=s.x,e.y=s.y,e.z=s.z}),this._geo._boundingBoxNeedsUpdate=!0,this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"vertices",type:"array",editable:!1,itemSchema:{properties:[{name:"x",type:"float",editable:!0},{name:"y",type:"float",editable:!0},{name:"z",type:"float",editable:!0}]},accessor:{get:()=>this._geo.vertices}},{name:"length",type:"float",editable:!1,accessor:{get:()=>this._geo.length}}]},{groupName:"others",properties:[{name:"closed",type:"float",editable:!0,accessor:{get:()=>this.closed,set:t=>{this.closed=t}}}]}]}}subWorldDraw(t){const e=this._geo.vertices.map(s=>new w(s.x,s.y,s.z||0));return t.lines(e)}dxfOut(t,e=!1){super.dxfOut(t,e);for(let s=0;s<this.numberOfVertices;++s){const n=this.getPointAt(s);t.writeStart("VERTEX"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDb3dPolylineVertex"),t.writePoint3d(10,{x:n.x,y:n.y,z:n.z}),t.writeInt16(70,32)}return t.writeStart("SEQEND"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),this}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDb3dPolyline");let e=this.closed?1:0;return e|=8,this.polyType===1&&(e|=16),this.polyType===2&&(e|=32),t.writeInt16(66,this.numberOfVertices>0?1:0),t.writeInt16(70,e),this}};Rr.typeName="3dPolyline";let Bi=Rr;var Ga=(i=>(i[i.SimpleVertex=0]="SimpleVertex",i[i.ControlVertex=1]="ControlVertex",i[i.FitVertex=2]="FitVertex",i))(Ga||{});const Fr=class Fr extends lt{get dxfTypeName(){return"VERTEX"}constructor(){super(),this._position=new w,this._vertexType=0}get position(){return this._position}set position(t){this._position.copy(t)}get vertexType(){return this._vertexType}set vertexType(t){this._vertexType=t}get geometricExtents(){return new N().expandByPoint(this._position)}subGetGripPoints(){const t=new Array;return t.push(this._position),t}subGetOsnapPoints(t,e,s,n){n.push(this._position)}transformBy(t){return this._position.applyMatrix4(t),this}subWorldDraw(t){}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDb3dPolylineVertex"),t.writePoint3d(10,this.position),t.writeInt16(70,this.vertexType|32),this}};Fr.typeName="3dVertex";let Xn=Fr;const zr=class zr extends ht{get dxfTypeName(){return"ARC"}constructor(t,e,s,n,r=_.Z_AXIS){super();const o=pr(r);this._geo=new Ie(t,e,s,n,r,o)}get center(){return this._geo.center}set center(t){this._geo.center=t}get radius(){return this._geo.radius}set radius(t){this._geo.radius=t}get startAngle(){return this._geo.startAngle}set startAngle(t){this._geo.startAngle=t}get endAngle(){return this._geo.endAngle}set endAngle(t){this._geo.endAngle=t}get normal(){return this._geo.normal}set normal(t){this._geo.normal=t}get startPoint(){return this._geo.startPoint}get endPoint(){return this._geo.endPoint}get midPoint(){return this._geo.midPoint}get geometricExtents(){return this._geo.box}get closed(){return this._geo.closed}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"centerX",type:"float",editable:!0,accessor:{get:()=>this.center.x,set:t=>{this.center.x=t}}},{name:"centerY",type:"float",editable:!0,accessor:{get:()=>this.center.y,set:t=>{this.center.y=t}}},{name:"centerZ",type:"float",editable:!0,accessor:{get:()=>this.center.z,set:t=>{this.center.z=t}}},{name:"radius",type:"float",editable:!0,accessor:{get:()=>this.radius,set:t=>{this.radius=t}}},{name:"startAngle",type:"float",editable:!0,accessor:{get:()=>this.startAngle,set:t=>{this.startAngle=t}}},{name:"endAngle",type:"float",editable:!0,accessor:{get:()=>this.endAngle,set:t=>{this.endAngle=t}}},{name:"normalX",type:"float",editable:!0,accessor:{get:()=>this.normal.x,set:t=>{this.normal.x=t}}},{name:"normalY",type:"float",editable:!0,accessor:{get:()=>this.normal.y,set:t=>{this.normal.y=t}}},{name:"normalZ",type:"float",editable:!0,accessor:{get:()=>this.normal.z,set:t=>{this.normal.z=t}}},{name:"arcLength",type:"float",editable:!1,accessor:{get:()=>this._geo.length}},{name:"totalAngle",type:"float",editable:!1,accessor:{get:()=>k.radToDeg(Math.abs(this._geo.deltaAngle))}},{name:"area",type:"float",editable:!1,accessor:{get:()=>this._geo.area}}]}]}}subGetGripPoints(){const t=new Array;return t.push(this.center),t.push(this.startPoint),t.push(this.endPoint),t}subGetOsnapPoints(t,e,s,n){const r=this.startPoint,o=this.endPoint;switch(t){case z.EndPoint:n.push(r),n.push(o);break;case z.MidPoint:n.push(this.midPoint);break;case z.Nearest:{const a=this._geo.nearestPoint(e);n.push(a)}break;case z.Perpendicular:break;case z.Tangent:{const a=this._geo.tangentPoints(e);n.push(...a);break}}}transformBy(t){return this._geo.transform(t),this}subWorldDraw(t){return t.circularArc(this._geo)}dxfOutFields(t){super.dxfOutFields(t);const e=Ws(this.center,this.normal);return t.writeSubclassMarker("AcDbArc"),t.writePoint3d(10,e),t.writeDouble(40,this.radius),t.writeAngle(50,Gn(this.center,this.startPoint,this.normal)),t.writeAngle(51,Gn(this.center,this.endPoint,this.normal)),t.writeVector3d(210,this.normal),this}};zr.typeName="Arc";let Ri=zr;var Ua=(i=>(i[i.LEFT=0]="LEFT",i[i.CENTER=1]="CENTER",i[i.RIGHT=2]="RIGHT",i[i.ALIGNED=3]="ALIGNED",i[i.MIDDLE=4]="MIDDLE",i[i.FIT=5]="FIT",i))(Ua||{}),Ya=(i=>(i[i.BASELINE=0]="BASELINE",i[i.BOTTOM=1]="BOTTOM",i[i.MIDDLE=2]="MIDDLE",i[i.TOP=3]="TOP",i))(Ya||{});const Vr=class Vr extends lt{get dxfTypeName(){return"TEXT"}constructor(){super(),this._textString="",this._height=0,this._thickness=1,this._position=new w,this._rotation=0,this._oblique=0,this._horizontalMode=0,this._verticalModel=2,this._styleName="",this._widthFactor=1}get textString(){return this._textString}set textString(t){this._textString=t}get thickness(){return this._thickness}set thickness(t){this._thickness=t}get height(){return this._height}set height(t){this._height=t}get position(){return this._position}set position(t){this._position.copy(t)}get rotation(){return this._rotation}set rotation(t){this._rotation=t}get oblique(){return this._oblique}set oblique(t){this._oblique=t}get horizontalMode(){return this._horizontalMode}set horizontalMode(t){this._horizontalMode=t}get verticalMode(){return this._verticalModel}set verticalMode(t){this._verticalModel=t}get styleName(){return this._styleName}set styleName(t){this._styleName=t}get widthFactor(){return this._widthFactor}set widthFactor(t){this._widthFactor=t}get geometricExtents(){return new N}subGetOsnapPoints(t,e,s,n){z.Insertion===t&&n.push(this._position)}transformBy(t){const e=this._position.clone(),s=this._position.clone().add(new _(Math.cos(this._rotation),Math.sin(this._rotation),0)),n=this._position.clone().add(new _(-Math.sin(this._rotation),Math.cos(this._rotation),0)),r=this._position.clone().add(new _(0,0,1));e.applyMatrix4(t),s.applyMatrix4(t),n.applyMatrix4(t),r.applyMatrix4(t);const o=new _(s).sub(e),a=new _(n).sub(e),h=new _(r).sub(e),c=a.length(),d=o.length(),u=h.length();return this._position.copy(e),d>0&&(this._rotation=Math.atan2(o.y,o.x)),c>0&&(this._height*=c,d>0&&(this._widthFactor*=d/c)),u>0&&(this._thickness*=u),this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"text",properties:[{name:"contents",type:"string",editable:!0,accessor:{get:()=>this.textString,set:t=>{this.textString=t}}},{name:"styleName",type:"string",editable:!0,accessor:{get:()=>this.styleName,set:t=>{this.styleName=t}}},{name:"textHeight",type:"float",editable:!0,accessor:{get:()=>this.height,set:t=>{this.height=t}}},{name:"rotation",type:"float",editable:!0,accessor:{get:()=>this.rotation,set:t=>{this.rotation=t}}},{name:"widthFactor",type:"float",editable:!0,accessor:{get:()=>this.widthFactor,set:t=>{this.widthFactor=t}}},{name:"oblique",type:"float",editable:!0,accessor:{get:()=>this.oblique,set:t=>{this.oblique=t}}}]},{groupName:"geometry",properties:[{name:"positionX",type:"float",editable:!0,accessor:{get:()=>this.position.x,set:t=>{this.position.x=t}}},{name:"positionY",type:"float",editable:!0,accessor:{get:()=>this.position.y,set:t=>{this.position.y=t}}},{name:"positionZ",type:"float",editable:!0,accessor:{get:()=>this.position.z,set:t=>{this.position.z=t}}}]}]}}getTextStyle(){const t=this.database.tables.textStyleTable,e=t.getAt(this.styleName)??t.getAt(this.database.textstyle)??t.getAt(Z);if(!e)throw new Error("No valid text style found in text style table.");return e.textStyle}subWorldDraw(t,e){const s={text:this.textString,height:this.height,width:1/0,widthFactor:this.widthFactor,position:this.position,rotation:this.rotation,drawingDirection:Dt.BOTTOM_TO_TOP,attachmentPoint:ot.BottomLeft};return t.mtext(s,this.getTextStyle(),e)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbText"),t.writePoint3d(10,this.position),t.writeDouble(39,this.thickness),t.writeDouble(40,this.height),t.writeString(1,this.textString),t.writeAngle(50,this.rotation),t.writeDouble(41,this.widthFactor),t.writeAngle(51,this.oblique),t.writeString(7,this.styleName),t.writeInt16(72,this.horizontalMode),t.writeInt16(73,this.verticalMode),t.writePoint3d(11,this.position),this}};Vr.typeName="Text";let cs=Vr;var tt=(i=>(i[i.Invisible=1]="Invisible",i[i.Const=2]="Const",i[i.Verifiable=4]="Verifiable",i[i.Preset=8]="Preset",i))(tt||{}),jt=(i=>(i[i.MultiLine=2]="MultiLine",i[i.ConstMultiLine=4]="ConstMultiLine",i))(jt||{});const Dr=class Dr extends cs{get dxfTypeName(){return"ATTDEF"}constructor(){super(),this._flags=0,this._prompt="",this._mtextFlag=0,this._tag="",this._fieldLength=0,this._lockPositionInBlock=!1,this._isReallyLocked=!1}get isInvisible(){return(this._flags&1)!==0}set isInvisible(t){t?this._flags|=1:this._flags&=-2}get prompt(){return this._prompt}set prompt(t){this._prompt=t}get isConst(){return(this._flags&2)!==0}set isConst(t){t?this._flags|=2:this._flags&=-3}get isVerifiable(){return(this._flags&4)!==0}set isVerifiable(t){t?this._flags|=4:this._flags&=-5}get isPreset(){return(this._flags&8)!==0}set isPreset(t){t?this._flags|=8:this._flags&=-9}get isMTextAttribute(){return(this._mtextFlag&2)!==0}set isMTextAttribute(t){t?this._mtextFlag|=2:this._mtextFlag&=-3}get isConstMTextAttribute(){return(this._mtextFlag&4)!==0}set isConstMTextAttribute(t){t?this._mtextFlag|=4:this._mtextFlag&=-5}get tag(){return this._tag}set tag(t){this._tag=t}get fieldLength(){return this._fieldLength}set fieldLength(t){this._fieldLength=t}get lockPositionInBlock(){return this._lockPositionInBlock}set lockPositionInBlock(t){this._lockPositionInBlock=t}get isReallyLocked(){return this._isReallyLocked}set isReallyLocked(t){this._isReallyLocked=t}get mtext(){return this._mtext}set mtext(t){this._mtext=t,this.isMTextAttribute=t!=null}subWorldDraw(t){}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbAttributeDefinition"),t.writeString(3,this.prompt),t.writeString(2,this.tag),t.writeInt16(70,this.isInvisible?1:0),t.writeInt16(73,this.fieldLength),t.writeInt16(74,this.isReallyLocked?1:0),this}};Dr.typeName="AttDef";let Fi=Dr;const jr=class jr extends cs{get dxfTypeName(){return"ATTRIB"}constructor(){super(),this._flags=0,this._mtextFlag=0,this._tag="",this._fieldLength=0,this._lockPositionInBlock=!1,this._isReallyLocked=!1}get isInvisible(){return(this._flags&tt.Invisible)!==0}set isInvisible(t){t?this._flags|=tt.Invisible:this._flags&=~tt.Invisible}get isConst(){return(this._flags&tt.Const)!==0}set isConst(t){t?this._flags|=tt.Const:this._flags&=~tt.Const}get isVerifiable(){return(this._flags&tt.Verifiable)!==0}set isVerifiable(t){t?this._flags|=tt.Verifiable:this._flags&=~tt.Verifiable}get isPreset(){return(this._flags&tt.Preset)!==0}set isPreset(t){t?this._flags|=tt.Preset:this._flags&=~tt.Preset}get isMTextAttribute(){return(this._mtextFlag&jt.MultiLine)!==0}set isMTextAttribute(t){t?this._mtextFlag|=jt.MultiLine:this._mtextFlag&=~jt.MultiLine}get isConstMTextAttribute(){return(this._mtextFlag&jt.ConstMultiLine)!==0}set isConstMTextAttribute(t){t?this._mtextFlag|=jt.ConstMultiLine:this._mtextFlag&=~jt.ConstMultiLine}get tag(){return this._tag}set tag(t){this._tag=t}get fieldLength(){return this._fieldLength}set fieldLength(t){this._fieldLength=t}get lockPositionInBlock(){return this._lockPositionInBlock}set lockPositionInBlock(t){this._lockPositionInBlock=t}get isReallyLocked(){return this._isReallyLocked}set isReallyLocked(t){this._isReallyLocked=t}get mtext(){return this._mtext}set mtext(t){this._mtext=t,this.isMTextAttribute=t!=null}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbAttribute"),t.writeInt16(70,this.isInvisible?1:0),t.writeInt16(73,this.fieldLength),t.writeString(2,this.tag),t.writeInt16(74,this.isReallyLocked?1:0),this.mtext&&t.writeInt16(71,this.isMTextAttribute?1:0),this}};jr.typeName="Attrib";let zi=jr;const Ds=class Ds extends lt{get dxfTypeName(){return"INSERT"}constructor(t){super(),this._blockName=t,this._position=new w,this._rotation=0,this._normal=new _(0,0,1),this._scaleFactors=new w(1,1,1),this._attribs=new Map}get position(){return this._position}set position(t){this._position.copy(t)}get rotation(){return this._rotation}set rotation(t){this._rotation=t}get scaleFactors(){return this._scaleFactors}set scaleFactors(t){this._scaleFactors.copy(t)}get normal(){return this._normal}set normal(t){this._normal.copy(t).normalize()}get blockName(){return this._blockName}get blockTableRecord(){return this.database.tables.blockTable.getAt(this._blockName)}appendAttributes(t){this._attribs.set(t.objectId,t),t.ownerId=this.objectId}attributeIterator(){return new ni(this._attribs)}get blockTransform(){const t=this.blockTableRecord,e=(t==null?void 0:t.origin)??w.ORIGIN,s=new D().makeTranslation(-e.x,-e.y,-e.z),n=new D().makeScale(this._scaleFactors.x,this._scaleFactors.y,this._scaleFactors.z),r=new ss().setFromAxisAngle(_.Z_AXIS,this._rotation),o=new D().makeRotationFromQuaternion(r),a=new D().makeTranslation(this._position.x,this._position.y,this._position.z);return new D().multiplyMatrices(a,o).multiply(n).multiply(s)}subGetOsnapPoints(t,e,s,n,r,o){const a=o??new D;z.Insertion===t?n.push(this.getInsertionPoint(a)):r&&this.subEntityGetOsnapPoints(t,e,s,n,r,a)}transformBy(t){const e=new D().setFromExtrusionDirection(this._normal),s=new D().makeRotationZ(this._rotation),n=new D().multiplyMatrices(e,s),r=this._position.clone(),o=new w(this._scaleFactors.x,0,0).applyMatrix4(n).add(r),a=new w(0,this._scaleFactors.y,0).applyMatrix4(n).add(r),h=new w(0,0,this._scaleFactors.z).applyMatrix4(n).add(r);r.applyMatrix4(t),o.applyMatrix4(t),a.applyMatrix4(t),h.applyMatrix4(t);const c=new _(o).sub(r),d=new _(a).sub(r),u=new _(h).sub(r);let p=new _().crossVectors(c,d);p.lengthSq()===0?p=this._normal.clone().transformDirection(t):p.normalize();const m=new D().setFromExtrusionDirection(p).clone().invert(),y=c.clone().applyMatrix4(m);return this._position.copy(r),this._normal.copy(p),this._rotation=Math.atan2(y.y,y.x),this._scaleFactors.set(c.length(),d.length(),u.length()),this._attribs.forEach(b=>b.transformBy(t)),this}get properties(){const t={type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"blockName",type:"float",editable:!1,accessor:{get:()=>this._blockName}},{name:"positionX",type:"float",editable:!0,accessor:{get:()=>this.position.x,set:e=>{this.position.x=e}}},{name:"positionY",type:"float",editable:!0,accessor:{get:()=>this.position.y,set:e=>{this.position.y=e}}},{name:"positionZ",type:"float",editable:!0,accessor:{get:()=>this.position.z,set:e=>{this.position.z=e}}},{name:"rotation",type:"float",editable:!0,accessor:{get:()=>this.rotation,set:e=>{this.rotation=e}}},{name:"scaleFactorsX",type:"float",editable:!0,accessor:{get:()=>this.scaleFactors.x,set:e=>{this.scaleFactors.x=e}}},{name:"scaleFactorsY",type:"float",editable:!0,accessor:{get:()=>this.scaleFactors.y,set:e=>{this.scaleFactors.y=e}}},{name:"scaleFactorsZ",type:"float",editable:!0,accessor:{get:()=>this.scaleFactors.z,set:e=>{this.scaleFactors.z=e}}},{name:"normalX",type:"float",editable:!0,accessor:{get:()=>this.normal.x,set:e=>{this.normal.x=e}}},{name:"normalY",type:"float",editable:!0,accessor:{get:()=>this.normal.y,set:e=>{this.normal.y=e}}},{name:"normalZ",type:"float",editable:!0,accessor:{get:()=>this.normal.z,set:e=>{this.normal.z=e}}}]}]};if(this._attribs.size>0){const e={groupName:"attribute",properties:[]};t.groups.push(e),this._attribs.forEach(s=>{e.properties.push({name:s.tag,type:"string",editable:!s.isConst,skipTranslation:!0,accessor:{get:()=>s.textString,set:n=>{s.textString=n}}})})}return t}get geometricExtents(){const t=new N,e=this.blockTableRecord;if(e!=null){const n=e.newIterator();for(const r of n)t.union(r.geometricExtents)}const s=this.blockTransform;return t.applyMatrix4(s),t}subWorldDraw(t){const e=this.blockTableRecord;if(e!=null){const s=this.blockTransform,n=[];return this._attribs.forEach(o=>{if(!o.isInvisible){const a=o.worldDraw(t);a&&n.push(a)}}),es.instance.draw(t,e,this.rgbColor,n,!0,s,this._normal)}else return t.group([])}dxfOut(t,e=!1){super.dxfOut(t,e);let s=!1;for(const n of this.attributeIterator())s=!0,t.writeStart("ATTRIB"),n.dxfOut(t);return s&&(t.writeStart("SEQEND"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity")),this}subEntityGetOsnapPoints(t,e,s,n,r,o,a=new Set){if(r===this.objectId||a.has(this.objectId))return!1;a.add(this.objectId);try{const h=this.blockTableRecord;if(h==null)return!1;const c=new D().multiplyMatrices(o,this.getFullInsertionTransform());for(const d of h.newIterator()){if(d.objectId===r){const u=new w(e).applyMatrix4(c.clone().invert()),p=new w(s).applyMatrix4(c.clone().invert()),g=[];return d.subGetOsnapPoints(t,u,p,g,r,c),d instanceof Ds?g.forEach(m=>{n.push(m.clone())}):g.forEach(m=>{n.push(new w(m).applyMatrix4(c))}),!0}if(d instanceof Ds&&d.subEntityGetOsnapPoints(t,e,s,n,r,c,a))return!0}return!1}finally{a.delete(this.objectId)}}getInsertionPoint(t){var n;const e=((n=this.blockTableRecord)==null?void 0:n.origin)??w.ORIGIN,s=new D().multiplyMatrices(t,this.getFullInsertionTransform());return new w(e).applyMatrix4(s)}getFullInsertionTransform(){const t=new D().setFromExtrusionDirection(this._normal);return new D().multiplyMatrices(t,this.blockTransform)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbBlockReference"),t.writePoint3d(10,this.position),t.writeString(2,this.blockName),t.writeDouble(41,this.scaleFactors.x),t.writeDouble(42,this.scaleFactors.y),t.writeDouble(43,this.scaleFactors.z),t.writeAngle(50,this.rotation),t.writeVector3d(210,this.normal),this}};Ds.typeName="BlockReference";let Je=Ds;const Wr=class Wr extends ht{get dxfTypeName(){return"CIRCLE"}constructor(t,e,s=_.Z_AXIS){super();const n=pr(s);this._geo=new Ie(t,e,0,G,s,n)}get center(){return this._geo.center}set center(t){this._geo.center=t}get radius(){return this._geo.radius}set radius(t){this._geo.radius=t}get normal(){return this._geo.normal}get geometricExtents(){return this._geo.box}get closed(){return this._geo.closed}subGetOsnapPoints(t,e,s,n){switch(t){case z.Center:case z.Centroid:n.push(this._geo.center);break;case z.Quadrant:n.push(this._geo.getPointAtAngle(0)),n.push(this._geo.getPointAtAngle(Math.PI/2)),n.push(this._geo.getPointAtAngle(Math.PI)),n.push(this._geo.getPointAtAngle(Math.PI/2*3));break;case z.Nearest:{const r=this._geo.nearestPoint(e);n.push(r)}break;case z.Tangent:{const r=this._geo.tangentPoints(e);n.push(...r);break}}}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"centerX",type:"float",editable:!0,accessor:{get:()=>this.center.x,set:t=>{this.center.x=t}}},{name:"centerY",type:"float",editable:!0,accessor:{get:()=>this.center.y,set:t=>{this.center.y=t}}},{name:"centerZ",type:"float",editable:!0,accessor:{get:()=>this.center.z,set:t=>{this.center.z=t}}},{name:"radius",type:"float",editable:!0,accessor:{get:()=>this.radius,set:t=>{this.radius=t}}},{name:"normalX",type:"float",editable:!0,accessor:{get:()=>this.normal.x,set:t=>{this.normal.x=t}}},{name:"normalY",type:"float",editable:!0,accessor:{get:()=>this.normal.y,set:t=>{this.normal.y=t}}},{name:"normalZ",type:"float",editable:!0,accessor:{get:()=>this.normal.z,set:t=>{this.normal.z=t}}},{name:"diameter",type:"float",editable:!1,accessor:{get:()=>this._geo.radius*2}},{name:"perimeter",type:"float",editable:!1,accessor:{get:()=>this._geo.length}},{name:"area",type:"float",editable:!1,accessor:{get:()=>this._geo.area}}]}]}}subGetGripPoints(){const t=new Array;return t.push(this.center),t}transformBy(t){return this._geo.transform(t),this}subWorldDraw(t){return t.circularArc(this._geo)}dxfOutFields(t){super.dxfOutFields(t);const e=Ws(this.center,this.normal);return t.writeSubclassMarker("AcDbCircle"),t.writePoint3d(10,e),t.writeDouble(40,this.radius),t.writeVector3d(210,this.normal),this}};Wr.typeName="Circle";let Vi=Wr;const Hr=class Hr extends ht{get dxfTypeName(){return"ELLIPSE"}constructor(t,e,s,n,r,o,a){super(),this._geo=new ls(t,e,s,n,r,o,a)}get center(){return this._geo.center}set center(t){this._geo.center=t}get majorAxisRadius(){return this._geo.majorAxisRadius}set majorAxisRadius(t){this._geo.majorAxisRadius=t}get minorAxisRadius(){return this._geo.minorAxisRadius}set minorAxisRadius(t){this._geo.minorAxisRadius=t}get startAngle(){return this._geo.startAngle}set startAngle(t){this._geo.startAngle=t}get endAngle(){return this._geo.endAngle}set endAngle(t){this._geo.endAngle=t}get normal(){return this._geo.normal}set normal(t){this._geo.normal=t}get geometricExtents(){return this._geo.box}get closed(){return this._geo.closed}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:this.closed||(n.push(this._geo.startPoint),n.push(this._geo.endPoint));break;case z.MidPoint:this.closed||n.push(this._geo.midPoint);break;case z.Quadrant:this.closed&&(n.push(this._geo.getPointAtAngle(0)),n.push(this._geo.getPointAtAngle(Math.PI/2)),n.push(this._geo.getPointAtAngle(Math.PI)),n.push(this._geo.getPointAtAngle(Math.PI/2*3)));break}}transformBy(t){return this._geo.transform(t),this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"centerX",type:"float",editable:!0,accessor:{get:()=>this.center.x,set:t=>{this.center.x=t}}},{name:"centerY",type:"float",editable:!0,accessor:{get:()=>this.center.y,set:t=>{this.center.y=t}}},{name:"centerZ",type:"float",editable:!0,accessor:{get:()=>this.center.z,set:t=>{this.center.z=t}}},{name:"majorAxisRadius",type:"float",editable:!0,accessor:{get:()=>this.majorAxisRadius,set:t=>{this.center.x=t}}},{name:"minorAxisRadius",type:"float",editable:!0,accessor:{get:()=>this.minorAxisRadius,set:t=>{this.minorAxisRadius=t}}},{name:"startAngle",type:"float",editable:!0,accessor:{get:()=>this.startAngle,set:t=>{this.startAngle=t}}},{name:"endAngle",type:"float",editable:!0,accessor:{get:()=>this.endAngle,set:t=>{this.endAngle=t}}},{name:"normalX",type:"float",editable:!0,accessor:{get:()=>this.normal.x,set:t=>{this.normal.x=t}}},{name:"normalY",type:"float",editable:!0,accessor:{get:()=>this.normal.y,set:t=>{this.normal.y=t}}},{name:"normalZ",type:"float",editable:!0,accessor:{get:()=>this.normal.z,set:t=>{this.normal.z=t}}},{name:"length",type:"float",editable:!1,accessor:{get:()=>this._geo.length}},{name:"area",type:"float",editable:!1,accessor:{get:()=>this._geo.area}}]}]}}subWorldDraw(t){return t.ellipticalArc(this._geo)}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbEllipse"),t.writePoint3d(10,this.center);const e=this._geo.majorAxis,s=this.majorAxisRadius;return t.writePoint3d(11,{x:e.x*s,y:e.y*s,z:e.z*s}),t.writeVector3d(210,this.normal),t.writeDouble(40,this.minorAxisRadius/this.majorAxisRadius),t.writeDouble(41,this.startAngle),t.writeDouble(42,this.endAngle),this}};Hr.typeName="Ellipse";let Di=Hr;const Gr=class Gr extends lt{get dxfTypeName(){return"3DFACE"}constructor(){super(),this._vertices=[new w,new w,new w],this._edgeInvisibilities=0}getVertexAt(t){return t<0?this._vertices[0]:t>this._vertices.length?this._vertices[this._vertices.length-1]:this._vertices[t]}setVertexAt(t,e){if(t<0&&this._vertices[0].copy(e),t>=3)return this._vertices.length===3&&this._vertices.push(new w),this._vertices[3].copy(e);this._vertices[t].copy(e)}setEdgeInvisibilities(t){this._edgeInvisibilities=t}isEdgeVisibleAt(t){if(t<0||t>3)throw new Error("Index out of range");return(this._edgeInvisibilities&1<<t)===0}makeEdgeInvisibleAt(t){if(t<0||t>3)throw new Error("Index out of range");this._edgeInvisibilities=this._edgeInvisibilities|1<<t}get geometricExtents(){return new N().setFromPoints(this._vertices)}subGetGripPoints(){const t=new Array;return t.push(...this._vertices),t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:n.push(...this._vertices);break}}transformBy(t){return this._vertices.forEach(e=>e.applyMatrix4(t)),this}subWorldDraw(t){const e=this._vertices.length,s=new Float32Array(e*3),n=new Uint16Array(e*2);for(let r=0;r<e;r++)s[r*3]=this._vertices[r].x,s[r*3+1]=this._vertices[r].y,s[r*3+2]=this._vertices[r].z,this.isEdgeVisibleAt(r)&&(n[r*2]=r,n[r*2+1]=(r+1)%4);return t.lineSegments(s,3,n)}dxfOutFields(t){super.dxfOutFields(t);const e=this.getVertexAt(0),s=this.getVertexAt(1),n=this.getVertexAt(2),r=this.getVertexAt(3);t.writeSubclassMarker("AcDbFace"),t.writePoint3d(10,e),t.writePoint3d(11,s),t.writePoint3d(12,n),t.writePoint3d(13,r);let o=0;for(let a=0;a<4;++a)this.isEdgeVisibleAt(a)||(o|=1<<a);return t.writeInt16(70,o),this}};Gr.typeName="Face";let ji=Gr;var Fs=(i=>(i[i.UserDefined=0]="UserDefined",i[i.Predefined=1]="Predefined",i[i.Custom=2]="Custom",i))(Fs||{}),Xa=(i=>(i[i.Normal=0]="Normal",i[i.Outer=1]="Outer",i[i.Ignore=2]="Ignore",i))(Xa||{}),br=(i=>(i[i.HatchObject=0]="HatchObject",i[i.GradientObject=1]="GradientObject",i))(br||{}),$a=(i=>(i[i.PreDefinedGradient=0]="PreDefinedGradient",i[i.UserDefinedGradient=1]="UserDefinedGradient",i))($a||{});const Ur=class Ur extends lt{constructor(){super(),this._gradientAngle=0,this._elevation=0,this._geo=new Pe,this._isSolidFill=!1,this._definitionLines=[],this._patternName="",this._patternType=1,this._patternAngle=0,this._patternScale=1,this._hatchStyle=0,this._hatchObjectType=0,this._gradientAngle=0,this._gradientShift=0,this._shadeTintValue=0,this._gradientStartColor=void 0,this._gradientEndColor=void 0,this._gradientType=0,this._gradientName="",this._gradientOneColorMode=!1}get dxfTypeName(){return"HATCH"}get isGradient(){return this._hatchObjectType===1}get isHatch(){return this._hatchObjectType===0}get isSolidFill(){return this._isSolidFill||this._patternName.toUpperCase()==="SOLID"}set isSolidFill(t){this._isSolidFill=t}get definitionLines(){return this._definitionLines}get patternName(){return this._patternName}set patternName(t){this._patternName=t}get patternType(){return this._patternType}set patternType(t){this._patternType=t}get patternAngle(){return this._patternAngle}set patternAngle(t){this._patternAngle=t}get patternScale(){return this._patternScale}set patternScale(t){this._patternScale=t}get hatchStyle(){return this._hatchStyle}set hatchStyle(t){this._hatchStyle=t}get elevation(){return this._elevation}set elevation(t){this._elevation=t}get hatchObjectType(){return this._hatchObjectType}set hatchObjectType(t){this._hatchObjectType=t}get gradientAngle(){return this._gradientAngle}set gradientAngle(t){this._gradientAngle=t}get gradientShift(){return this._gradientShift}set gradientShift(t){this._gradientShift=t}get gradientType(){return this._gradientType}set gradientType(t){this._gradientType=t}get gradientName(){return this._gradientName}set gradientName(t){this._gradientName=t}get gradientOneColorMode(){return this._gradientOneColorMode}set gradientOneColorMode(t){this._gradientOneColorMode=t}get shadeTintValue(){return this._shadeTintValue}set shadeTintValue(t){this._shadeTintValue=t}get gradientStartColor(){return this._gradientStartColor}set gradientStartColor(t){this._gradientStartColor=t==null||!Number.isFinite(t)?void 0:t&16777215}get gradientEndColor(){return this._gradientEndColor}set gradientEndColor(t){this._gradientEndColor=t==null||!Number.isFinite(t)?void 0:t&16777215}add(t){this._geo.add(t)}buildAreasFromLoops(){const t=this._geo.loops;if(t.length===0)return[];if(t.length===1)return[this._geo];const e=this._geo.buildHierarchy(),s=[],n=(r,o)=>{if(r.index>=0&&o%2===0){const a=new Pe;a.add(t[r.index]),r.children.forEach(h=>{h.index>=0&&a.add(t[h.index])}),s.push(a)}r.children.forEach(a=>n(a,o+1))};return e.children.forEach(r=>n(r,0)),s.length>0?s:[this._geo]}getCalculatedAreaValue(){const t=this.buildAreasFromLoops();return t.length===0?0:t.reduce((e,s)=>e+s.area,0)}get geometricExtents(){const t=this.buildAreasFromLoops();if(t.length===0)return new N;const e=new N;return t.forEach(s=>{const n=s.box;e.union(new N({x:n.min.x,y:n.min.y,z:this._elevation},{x:n.max.x,y:n.max.y,z:this._elevation}))}),e}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"pattern",properties:[{name:"patternType",type:"enum",editable:!0,options:[{label:Fs[0],value:0},{label:Fs[1],value:1},{label:Fs[2],value:2}],accessor:{get:()=>this.patternType,set:t=>{this.patternType=t}}},{name:"patternName",type:"string",editable:!0,accessor:{get:()=>this.patternName,set:t=>{this.patternName=t}}},{name:"patternAngle",type:"float",editable:!0,accessor:{get:()=>this.patternAngle,set:t=>{this.patternAngle=t}}},{name:"patternScale",type:"float",editable:!0,accessor:{get:()=>this.patternScale,set:t=>{this.patternScale=t}}}]},{groupName:"geometry",properties:[{name:"elevation",type:"float",editable:!0,accessor:{get:()=>this.elevation,set:t=>{this.elevation=t}}},{name:"area",type:"float",editable:!1,accessor:{get:()=>this.getCalculatedAreaValue()}}]}]}}subWorldDraw(t){const e=t.subEntityTraits;e.fillType={solidFill:this.isSolidFill,patternAngle:this.patternAngle,definitionLines:this.definitionLines,gradient:this.isGradient?{name:this.gradientName,angle:this.gradientAngle,shift:this.gradientShift,oneColorMode:this.gradientOneColorMode,shadeTintValue:this.shadeTintValue,startColor:this.gradientStartColor,endColor:this.gradientEndColor}:void 0},e.drawOrder=-1;const s=this.buildAreasFromLoops();if(s.length===0)return t.area(this._geo);if(s.length===1)return t.area(s[0]);const n=s.map(r=>t.area(r));return t.group(n)}transformBy(t){const e=t.elements,s=new Js(e[0],e[4],e[12],e[1],e[5],e[13],0,0,1);this._geo.transform(s),this._elevation=new w(0,0,this._elevation).applyMatrix4(t).z;const n=new w(1,0,0).applyMatrix4(t),r=new w().applyMatrix4(t),o=new w(n).sub(r);if(o.length()>0){const a=Math.atan2(o.y,o.x);this._patternAngle+=a,this._gradientAngle+=a,this._patternScale*=o.length()}return this}dxfOutFields(t){super.dxfOutFields(t);const e=this._geo.loops;return t.writeSubclassMarker("AcDbHatch"),t.writePoint3d(10,{x:0,y:0,z:this.elevation}),t.writeVector3d(210,{x:0,y:0,z:1}),t.writeString(2,this.patternName||(this.isSolidFill?"SOLID":"USER")),t.writeInt16(70,this.isSolidFill?1:0),t.writeInt16(71,0),t.writeInt16(91,e.length),e.forEach((s,n)=>{const r=n===0;if(s instanceof at){const o=s.vertices,a=o.some(c=>(c.bulge??0)!==0);t.writeInt16(92,2),t.writeInt16(72,a?1:0),t.writeInt16(73,s.closed?1:0),t.writeInt16(93,o.length);for(const c of o)t.writePoint2d(10,c),a&&t.writeDouble(42,c.bulge??0);t.writeInt16(97,0);return}if(s instanceof Gs){const o=r?1:0;t.writeInt16(92,o),t.writeInt16(93,s.numberOfEdges);for(const a of s.curves){if(a instanceof Wt){t.writeInt16(72,1),t.writePoint2d(10,a.startPoint),t.writePoint2d(11,a.endPoint);continue}if(a instanceof Te){t.writeInt16(72,2),t.writePoint2d(10,a.center),t.writeDouble(40,a.radius),t.writeAngle(50,a.startAngle),t.writeAngle(51,a.endAngle),t.writeInt16(73,a.clockwise?0:1);continue}if(a instanceof Hs){t.writeInt16(72,3),t.writePoint2d(10,a.center);const h=new v(a.majorAxisRadius*Math.cos(a.rotation),a.majorAxisRadius*Math.sin(a.rotation));t.writePoint2d(11,h);const c=a.majorAxisRadius===0?0:a.minorAxisRadius/a.majorAxisRadius;t.writeDouble(40,c),t.writeAngle(50,a.startAngle),t.writeAngle(51,a.endAngle),t.writeInt16(73,a.clockwise?0:1);continue}if(a instanceof Ht){const h=a.knots,c=a.controlPoints,d=a.weights,u=a.fitPoints,p=d.some(g=>g!==1);t.writeInt16(72,4),t.writeInt16(94,a.degree),t.writeInt16(73,p?1:0),t.writeInt16(74,a.closed?1:0),t.writeInt16(95,h.length),t.writeInt16(96,c.length),h.forEach(g=>t.writeDouble(40,g)),c.forEach((g,m)=>{t.writePoint2d(10,g),p&&t.writeDouble(42,d[m]??1)}),t.writeInt16(97,(u==null?void 0:u.length)??0),u==null||u.forEach(g=>t.writePoint2d(11,g))}}t.writeInt16(97,0)}}),t.writeInt16(75,this.hatchStyle),t.writeInt16(76,this.patternType),t.writeAngle(52,this.patternAngle),t.writeDouble(41,this.patternScale),t.writeInt16(77,0),t.writeInt16(78,this.definitionLines.length),this.definitionLines.forEach(s=>{t.writeAngle(53,s.angle),t.writePoint2d(43,s.base),t.writePoint2d(45,s.offset),t.writeInt16(79,s.dashLengths.length),s.dashLengths.forEach(n=>t.writeDouble(49,n))}),this.isGradient&&(t.writeInt16(450,this._hatchObjectType),t.writeInt16(451,0),t.writeInt16(452,this._gradientOneColorMode?1:0),t.writeAngle(460,this._gradientAngle),t.writeDouble(461,this._gradientShift),t.writeString(470,this._gradientName)),t.writeInt16(98,0),this}};Ur.typeName="Hatch";let Us=Ur;var qa=(i=>(i[i.MText=0]="MText",i[i.Fcf=1]="Fcf",i[i.BlockReference=2]="BlockReference",i[i.NoAnnotation=3]="NoAnnotation",i))(qa||{});const Yr=class Yr extends ht{get dxfTypeName(){return"LEADER"}constructor(){super(),this._isSplined=!1,this._updated=!1,this._hasArrowHead=!1,this._vertices=[],this._dimensionStyle="",this._hasHookLine=!1,this._isHookLineSameDirection=!1,this._annoType=3,this._textHeight=0,this._textWidth=0,this._associatedAnnotation="",this._normal=new _(0,0,1),this._horizontalDirection=new _(1,0,0)}get isSplined(){return this._isSplined}set isSplined(t){this._isSplined=t}get hasArrowHead(){return this._hasArrowHead}set hasArrowHead(t){this._hasArrowHead=t}get hasHookLine(){return this._hasHookLine}set hasHookLine(t){this._hasHookLine=t}get isHookLineSameDirection(){return this._isHookLineSameDirection}set isHookLineSameDirection(t){this._isHookLineSameDirection=t}get numVertices(){return this._vertices.length}get vertices(){return this._vertices.map(t=>t.clone())}get dimensionStyle(){return this._dimensionStyle}set dimensionStyle(t){this._dimensionStyle=t}get annoType(){return this._annoType}set annoType(t){this._annoType=t}get textHeight(){return this._textHeight}set textHeight(t){this._textHeight=t}get textWidth(){return this._textWidth}set textWidth(t){this._textWidth=t}get byBlockColor(){return this._byBlockColor}set byBlockColor(t){this._byBlockColor=t}get associatedAnnotation(){return this._associatedAnnotation}set associatedAnnotation(t){this._associatedAnnotation=t}get normal(){return this._normal}set normal(t){this._normal.copy(t)}get horizontalDirection(){return this._horizontalDirection}set horizontalDirection(t){this._horizontalDirection.copy(t)}get offsetFromBlock(){var t;return(t=this._offsetFromBlock)==null?void 0:t.clone()}set offsetFromBlock(t){this._offsetFromBlock=t?new _(t):void 0}get offsetFromAnnotation(){var t;return(t=this._offsetFromAnnotation)==null?void 0:t.clone()}set offsetFromAnnotation(t){this._offsetFromAnnotation=t?new _(t):void 0}appendVertex(t){this._vertices.push(new w().copy(t)),this._updated=!0}setVertexAt(t,e){if(t<0||t>=this._vertices.length)throw new Error("The vertex index is out of range!");return this._vertices[t].copy(e),this._updated=!0,this}vertexAt(t){if(t<0||t>=this._vertices.length)throw new Error("The vertex index is out of range!");return this._vertices[t].clone()}get geometricExtents(){return this._isSplined&&this.splineGeo?this.splineGeo.calculateBoundingBox():new N().setFromPoints(this._vertices)}get closed(){return!1}set closed(t){}transformBy(t){return this._vertices.forEach(e=>e.applyMatrix4(t)),this.transformVector(this._normal,t),this.transformVector(this._horizontalDirection,t),this._offsetFromBlock&&this.transformVector(this._offsetFromBlock,t),this._offsetFromAnnotation&&this.transformVector(this._offsetFromAnnotation,t),this._splineGeo?(this._splineGeo.transform(t),this._updated=!1):this._updated=!0,this}subWorldDraw(t){if(this.isSplined&&this.splineGeo){const e=this.splineGeo.getPoints(100);return t.lines(e)}else return t.lines(this._vertices)}get splineGeo(){return this.createSplineIfNeeded(),this._splineGeo}createSplineIfNeeded(){this.isSplined&&this.numVertices>=2&&(this._splineGeo==null||this._updated)&&(this._splineGeo=new Ht(this._vertices,"Uniform"),this._updated=!1)}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbLeader"),t.writeString(3,this.dimensionStyle),t.writeInt16(71,this.hasArrowHead?1:0),t.writeInt16(72,this.isSplined?1:0),t.writeInt16(73,this.annoType),t.writeInt16(74,this.isHookLineSameDirection?1:0),t.writeInt16(75,this.hasHookLine?1:0),t.writeInt16(76,this.numVertices),this.textHeight!==0&&t.writeDouble(40,this.textHeight),this.textWidth!==0&&t.writeDouble(41,this.textWidth),this.byBlockColor!=null&&t.writeInt16(77,this.byBlockColor),this.associatedAnnotation&&t.writeHandle(340,this.associatedAnnotation);for(const e of this.vertices)t.writePoint3d(10,e);return t.writeVector3d(210,this.normal),t.writeVector3d(211,this.horizontalDirection),this._offsetFromBlock&&t.writeVector3d(212,this._offsetFromBlock),this._offsetFromAnnotation&&t.writeVector3d(213,this._offsetFromAnnotation),this}transformVector(t,e){const s=new w,n=new w(t.x,t.y,t.z);s.applyMatrix4(e),n.applyMatrix4(e),t.set(n.x-s.x,n.y-s.y,n.z-s.z)}};Yr.typeName="Leader";let Wi=Yr;var z=(i=>(i[i.EndPoint=1]="EndPoint",i[i.MidPoint=2]="MidPoint",i[i.Center=3]="Center",i[i.Node=4]="Node",i[i.Quadrant=5]="Quadrant",i[i.Insertion=7]="Insertion",i[i.Perpendicular=8]="Perpendicular",i[i.Tangent=9]="Tangent",i[i.Nearest=10]="Nearest",i[i.Centroid=11]="Centroid",i))(z||{});function Ac(i){let t=0;for(const e of i)t|=1<<e-1;return t}function Pc(i){const t=[];for(const e of Object.values(z)){if(typeof e!="number")continue;const s=1<<e-1;i&s&&t.push(e)}return t}function Tc(i,t){return i^1<<t-1}function Ec(i,t){return(i&1<<t-1)!==0}function Lc(i,t){return i|1<<t-1}function Mc(i,t){return i&~(1<<t-1)}const Xr=class Xr extends ht{get dxfTypeName(){return"LINE"}constructor(t,e){super(),this._geo=new Ee(t,e)}get startPoint(){return this._geo.startPoint}set startPoint(t){this._geo.startPoint=t}get endPoint(){return this._geo.endPoint}set endPoint(t){this._geo.endPoint=t}get midPoint(){return this._geo.midPoint}get geometricExtents(){return this._geo.box}get closed(){return!1}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"startX",type:"float",editable:!0,accessor:{get:()=>this.startPoint.x,set:t=>{this.startPoint.x=t}}},{name:"startY",type:"float",editable:!0,accessor:{get:()=>this.startPoint.y,set:t=>{this.startPoint.y=t}}},{name:"startZ",type:"float",editable:!0,accessor:{get:()=>this.startPoint.z,set:t=>{this.startPoint.z=t}}},{name:"endX",type:"float",editable:!0,accessor:{get:()=>this.endPoint.x,set:t=>{this.endPoint.x=t}}},{name:"endY",type:"float",editable:!0,accessor:{get:()=>this.endPoint.y,set:t=>{this.endPoint.y=t}}},{name:"endZ",type:"float",editable:!0,accessor:{get:()=>this.endPoint.z,set:t=>{this.endPoint.z=t}}},{name:"length",type:"float",editable:!1,accessor:{get:()=>this._geo.length}}]}]}}subGetGripPoints(){const t=new Array;return t.push(this.midPoint),t.push(this.startPoint),t.push(this.endPoint),t}subGetOsnapPoints(t,e,s,n){const r=this.startPoint,o=this.endPoint;switch(t){case z.EndPoint:n.push(r),n.push(o);break;case z.MidPoint:n.push(this.midPoint);break;case z.Nearest:{const a=this._geo.project(e);n.push(a)}break;case z.Perpendicular:{const a=this._geo.perpPoint(e);n.push(a)}break;case z.Tangent:break}}transformBy(t){return this._geo.transform(t),this}subWorldDraw(t){const e=this.startPoint,s=this.endPoint,n=[new w(e.x,e.y,0),new w(s.x,s.y,0)];return t.lines(n)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbLine"),t.writePoint3d(10,this.startPoint),t.writePoint3d(11,this.endPoint),this}};Xr.typeName="Line";let Ys=Xr;var Za=(i=>(i[i.Top=0]="Top",i[i.Zero=1]="Zero",i[i.Bottom=2]="Bottom",i))(Za||{}),Ka=(i=>(i[i.HasVertex=1]="HasVertex",i[i.Closed=2]="Closed",i[i.SuppressStartCaps=4]="SuppressStartCaps",i[i.SuppressEndCaps=8]="SuppressEndCaps",i))(Ka||{});const $r=class $r extends lt{get dxfTypeName(){return"MLINE"}constructor(){super(),this._styleName="",this._styleObjectHandle="",this._scale=1,this._justification=1,this._flags=0,this._styleCount=0,this._startPosition=new w,this._normal=new _(0,0,1),this._segments=[]}get styleName(){return this._styleName||this.getDefaultStyleName()}set styleName(t){this._styleName=t}get styleObjectHandle(){return this._styleObjectHandle}set styleObjectHandle(t){this._styleObjectHandle=t}get scale(){return this._scale}set scale(t){this._scale=t}get justification(){return this._justification}set justification(t){this._justification=t}get flags(){return this._flags}set flags(t){this._flags=t}get styleCount(){return this._styleCount}set styleCount(t){this._styleCount=Math.max(0,t)}get startPosition(){return this._startPosition}set startPosition(t){this._startPosition.copy(t)}get normal(){return this._normal}set normal(t){this._normal.copy(t)}get segments(){return this._segments.map(t=>this.cloneSegment(t))}set segments(t){this._segments=t.map(e=>this.createSegment(e)),this.updateHasVertexFlag()}get vertexCount(){return this._segments.length}get closed(){return(this._flags&2)!==0}set closed(t){this.setFlag(2,t)}get suppressStartCaps(){return(this._flags&4)!==0}set suppressStartCaps(t){this.setFlag(4,t)}get suppressEndCaps(){return(this._flags&8)!==0}set suppressEndCaps(t){this.setFlag(8,t)}appendSegment(t){this._segments.push(this.createSegment(t)),this.updateHasVertexFlag()}clearSegments(){this._segments=[],this.updateHasVertexFlag()}get geometricExtents(){const t=this.collectGeometryPoints();return new N().setFromPoints(t)}transformBy(t){return this._startPosition.applyMatrix4(t),this._segments.forEach(e=>{e.position.applyMatrix4(t),this.transformVector(e.direction,t),this.transformVector(e.miterDirection,t)}),this.transformVector(this._normal,t),this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"mline",properties:[{name:"styleName",type:"string",editable:!0,accessor:{get:()=>this.styleName,set:t=>{this.styleName=t}}},{name:"scale",type:"float",editable:!0,accessor:{get:()=>this.scale,set:t=>{this.scale=t}}},{name:"justification",type:"int",editable:!0,accessor:{get:()=>this.justification,set:t=>{this.justification=t}}},{name:"closed",type:"boolean",editable:!0,accessor:{get:()=>this.closed,set:t=>{this.closed=t}}},{name:"vertexCount",type:"int",editable:!1,accessor:{get:()=>this.vertexCount}}]}]}}subWorldDraw(t){if(this._segments.length===0)return;const e=[],s=this.getMLineStyle(),n=this.getRenderableElementCount(s),r=t.subEntityTraits,o=r.color,a=r.rgbColor,h=r.lineType,c=r.fillType,d=r.drawOrder,u=this.createFillArea(s,n);if(u&&(r.color=o,r.rgbColor=a,this.applyFillTraits(s,r),r.fillType={solidFill:!0,patternAngle:0,definitionLines:[]},r.drawOrder=-1,e.push(t.area(u)),r.fillType=c,r.drawOrder=d),n<=0){const p=this.getReferencePath();p.length>=2&&e.push(t.lines(p))}else{for(let p=0;p<n;p++){r.color=o,r.rgbColor=a,r.lineType=h,this.applyStyleElementTraits(s,p,r);const g=this.getElementPath(p,s);g.length>=2&&e.push(t.lines(g))}this.appendStyleDrivenJointAndCapEntities(t,e,s,n,o,a,h)}if(r.color=o,r.rgbColor=a,r.lineType=h,r.fillType=c,r.drawOrder=d,e.length!==0)return e.length===1?e[0]:t.group(e)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbMline"),t.writeString(2,this.styleName),t.writeHandle(340,this._styleObjectHandle),t.writeDouble(40,this._scale),t.writeInt16(70,this._justification),t.writeInt16(71,this._flags),t.writeInt16(72,this.vertexCount),t.writeInt16(73,this._styleCount),t.writePoint3d(10,this._startPosition),t.writeVector3d(210,this._normal),this._segments.forEach(e=>{t.writePoint3d(11,e.position),t.writeVector3d(12,e.direction),t.writeVector3d(13,e.miterDirection),e.elements.forEach(s=>{t.writeInt16(74,s.parameterCount),s.parameters.forEach(n=>t.writeDouble(41,n)),t.writeInt16(75,s.fillCount),s.fillParameters.forEach(n=>t.writeDouble(42,n))})}),this}setFlag(t,e){e?this._flags|=t:this._flags&=~t}updateHasVertexFlag(){this.setFlag(1,this._segments.length>0)}createSegment(t){var e;return{position:new w().copy(t.position),direction:new _().copy(t.direction),miterDirection:new _().copy(t.miterDirection),elements:((e=t.elements)==null?void 0:e.map(s=>this.createElement(s)))??[]}}createElement(t){const e=t.parameters?[...t.parameters]:[],s=t.fillParameters?[...t.fillParameters]:[];return{parameterCount:t.parameterCount??e.length,parameters:e,fillCount:t.fillCount??s.length,fillParameters:s}}cloneSegment(t){return{position:t.position.clone(),direction:t.direction.clone(),miterDirection:t.miterDirection.clone(),elements:t.elements.map(e=>({parameterCount:e.parameterCount,parameters:[...e.parameters],fillCount:e.fillCount,fillParameters:[...e.fillParameters]}))}}collectGeometryPoints(){const t=[this._startPosition];if(this._segments.length===0)return t;const e=this.getMLineStyle(),s=this.getRenderableElementCount(e);if(s<=0)return this._segments.forEach(n=>t.push(n.position)),t;for(let n=0;n<s;n++)t.push(...this.getElementPath(n,e));return t}getRenderableElementCount(t){const e=(t==null?void 0:t.elementCount)??0;return Math.max(this._styleCount,e,...this._segments.map(s=>s.elements.length),0)}getReferencePath(){const t=[this._startPosition.clone(),...this._segments.map(e=>e.position.clone())];return this.closePathIfNeeded(t)}getElementPath(t,e){const s=[],n=this._segments[0];return s.push(this.getElementBoundaryPoint("start",n,t,e)),this._segments.forEach(r=>{s.push(this.offsetPoint(r.position,r.miterDirection,this.getElementMiterOffset(r,t,e)))}),s[s.length-1]=this.getElementBoundaryPoint("end",this._segments[this._segments.length-1],t,e),this.closePathIfNeeded(s)}getElementMiterOffset(t,e,s){var r;const n=t.elements[e];return(r=n==null?void 0:n.parameters)!=null&&r.length?n.parameters[0]:this.getStyleElementOffset(e,s)}getElementBoundaryPoint(t,e,s,n){const r=this.getElementMiterOffset(e,s,n),o=t==="start"?this._startPosition:e.position,a=this.offsetPoint(o,e.miterDirection,r);if(!this.shouldApplyCapCutAtSide(t,n))return a;const h=t==="start"?n==null?void 0:n.startAngle:n==null?void 0:n.endAngle,c=this.computeCapCutDistance(r,h,t);if(c===0)return a;const d=t==="start"?this.getStartSegmentDirection():this.getEndSegmentDirection();return d.lengthSq()===0?a:a.add(d.multiplyScalar(c))}shouldApplyCapCutAtSide(t,e){return!e||this.closed?!1:t==="start"?this.suppressStartCaps?!1:(e.flags&112)!==0:this.suppressEndCaps?!1:(e.flags&1792)!==0}computeCapCutDistance(t,e,s){const n=this.normalizeCapAngle(e),r=Math.tan(n);if(Math.abs(r)<1e-6)return 0;const o=t/r;return o}normalizeCapAngle(t){if(t==null||!Number.isFinite(t))return Math.PI/2;let e=t%180;return e<0&&(e+=180),(e<1||e>179)&&(e=90),e*Math.PI/180}getStartSegmentDirection(){const t=this._segments[0],e=new _;return t&&(e.subVectors(t.position,this._startPosition),e.lengthSq()===0&&e.copy(t.direction)),e.lengthSq()>0&&e.normalize(),e}getEndSegmentDirection(){const t=this._segments[this._segments.length-1];if(!t)return new _;const e=new _,s=this._segments.length>1?this._segments[this._segments.length-2].position:this._startPosition;return e.subVectors(t.position,s),e.lengthSq()===0&&e.copy(t.direction),e.lengthSq()>0&&e.normalize(),e}createFillArea(t,e){if(!t||!(t.flags&1)||e<2)return;const s=this.getFillBoundaryElementIndices(e,t);if(!s)return;const n=this.getElementPath(s.outerIndex,t),r=this.getElementPath(s.innerIndex,t),o=this.stripClosingPoint(n),a=this.stripClosingPoint(r);if(o.length<2||a.length<2)return;const h=new Pe;if(this.closed){if(o.length<3||a.length<3)return;h.add(new at(o.map(c=>({x:c.x,y:c.y})),!0)),h.add(new at(a.map(c=>({x:c.x,y:c.y})),!0))}else{const c=[...o,...a.slice().reverse()].map(d=>({x:d.x,y:d.y}));if(c.length<3)return;h.add(new at(c,!0))}return h}getFillBoundaryElementIndices(t,e){let s=Number.POSITIVE_INFINITY,n=Number.NEGATIVE_INFINITY,r=-1,o=-1;for(let a=0;a<t;a++){const h=this.getElementReferenceOffset(a,e);h<s&&(s=h,r=a),h>n&&(n=h,o=a)}if(!(r<0||o<0||r===o))return{outerIndex:o,innerIndex:r}}getElementReferenceOffset(t,e){var n;const s=this._segments[0];if(s){const r=s.elements[t];if((n=r==null?void 0:r.parameters)!=null&&n.length)return r.parameters[0]}return this.getStyleElementOffset(t,e)}getStyleElementOffset(t,e){const s=e==null?void 0:e.elements[t];if(!s)return 0;const n=this.getStyleJustificationShift(e);return(s.offset+n)*this._scale}getStyleJustificationShift(t){const e=(t==null?void 0:t.elements)??[];if(e.length<=0)return 0;let s=Number.POSITIVE_INFINITY,n=Number.NEGATIVE_INFINITY;for(const r of e){const o=r.offset;o<s&&(s=o),o>n&&(n=o)}return this._justification===0?-n:this._justification===2?-s:0}stripClosingPoint(t){if(t.length<2)return t;const e=t[0],s=t[t.length-1],n=1e-9;return Math.abs(e.x-s.x)<=n&&Math.abs(e.y-s.y)<=n&&Math.abs(e.z-s.z)<=n?t.slice(0,-1):t}offsetPoint(t,e,s){if(s===0||e.lengthSq()===0)return t.clone();const n=e.clone().normalize().multiplyScalar(s);return t.clone().add(n)}closePathIfNeeded(t){if(!this.closed||t.length<2)return t;const e=t[0],s=t[t.length-1],n=1e-9;return Math.abs(e.x-s.x)<=n&&Math.abs(e.y-s.y)<=n&&Math.abs(e.z-s.z)<=n||t.push(e.clone()),t}appendStyleDrivenJointAndCapEntities(t,e,s,n,r,o,a){!s||n<2||(e.push(...this.drawMiterJointEntities(t,s,n,r,o,a)),e.push(...this.drawCapEntities(t,s,n,r,o,a)))}drawMiterJointEntities(t,e,s,n,r,o){if(this.closed||this._segments.length<2||!(e.flags&2))return[];const a=[],h=t.subEntityTraits;for(let c=0;c<this._segments.length-1;c++){const d=this._segments[c],u=Array.from({length:s},(p,g)=>{const m=this.getElementMiterOffset(d,g,e);return{elementIndex:g,offset:m,point:this.offsetPoint(d.position,d.miterDirection,m)}}).sort((p,g)=>g.offset-p.offset);for(let p=0;p<u.length-1;p++)this.applyElementDrawTraits(h,n,r,o,e,u[p].elementIndex),a.push(t.lines([u[p].point,u[p+1].point]))}return a}drawCapEntities(t,e,s,n,r,o){if(this.closed||this._segments.length<=0)return[];const a=[];return a.push(...this.drawCapEntitiesForSide(t,"start",e,s,n,r,o)),a.push(...this.drawCapEntitiesForSide(t,"end",e,s,n,r,o)),a}drawCapEntitiesForSide(t,e,s,n,r,o,a){if(e==="start"&&this.suppressStartCaps)return[];if(e==="end"&&this.suppressEndCaps)return[];const h=s.flags,c=e==="start",d=c?(h&16)!==0:(h&256)!==0,u=c?(h&64)!==0:(h&1024)!==0,p=c?(h&32)!==0:(h&512)!==0;if(!d&&!u&&!p)return[];const g=this.getCapElementPoints(e,n,s);if(g.length<2)return[];const m=[],y=t.subEntityTraits;if(d)for(let x=0;x<g.length-1;x++)this.applyElementDrawTraits(y,r,o,a,s,g[x].elementIndex),m.push(t.lines([g[x].point,g[x+1].point]));const b=c?this.getStartSegmentDirection().multiplyScalar(-1):this.getEndSegmentDirection().clone();if(u){const x=this.drawCapArcBetweenElements(t,e,g[0],g[g.length-1],b,y,r,o,a,s);x&&m.push(x)}if(p)for(let x=1;x<Math.floor(g.length/2);x++){const I=g[x],S=g[g.length-1-x];if(!I||!S||I===S)continue;const L=this.drawCapArcBetweenElements(t,e,I,S,b,y,r,o,a,s);L&&m.push(L)}return m}getCapElementPoints(t,e,s){const n=t==="start"?this._segments[0]:this._segments[this._segments.length-1];return n?Array.from({length:e},(r,o)=>({elementIndex:o,offset:this.getElementMiterOffset(n,o,s),point:this.getElementBoundaryPoint(t,n,o,s)})).sort((r,o)=>o.offset-r.offset):[]}drawCapArcBetweenElements(t,e,s,n,r,o,a,h,c,d){const u=e==="end"?n.point:s.point,p=e==="end"?s.point:n.point,g=u.distanceTo(p);if(g<=1e-9||r.lengthSq()===0)return;const y=u.clone().add(new _().subVectors(p,u).multiplyScalar(.5)).add(r.clone().normalize().multiplyScalar(g/2)),b=Ie.createByThreePoints(u,p,y);if(b)return this.applyElementDrawTraits(o,a,h,c,d,e==="end"?n.elementIndex:s.elementIndex),t.circularArc(b)}applyElementDrawTraits(t,e,s,n,r,o){t.color=e,t.rgbColor=s,t.lineType=n,this.applyStyleElementTraits(r,o,t)}transformVector(t,e){const s=new w,n=new w(t.x,t.y,t.z);s.applyMatrix4(e),n.applyMatrix4(e),t.set(n.x-s.x,n.y-s.y,n.z-s.z)}getMLineStyle(){var r;const t=this.database.objects.mlineStyle,e=this.styleObjectHandle?t.getIdAt(this.styleObjectHandle):void 0;if(e)return e;const s=this.styleName?t.getAt(this.styleName):void 0;if(s)return s;const n=(r=this.styleName)==null?void 0:r.toUpperCase();if(n)for(const[o,a]of t.entries()){const h=(a.styleName||o).toUpperCase();if(o.toUpperCase()===n||h===n)return a}}applyStyleElementTraits(t,e,s){const n=t==null?void 0:t.elements[e];if(!n)return;const r=this.resolveStyleElementLineType(n.lineType);r&&(s.lineType=r),!(n.color.isByBlock||n.color.isByLayer)&&(s.color=n.color.clone(),s.rgbColor=n.color.RGB??this.rgbColor)}applyFillTraits(t,e){const s=t==null?void 0:t.fillColor;!s||s.isByBlock||s.isByLayer||(e.color=s.clone(),e.rgbColor=s.RGB??this.rgbColor)}resolveStyleElementLineType(t){var c;const e=t==null?void 0:t.trim();if(!e)return;const s=e.toUpperCase(),n=dt.toUpperCase(),r=fe.toUpperCase();let o="UserSpecified",a=e;if(s===n){o="ByLayer";const d=(c=this.database.tables.layerTable.getAt(this.layer))==null?void 0:c.linetype;a=d&&d.toUpperCase()!==n&&d.toUpperCase()!==r?d:Se}else s===r&&(o="ByBlock",a=Se);const h=this.database.tables.linetypeTable.getAt(a);return h?{type:o,...h.linetype}:{type:o,name:a,standardFlag:0,description:"",totalPatternLength:0}}resolveEffectiveProperties(){super.resolveEffectiveProperties(),this._styleName||(this._styleName=this.getDefaultStyleName())}getDefaultStyleName(){try{return this.database.cmlstyle||ce}catch{return ce}}};$r.typeName="MLine";let Hi=$r;var hs=(i=>(i[i.InvisibleLeader=0]="InvisibleLeader",i[i.StraightLeader=1]="StraightLeader",i[i.SplineLeader=2]="SplineLeader",i))(hs||{}),ue=(i=>(i[i.NoneContent=0]="NoneContent",i[i.BlockContent=1]="BlockContent",i[i.MTextContent=2]="MTextContent",i[i.ToleranceContent=3]="ToleranceContent",i))(ue||{}),Qa=(i=>(i[i.Horizontal=0]="Horizontal",i[i.Vertical=1]="Vertical",i))(Qa||{}),Ja=(i=>(i[i.Unknown=0]="Unknown",i[i.Left=1]="Left",i[i.Right=2]="Right",i[i.Top=3]="Top",i[i.Bottom=4]="Bottom",i))(Ja||{});const kc=1,vc=2,Cc=4,Oc=8,Nc=64,Bc=128,Rc=32768,qr=class qr extends lt{get dxfTypeName(){return"MULTILEADER"}constructor(){super(),this._leaders=[],this._leaderLineType=1,this._contentType=0,this._doglegEnabled=!1,this._doglegLength=0,this._doglegVector=new _(1,0,0),this._normal=new _(0,0,1),this._mleaderStyleId="",this._textHeight=2.5,this._textWidth=0,this._textRotation=0,this._textDirection=new _(1,0,0),this._textStyleName="",this._textAttachmentPoint=ot.MiddleLeft,this._textDrawingDirection=Dt.LEFT_TO_RIGHT,this._textLineSpacingFactor=1,this._textAttachmentDirection=0,this._arrowheadOverrides=[],this._blockAttributes=[]}get leaders(){return this._leaders.map(t=>this.cloneLeader(t))}get numberOfLeaders(){return this._leaders.length}get leaderLineType(){return this._leaderLineType}set leaderLineType(t){this._leaderLineType=t}get contentType(){return this._contentType}set contentType(t){this._contentType=t}get doglegEnabled(){return this._doglegEnabled}set doglegEnabled(t){this._doglegEnabled=t}get doglegLength(){return this._doglegLength}set doglegLength(t){this._doglegLength=t}get doglegVector(){return this._doglegVector}set doglegVector(t){this._doglegVector.copy(t)}get landingPoint(){return this._landingPoint}set landingPoint(t){this._landingPoint=t?this.createPoint(t):void 0}get normal(){return this._normal}set normal(t){this._normal.copy(t)}get mleaderStyleId(){return this._mleaderStyleId}set mleaderStyleId(t){this._mleaderStyleId=t}get version(){return this._version}set version(t){this._version=t}get leaderStyleId(){return this._leaderStyleId}set leaderStyleId(t){this._leaderStyleId=t}get propertyOverrideFlag(){return this._propertyOverrideFlag}set propertyOverrideFlag(t){this._propertyOverrideFlag=t}get leaderLineColor(){return this._leaderLineColor}set leaderLineColor(t){this._leaderLineColor=t}get leaderLineTypeId(){return this._leaderLineTypeId}set leaderLineTypeId(t){this._leaderLineTypeId=t}get leaderLineWeight(){return this._leaderLineWeight}set leaderLineWeight(t){this._leaderLineWeight=t}get landingEnabled(){return this._landingEnabled}set landingEnabled(t){this._landingEnabled=t}get arrowheadId(){return this._arrowheadId}set arrowheadId(t){this._arrowheadId=t}get arrowheadSize(){return this._arrowheadSize}set arrowheadSize(t){this._arrowheadSize=t}get textStyleId(){return this._textStyleId}set textStyleId(t){this._textStyleId=t}get textLeftAttachmentType(){return this._textLeftAttachmentType}set textLeftAttachmentType(t){this._textLeftAttachmentType=t}get textRightAttachmentType(){return this._textRightAttachmentType}set textRightAttachmentType(t){this._textRightAttachmentType=t}get textAngleType(){return this._textAngleType}set textAngleType(t){this._textAngleType=t}get textAlignmentType(){return this._textAlignmentType}set textAlignmentType(t){this._textAlignmentType=t}get textColor(){return this._textColor}set textColor(t){this._textColor=t}get textFrameEnabled(){return this._textFrameEnabled}set textFrameEnabled(t){this._textFrameEnabled=t}get landingGap(){return this._landingGap}set landingGap(t){this._landingGap=t}get textAttachment(){return this._textAttachment}set textAttachment(t){this._textAttachment=t}get textFlowDirection(){return this._textFlowDirection}set textFlowDirection(t){this._textFlowDirection=t}get blockContentId(){return this._blockContentId}set blockContentId(t){this._blockContentId=t}get blockContentColor(){return this._blockContentColor}set blockContentColor(t){this._blockContentColor=t}get blockContentScale(){return this._blockContentScale}set blockContentScale(t){this._blockContentScale=t}get blockContentRotation(){return this._blockContentRotation}set blockContentRotation(t){this._blockContentRotation=t}get blockContentConnectionType(){return this._blockContentConnectionType}set blockContentConnectionType(t){this._blockContentConnectionType=t}get annotativeScaleEnabled(){return this._annotativeScaleEnabled}set annotativeScaleEnabled(t){this._annotativeScaleEnabled=t}get arrowheadOverrides(){return this._arrowheadOverrides}set arrowheadOverrides(t){this._arrowheadOverrides=t}get blockAttributes(){return this._blockAttributes}set blockAttributes(t){this._blockAttributes=t}get textDirectionNegative(){return this._textDirectionNegative}set textDirectionNegative(t){this._textDirectionNegative=t}get textAlignInIPE(){return this._textAlignInIPE}set textAlignInIPE(t){this._textAlignInIPE=t}get bottomTextAttachmentDirection(){return this._bottomTextAttachmentDirection}set bottomTextAttachmentDirection(t){this._bottomTextAttachmentDirection=t}get topTextAttachmentDirection(){return this._topTextAttachmentDirection}set topTextAttachmentDirection(t){this._topTextAttachmentDirection=t}get contentScale(){return this._contentScale}set contentScale(t){this._contentScale=t}get contentBasePosition(){return this._contentBasePosition}set contentBasePosition(t){this._contentBasePosition=t}get textAnchor(){return this._textAnchor}set textAnchor(t){this._textAnchor=t}get textLineSpacingStyle(){return this._textLineSpacingStyle}set textLineSpacingStyle(t){this._textLineSpacingStyle=t}get textBackgroundColor(){return this._textBackgroundColor}set textBackgroundColor(t){this._textBackgroundColor=t}get textBackgroundScaleFactor(){return this._textBackgroundScaleFactor}set textBackgroundScaleFactor(t){this._textBackgroundScaleFactor=t}get textBackgroundTransparency(){return this._textBackgroundTransparency}set textBackgroundTransparency(t){this._textBackgroundTransparency=t}get textBackgroundColorOn(){return this._textBackgroundColorOn}set textBackgroundColorOn(t){this._textBackgroundColorOn=t}get textFillOn(){return this._textFillOn}set textFillOn(t){this._textFillOn=t}get textColumnType(){return this._textColumnType}set textColumnType(t){this._textColumnType=t}get textUseAutoHeight(){return this._textUseAutoHeight}set textUseAutoHeight(t){this._textUseAutoHeight=t}get textColumnWidth(){return this._textColumnWidth}set textColumnWidth(t){this._textColumnWidth=t}get textColumnGutterWidth(){return this._textColumnGutterWidth}set textColumnGutterWidth(t){this._textColumnGutterWidth=t}get textColumnFlowReversed(){return this._textColumnFlowReversed}set textColumnFlowReversed(t){this._textColumnFlowReversed=t}get textColumnHeight(){return this._textColumnHeight}set textColumnHeight(t){this._textColumnHeight=t}get textUseWordBreak(){return this._textUseWordBreak}set textUseWordBreak(t){this._textUseWordBreak=t}get hasMText(){return this._hasMText}set hasMText(t){this._hasMText=t}get hasBlock(){return this._hasBlock}set hasBlock(t){this._hasBlock=t}get planeOrigin(){return this._planeOrigin}set planeOrigin(t){this._planeOrigin=t}get planeXAxisDirection(){return this._planeXAxisDirection}set planeXAxisDirection(t){this._planeXAxisDirection=t}get planeYAxisDirection(){return this._planeYAxisDirection}set planeYAxisDirection(t){this._planeYAxisDirection=t}get planeNormalReversed(){return this._planeNormalReversed}set planeNormalReversed(t){this._planeNormalReversed=t}get leaderSections(){return this.leaders}get blockContentData(){return this.blockContent}get mtextContent(){return this._mtextContent?{text:this._mtextContent.text,anchorPoint:this._mtextContent.anchorPoint.clone()}:void 0}set mtextContent(t){if(!t){this._mtextContent=void 0,this._contentType===2&&(this._contentType=0);return}this._mtextContent={text:t.text,anchorPoint:this.createPoint(t.anchorPoint)},this._contentType=2}get contents(){var t;return((t=this._mtextContent)==null?void 0:t.text)??""}set contents(t){this._mtextContent?this._mtextContent.text=t:this._mtextContent={text:t,anchorPoint:new w},this._contentType=2}get textLocation(){var t;return(t=this._mtextContent)==null?void 0:t.anchorPoint}set textLocation(t){if(!t){this._mtextContent=void 0;return}this._mtextContent?this._mtextContent.anchorPoint.copy(t):this._mtextContent={text:"",anchorPoint:this.createPoint(t)},this._contentType=2}get textHeight(){return this._textHeight}set textHeight(t){this._textHeight=t}get textWidth(){return this._textWidth}set textWidth(t){this._textWidth=t}get textRotation(){return this._textRotation}set textRotation(t){this._textRotation=t}get textDirection(){return this._textDirection}set textDirection(t){this._textDirection.copy(t)}get textStyleName(){return this._textStyleName}set textStyleName(t){this._textStyleName=t}get textAttachmentPoint(){return this._textAttachmentPoint}set textAttachmentPoint(t){this._textAttachmentPoint=t}get textDrawingDirection(){return this._textDrawingDirection}set textDrawingDirection(t){this._textDrawingDirection=t}get textLineSpacingFactor(){return this._textLineSpacingFactor}set textLineSpacingFactor(t){this._textLineSpacingFactor=t}get textAttachmentDirection(){return this._textAttachmentDirection}set textAttachmentDirection(t){this._textAttachmentDirection=t}get blockContent(){var t,e;return this._blockContent?{blockContentId:this._blockContent.blockContentId,blockHandle:this._blockContent.blockHandle,normal:(t=this._blockContent.normal)==null?void 0:t.clone(),position:(e=this._blockContent.position)==null?void 0:e.clone(),scale:this._blockContent.scale.clone(),rotation:this._blockContent.rotation,color:this._blockContent.color,transformationMatrix:[...this._blockContent.transformationMatrix]}:void 0}set blockContent(t){if(!t){this._blockContent=void 0,this._contentType===1&&(this._contentType=0);return}this._blockContent={blockContentId:t.blockContentId??t.blockHandle,blockHandle:t.blockHandle,normal:t.normal?new _(t.normal):void 0,position:t.position?this.createPoint(t.position):void 0,scale:new _(t.scale??{x:1,y:1,z:1}),rotation:t.rotation??0,color:t.color,transformationMatrix:t.transformationMatrix?[...t.transformationMatrix]:[]},this.blockContentId=this._blockContent.blockContentId,this._contentType=1}addLeader(t={}){var s,n;const e={lastLeaderLinePoint:t.lastLeaderLinePoint?this.createPoint(t.lastLeaderLinePoint):void 0,lastLeaderLinePointSet:t.lastLeaderLinePointSet,landingPoint:t.landingPoint?this.createPoint(t.landingPoint):void 0,doglegVector:t.doglegVector?new _(t.doglegVector):void 0,doglegVectorSet:t.doglegVectorSet,doglegLength:t.doglegLength,breaks:((s=t.breaks)==null?void 0:s.map(r=>({index:r.index,start:this.createPoint(r.start),end:this.createPoint(r.end)})))??[],leaderBranchIndex:t.leaderBranchIndex,directionType:t.directionType,leaderLines:[]};return(n=t.leaderLines)==null||n.forEach(r=>{e.leaderLines.push(this.createLeaderLine(r))}),this._leaders.push(e),this._leaders.length-1}removeLeader(t){return this.checkLeaderIndex(t),this._leaders.splice(t,1),this}addLeaderLine(t,e=[]){return this.checkLeaderIndex(t),this._leaders[t].leaderLines.push(this.createLeaderLine({vertices:e})),this._leaders[t].leaderLines.length-1}appendVertex(t,e,s){return this.getMutableLeaderLine(t,e).vertices.push(this.createPoint(s)),this}setLeaderLineVertices(t,e,s){return this.getMutableLeaderLine(t,e).vertices=s.map(n=>this.createPoint(n)),this}getLeaderLineVertices(t,e){return this.getMutableLeaderLine(t,e).vertices.map(s=>s.clone())}addBreak(t,e,s,n){return this.getMutableLeaderLine(t,e).breaks.push({start:this.createPoint(s),end:this.createPoint(n)}),this}setLandingPoint(t,e){return this.checkLeaderIndex(t),this._leaders[t].landingPoint=e?this.createPoint(e):void 0,this}setDoglegDirection(t,e){return this.checkLeaderIndex(t),this._leaders[t].doglegVector=new _(e),this}setDoglegLength(t,e){return this.checkLeaderIndex(t),this._leaders[t].doglegLength=e,this}get geometricExtents(){const t=this.collectGeometryPoints();return t.length>0?new N().setFromPoints(t):new N}subGetGripPoints(){return this.collectGeometryPoints().map(t=>t.clone())}transformBy(t){var e,s,n,r,o,a,h,c;return this._leaders.forEach(d=>{var u,p;(u=d.lastLeaderLinePoint)==null||u.applyMatrix4(t),(p=d.landingPoint)==null||p.applyMatrix4(t),d.doglegVector&&this.transformVector(d.doglegVector,t),d.breaks.forEach(g=>{g.start.applyMatrix4(t),g.end.applyMatrix4(t)}),d.leaderLines.forEach(g=>{g.vertices.forEach(m=>m.applyMatrix4(t)),g.breaks.forEach(m=>{m.start.applyMatrix4(t),m.end.applyMatrix4(t)})})}),(e=this._landingPoint)==null||e.applyMatrix4(t),(s=this.contentBasePosition)==null||s.applyMatrix4(t),this.transformVector(this._doglegVector,t),this.transformVector(this._normal,t),(n=this.textAnchor)==null||n.applyMatrix4(t),(r=this._mtextContent)==null||r.anchorPoint.applyMatrix4(t),this.transformVector(this._textDirection,t),(a=(o=this._blockContent)==null?void 0:o.position)==null||a.applyMatrix4(t),(h=this._blockContent)!=null&&h.normal&&this.transformVector(this._blockContent.normal,t),this.blockContentScale&&this.transformVector(this.blockContentScale,t),(c=this.planeOrigin)==null||c.applyMatrix4(t),this.planeXAxisDirection&&this.transformVector(this.planeXAxisDirection,t),this.planeYAxisDirection&&this.transformVector(this.planeYAxisDirection,t),this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"leader",properties:[{name:"contentType",type:"enum",editable:!0,options:[{label:ue[0],value:0},{label:ue[1],value:1},{label:ue[2],value:2},{label:ue[3],value:3}],accessor:{get:()=>this.contentType,set:t=>{this.contentType=t}}},{name:"leaderLineType",type:"enum",editable:!0,options:[{label:hs[0],value:0},{label:hs[1],value:1},{label:hs[2],value:2}],accessor:{get:()=>this.leaderLineType,set:t=>{this.leaderLineType=t}}},{name:"doglegEnabled",type:"boolean",editable:!0,accessor:{get:()=>this.doglegEnabled,set:t=>{this.doglegEnabled=t}}},{name:"doglegLength",type:"float",editable:!0,accessor:{get:()=>this.doglegLength,set:t=>{this.doglegLength=t}}},{name:"leaderCount",type:"int",editable:!1,accessor:{get:()=>this.numberOfLeaders}}]},{groupName:"text",properties:[{name:"contents",type:"string",editable:!0,accessor:{get:()=>this.contents,set:t=>{this.contents=t}}},{name:"textHeight",type:"float",editable:!0,accessor:{get:()=>this.textHeight,set:t=>{this.textHeight=t}}},{name:"textWidth",type:"float",editable:!0,accessor:{get:()=>this.textWidth,set:t=>{this.textWidth=t}}},{name:"textStyleName",type:"string",editable:!0,accessor:{get:()=>this.textStyleName,set:t=>{this.textStyleName=t}}}]}]}}resolveEffectiveProperties(){if(super.resolveEffectiveProperties(),this._mleaderStyleId)return;const t=this.getDefaultMLeaderStyle();t&&(this._mleaderStyleId=t.objectId)}subWorldDraw(t){const e=[],s=t.subEntityTraits,n=s.color,r=s.rgbColor,o=s.lineType,a=s.lineWeight,h=this.getResolvedLeaderLineColor(),c=this.getResolvedLeaderLineStyle(),d=this.getResolvedLeaderLineWeight(),u=this.getResolvedTextColor();this.getResolvedLeaderLineType()!==0&&(this.applyColorTraits(s,h,n,r),this.applyLineTraits(s,c,d),this._leaders.forEach(g=>{g.leaderLines.forEach(y=>{const b=this.getLeaderLineDrawPoints(g,y);if(b.length>0){const x=this.drawLeaderLine(t,b);x&&e.push(x)}});const m=this.getDoglegPoints(g);m&&e.push(t.lines(m))}));const p=this.getRenderableMTextContent();if(this.contentType===2&&p){this.applyColorTraits(s,u,n,r);const g=this.getResolvedTextHeight(),m={text:p.text,height:g,width:this.getMTextRenderWidth(p.text,g),position:p.anchorPoint,rotation:this.textRotation,directionVector:this.textDirection,attachmentPoint:this.textAttachmentPoint,drawingDirection:this.textDrawingDirection,lineSpaceFactor:this.textLineSpacingFactor};e.push(t.mtext(m,this.getTextStyle(),!1))}if(s.color=n,s.rgbColor=r,s.lineType=o,s.lineWeight=a,e.length!==0)return e.length===1?e[0]:t.group(e)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbMLeader"),t.writeInt16(170,this.leaderLineType),t.writeBoolean(290,this.doglegEnabled),t.writeDouble(41,this.doglegLength),t.writeInt16(172,this.contentType),t.writeVector3d(210,this.normal),t.writeHandle(340,this.mleaderStyleId),this._landingPoint&&t.writePoint3d(10,this._landingPoint),t.writeVector3d(11,this.doglegVector),this._mtextContent&&(t.writeString(1,this._mtextContent.text),t.writePoint3d(12,this._mtextContent.anchorPoint),t.writeDouble(40,this.textHeight),t.writeDouble(42,this.textWidth),t.writeAngle(50,this.textRotation),t.writeString(7,this.textStyleName)),this._blockContent&&(t.writeHandle(341,this._blockContent.blockContentId??""),this._blockContent.position&&t.writePoint3d(15,this._blockContent.position),t.writeVector3d(16,this._blockContent.scale),t.writeAngle(52,this._blockContent.rotation)),this._leaders.forEach(e=>{e.landingPoint&&t.writePoint3d(110,e.landingPoint),e.doglegVector&&t.writeVector3d(111,e.doglegVector),t.writeDouble(140,e.doglegLength),t.writeInt16(171,e.leaderLines.length),e.leaderLines.forEach(s=>{t.writeInt16(90,s.vertices.length),s.vertices.forEach(n=>t.writePoint3d(10,n))})}),this}createPoint(t){return new w().copy(t)}createLeaderLine(t){var e,s;return{vertices:((e=t.vertices)==null?void 0:e.map(n=>this.createPoint(n)))??[],breakPointIndexes:t.breakPointIndexes?[...t.breakPointIndexes]:[],leaderLineIndex:t.leaderLineIndex,breaks:((s=t.breaks)==null?void 0:s.map(n=>({index:n.index,start:this.createPoint(n.start),end:this.createPoint(n.end)})))??[]}}cloneLeader(t){var e,s,n;return{lastLeaderLinePoint:(e=t.lastLeaderLinePoint)==null?void 0:e.clone(),lastLeaderLinePointSet:t.lastLeaderLinePointSet,landingPoint:(s=t.landingPoint)==null?void 0:s.clone(),doglegVector:(n=t.doglegVector)==null?void 0:n.clone(),doglegVectorSet:t.doglegVectorSet,doglegLength:t.doglegLength,breaks:t.breaks.map(r=>({index:r.index,start:r.start.clone(),end:r.end.clone()})),leaderBranchIndex:t.leaderBranchIndex,directionType:t.directionType,leaderLines:t.leaderLines.map(r=>({vertices:r.vertices.map(o=>o.clone()),breakPointIndexes:[...r.breakPointIndexes],leaderLineIndex:r.leaderLineIndex,breaks:r.breaks.map(o=>({index:o.index,start:o.start.clone(),end:o.end.clone()}))}))}}checkLeaderIndex(t){if(t<0||t>=this._leaders.length)throw new Error("The leader index is out of range!")}getMutableLeaderLine(t,e){this.checkLeaderIndex(t);const s=this._leaders[t].leaderLines[e];if(!s)throw new Error("The leader line index is out of range!");return s}collectGeometryPoints(){var e;const t=[];return this._leaders.forEach(s=>{s.lastLeaderLinePoint&&t.push(s.lastLeaderLinePoint),s.landingPoint&&t.push(s.landingPoint),s.breaks.forEach(r=>t.push(r.start,r.end)),s.leaderLines.forEach(r=>{t.push(...r.vertices),r.breaks.forEach(o=>t.push(o.start,o.end))});const n=this.getDoglegPoints(s);n&&t.push(...n),s.leaderLines.forEach(r=>{const o=this.getArrowheadPoints(this.getLeaderLineDrawPoints(s,r));o&&t.push(...o)})}),this._landingPoint&&t.push(this._landingPoint),this.contentBasePosition&&t.push(this.contentBasePosition),this.textAnchor&&t.push(this.textAnchor),this._mtextContent&&t.push(this._mtextContent.anchorPoint),(e=this._blockContent)!=null&&e.position&&t.push(this._blockContent.position),this.planeOrigin&&t.push(this.planeOrigin),t}getLeaderLineDrawPoints(t,e){if(e.vertices.length>=2)return e.vertices;if(e.vertices.length===0)return[];const s=t.lastLeaderLinePoint??t.landingPoint??this._landingPoint??this.contentBasePosition;return!s||e.vertices[0].equals(s)?e.vertices:[e.vertices[0],s]}getDoglegPoints(t){if(!this.getResolvedDoglegEnabled())return;const e=t.lastLeaderLinePoint??t.landingPoint??this._landingPoint,s=t.doglegVector??this._doglegVector,n=t.doglegLength??this.getResolvedDoglegLength();if(!e||n==null||n===0||s.lengthSq()===0)return;const r=e.clone().add(s.clone().normalize().multiplyScalar(n));return[e,r]}getArrowheadPoints(t){if(!this.isArrowheadVisible()||t.length<2)return;const e=this.getArrowheadFrame(t);if(!e)return;const s=this.getResolvedArrowheadSize(),{tip:n,unit:r}=e,o=n.clone().add(r.clone().multiplyScalar(s)),a=s/6,h=new _(-r.y,r.x,0),c=o.clone().add(h.clone().multiplyScalar(a)),d=o.clone().add(h.clone().multiplyScalar(-a));return[n,c,d,n]}isArrowheadVisible(){const t=this.getResolvedArrowheadId();return(t==null?void 0:t.toUpperCase())==="_NONE"?!1:this.getResolvedArrowheadSize()>0}drawLeaderLine(t,e){const s=[],n=this.getLeaderLinePointsForDraw(e);n.length>=2&&s.push(t.lines(n));const r=this.drawArrowhead(t,e);if(r&&s.push(r),s.length!==0)return s.length===1?s[0]:t.group(s)}getLeaderLinePointsForDraw(t){const e=this.getArrowheadLeaderLineTrimDistance();return e<=0?t:this.trimPolylineStart(t,e)}getArrowheadLeaderLineTrimDistance(){if(!this.isArrowheadVisible())return 0;const t=this.getResolvedArrowheadBlockTableRecord();if(!t)return 0;const e=this.getResolvedArrowheadSize();if(e<=0)return 0;const s=t.origin??w.ORIGIN;let n=s.x;for(const r of t.newIterator()){const o=r.geometricExtents;o.isEmpty()||o.max.x>n&&(n=o.max.x)}return Math.max(0,(n-s.x)*e)}trimPolylineStart(t,e){if(t.length<2||e<=0)return t;let s=e;for(let n=0;n<t.length-1;n++){const r=t[n],o=t[n+1],a=o.distanceTo(r);if(!(a<=0)){if(s<a){const h=new _().subVectors(o,r);return[r.clone().add(h.multiplyScalar(s/a)),...t.slice(n+1)]}s-=a}}return[t[t.length-1]]}drawArrowhead(t,e){if(!this.isArrowheadVisible())return;const s=this.drawArrowheadBlock(t,e);if(s)return s;const n=this.getArrowheadPoints(e);if(!n)return;const r=new Pe;r.add(new at(n,!0));const o=t.subEntityTraits,a=o.fillType;o.fillType={solidFill:!0,patternAngle:0,definitionLines:[]};const h=t.area(r);return o.fillType=a,h}drawArrowheadBlock(t,e){const s=this.getResolvedArrowheadBlockTableRecord();if(!s)return;const n=this.getArrowheadFrame(e);if(!n)return;const{tip:r,unit:o}=n,a=this.getResolvedArrowheadSize(),h=Math.atan2(o.y,o.x),c=s.origin??w.ORIGIN,d=new D().makeTranslation(-c.x,-c.y,-c.z),u=new D().makeScale(a,a,a),p=new D().makeRotationZ(h),g=new D().makeTranslation(r.x,r.y,r.z),m=new D().multiplyMatrices(g,p).multiply(u).multiply(d);return es.instance.draw(t,s,this.rgbColor,[],!0,m,new _(this.normal))}getArrowheadFrame(t){if(t.length<2)return;const e=t[0],s=t.find(r=>!r.equals(e));if(!s)return;const n=new _().subVectors(s,e);if(n.lengthSq()!==0)return{tip:e,unit:n.normalize()}}getResolvedArrowheadId(){var e;const t=(e=this.getMLeaderStyle())==null?void 0:e.arrowSymbolId;return this.arrowheadId??t}getResolvedArrowheadBlockTableRecord(){const t=this.getResolvedArrowheadId();if(t)return this.database.tables.blockTable.getIdAt(t)}getResolvedArrowheadSize(){const t=this.getMLeaderStyle(),e=(t==null?void 0:t.arrowSize)??(t==null?void 0:t.scale);return this.arrowheadSize??this.contentScale??e??this.getResolvedTextHeight()}getResolvedTextHeight(){var e;const t=(e=this.getMLeaderStyle())==null?void 0:e.textHeight;return this.textHeight>0?this.textHeight:t!=null&&t>0?t:2.5}getRenderableMTextContent(){var s;if(this._mtextContent)return{text:this._mtextContent.text,anchorPoint:this._mtextContent.anchorPoint};const t=(s=this.getMLeaderStyle())==null?void 0:s.defaultMTextContents,e=this.textAnchor??this.contentBasePosition??this._landingPoint;if(!(!t||!e))return{text:t,anchorPoint:e}}getMTextRenderWidth(t,e){if(this._textWidth>0)return this._textWidth;if(!t)return this._textWidth;const s=t.replace(/\\[PpNn]/g,`
4
+ `).replace(/\\[A-Za-z][^;]*;/g,"").replace(/[{}]/g,""),n=Math.max(...s.split(/\r\n|\r|\n/g).map(r=>r.length),1);return Math.max(e,n*e)}transformVector(t,e){const s=new w,n=new w(t.x,t.y,t.z);s.applyMatrix4(e),n.applyMatrix4(e),t.set(n.x-s.x,n.y-s.y,n.z-s.z)}getMLeaderStyle(){const t=this.database.objects.mleaderStyle,e=this.mleaderStyleId||this.leaderStyleId;if(e){const s=t.getIdAt(e);if(s)return s}return this.getDefaultMLeaderStyle()}getDefaultMLeaderStyle(){const t=this.resolveMLeaderStyleByName(this.getDefaultMLeaderStyleName());return t||this.database.objects.mleaderStyle.newIterator().toArray()[0]}resolveMLeaderStyleByName(t){const e=t==null?void 0:t.trim();if(!e)return;const s=this.database.objects.mleaderStyle,n=s.getAt(e);if(n)return n;const r=s.getIdAt(e);if(r)return r;const o=e.toUpperCase();for(const[a,h]of s.entries())if(a.toUpperCase()===o)return h}getDefaultMLeaderStyleName(){try{return this.database.cmleaderstyle||de}catch{return de}}getResolvedTextStyleName(){var r,o;const t=this.database.tables.textStyleTable,e=(r=this.getMLeaderStyle())==null?void 0:r.textStyleId,s=e?(o=t.getIdAt(e))==null?void 0:o.name:void 0;if(this.textStyleName)return this.textStyleName;const n=this.textStyleId?t.getIdAt(this.textStyleId):void 0;return n!=null&&n.name?n.name:s}getTextStyle(){const t=this.database.tables.textStyleTable,e=this.getResolvedTextStyleName(),s=(e?t.getAt(e):void 0)??t.getAt(this.database.textstyle)??t.getAt(Z);if(!s)throw new Error("No valid text style found in text style table.");return s.textStyle}getResolvedLeaderLineColor(){var t;return this.getResolvedComponentColor(this.leaderLineColor,(t=this.getMLeaderStyle())==null?void 0:t.leaderLineColor,vc)}getResolvedLeaderLineType(){var e;const t=(e=this.getMLeaderStyle())==null?void 0:e.leaderLineType;return this.getResolvedStyleDrivenValue(this.leaderLineType,t,kc)}getResolvedLeaderLineTypeId(){var t;return this.getResolvedStyleDrivenValue(this.leaderLineTypeId,(t=this.getMLeaderStyle())==null?void 0:t.leaderLineTypeId,Cc)}getResolvedLeaderLineStyle(){const t=this.getResolvedLeaderLineTypeId();if(!t)return;const e=this.database.tables.linetypeTable.getIdAt(t);if(e)return{type:"UserSpecified",...e.linetype}}getResolvedLeaderLineWeight(){var s;const t=(s=this.getMLeaderStyle())==null?void 0:s.leaderLineWeight,e=this.getResolvedStyleDrivenValue(this.leaderLineWeight,t,Oc);if(e!=null)return e}getResolvedDoglegEnabled(){var e;const t=(e=this.getMLeaderStyle())==null?void 0:e.doglegEnabled;return this.getResolvedStyleDrivenValue(this.doglegEnabled,t,Nc)}getResolvedDoglegLength(){var e;const t=(e=this.getMLeaderStyle())==null?void 0:e.doglegLength;return this.getResolvedStyleDrivenValue(this.doglegLength,t,Bc)}getResolvedTextColor(){var t;return this.getResolvedComponentColor(this.textColor,(t=this.getMLeaderStyle())==null?void 0:t.textColor,Rc)}getResolvedComponentColor(t,e,s){const n=t!=null?zs(t):void 0;if(!n)return e;const r=this.isPropertyOverrideEnabled(s);return r===!0?n:r===!1?e??n:!n.isByBlock&&!n.isByLayer?n:e??n}getResolvedStyleDrivenValue(t,e,s){const n=this.isPropertyOverrideEnabled(s);return n===!0?t??e:e??t}isPropertyOverrideEnabled(t){if(this.propertyOverrideFlag!=null)return(this.propertyOverrideFlag&t)!==0}applyColorTraits(t,e,s,n){t.color=s,t.rgbColor=n,e&&(t.color=e,t.rgbColor=this.resolveColorToRgb(e))}applyLineTraits(t,e,s){e&&(t.lineType=e),s!=null&&(t.lineWeight=s)}resolveColorToRgb(t){if(t.isByLayer){const e=this.getLayerColor();return(e==null?void 0:e.RGB)!=null?e.RGB:this.rgbColor}return t.isByBlock?this.rgbColor:t.RGB??this.rgbColor}};qr.typeName="MLeader";let Gi=qr;const Zr=class Zr extends lt{get dxfTypeName(){return"MTEXT"}constructor(){super(),this._contents="",this._height=0,this._width=0,this._lineSpacingFactor=.25,this._lineSpacingStyle=0,this._backgroundFill=!1,this._backgroundFillColor=13158600,this._backgroundFillTransparency=1,this._backgroundScaleFactor=1,this._rotation=0,this._styleName="",this._location=new w,this._attachmentPoint=ot.TopLeft,this._direction=new _(1,0,0),this._drawingDirection=Dt.LEFT_TO_RIGHT}get contents(){return this._contents}set contents(t){this._contents=t}get height(){return this._height}set height(t){this._height=t}get width(){return this._width}set width(t){this._width=t}get rotation(){return this._rotation}set rotation(t){this._rotation=t}get lineSpacingFactor(){return this._lineSpacingFactor}set lineSpacingFactor(t){this._lineSpacingFactor=t}get lineSpacingStyle(){return this._lineSpacingStyle}set lineSpacingStyle(t){this._lineSpacingStyle=t}get backgroundFill(){return this._backgroundFill}set backgroundFill(t){this._backgroundFill=t,this._backgroundFillColor=13158600}get backgroundFillColor(){return this._backgroundFillColor}set backgroundFillColor(t){this._backgroundFillColor=t}get backgroundFillTransparency(){return this._backgroundFillTransparency}set backgroundFillTransparency(t){this._backgroundFillTransparency=t}get backgroundScaleFactor(){return this._backgroundScaleFactor}set backgroundScaleFactor(t){this._backgroundScaleFactor=t}get styleName(){return this._styleName}set styleName(t){this._styleName=t}get location(){return this._location}set location(t){this._location.copy(t)}get attachmentPoint(){return this._attachmentPoint}set attachmentPoint(t){this._attachmentPoint=t}get direction(){return this._direction}set direction(t){this._direction.copy(t)}get drawingDirection(){return this._drawingDirection}set drawingDirection(t){this._drawingDirection=t}get geometricExtents(){return new N}subGetOsnapPoints(t,e,s,n){z.Insertion===t&&n.push(this._location)}transformBy(t){const e=this._location.clone(),s=this._direction.lengthSq()>0?this._direction.clone().normalize():new _(Math.cos(this._rotation),Math.sin(this._rotation),0),n=new _(-s.y,s.x,s.z);n.lengthSq()===0&&n.set(0,1,0),n.normalize();const r=e.clone().add(s),o=e.clone().add(n);e.applyMatrix4(t),r.applyMatrix4(t),o.applyMatrix4(t);const a=new _(r).sub(e),h=new _(o).sub(e),c=a.length(),d=h.length();return this._location.copy(e),c>0&&(this._direction.copy(a).normalize(),this._rotation=Math.atan2(this._direction.y,this._direction.x),this._width*=c),d>0&&(this._height*=d),this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"text",properties:[{name:"contents",type:"string",editable:!0,accessor:{get:()=>this.contents,set:t=>{this.contents=t}}},{name:"styleName",type:"string",editable:!0,accessor:{get:()=>this.styleName,set:t=>{this.styleName=t}}},{name:"attachmentPoint",type:"enum",editable:!0,options:[{label:ot[1],value:1},{label:ot[2],value:2},{label:ot[3],value:3},{label:ot[4],value:4},{label:ot[5],value:5},{label:ot[6],value:6},{label:ot[7],value:7},{label:ot[8],value:8},{label:ot[9],value:9}],accessor:{get:()=>this.attachmentPoint,set:t=>{this.attachmentPoint=t}}},{name:"drawingDirection",type:"enum",editable:!0,options:[{label:Dt[1],value:1},{label:Dt[2],value:2},{label:Dt[3],value:3},{label:Dt[4],value:4},{label:Dt[5],value:5}],accessor:{get:()=>this.drawingDirection,set:t=>{this.drawingDirection=t}}},{name:"textHeight",type:"float",editable:!0,accessor:{get:()=>this.height,set:t=>{this.height=t}}},{name:"rotation",type:"float",editable:!0,accessor:{get:()=>this.rotation,set:t=>{this.rotation=t}}},{name:"lineSpacingFactor",type:"float",editable:!0,accessor:{get:()=>this.lineSpacingFactor,set:t=>{this.lineSpacingFactor=t}}},{name:"definedWidth",type:"float",editable:!0,accessor:{get:()=>this.width,set:t=>{this.width=t}}},{name:"directionX",type:"float",editable:!0,accessor:{get:()=>this.direction.x,set:t=>{this.direction.x=t}}},{name:"directionY",type:"float",editable:!0,accessor:{get:()=>this.direction.y,set:t=>{this.direction.y=t}}},{name:"directionZ",type:"float",editable:!0,accessor:{get:()=>this.direction.z,set:t=>{this.direction.z=t}}}]},{groupName:"geometry",properties:[{name:"locationX",type:"float",editable:!0,accessor:{get:()=>this.location.x,set:t=>{this.location.x=t}}},{name:"locationY",type:"float",editable:!0,accessor:{get:()=>this.location.y,set:t=>{this.location.y=t}}},{name:"locationZ",type:"float",editable:!0,accessor:{get:()=>this.location.z,set:t=>{this.location.z=t}}}]}]}}getTextStyle(){const t=this.database.tables.textStyleTable,e=t.getAt(this.styleName)??t.getAt(this.database.textstyle)??t.getAt(Z);if(!e)throw new Error("No valid text style found in text style table.");return e.textStyle}subWorldDraw(t,e){const s={text:this.contents,height:this.height,width:this.width,position:this.location,rotation:this.rotation,directionVector:this.direction,attachmentPoint:this.attachmentPoint,drawingDirection:this.drawingDirection,lineSpaceFactor:this.lineSpacingFactor};return t.mtext(s,this.getTextStyle(),e)}encodeMTextContentsForDxf(t){return t.replace(/\r\n|\r|\n/g,"\\P")}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbMText"),t.writePoint3d(10,this.location),t.writeDouble(40,this.height),t.writeDouble(41,this.width),t.writeString(1,this.encodeMTextContentsForDxf(this.contents)),t.writeString(7,this.styleName),t.writeAngle(50,this.rotation),t.writeVector3d(11,this.direction),t.writeInt16(71,this.attachmentPoint),t.writeInt16(72,this.drawingDirection),t.writeInt16(73,this.lineSpacingStyle),t.writeDouble(44,this.lineSpacingFactor),this.backgroundFill&&(t.writeInt16(90,1),t.writeInt32(63,this.backgroundFillColor),t.writeInt32(441,this.backgroundFillTransparency),t.writeDouble(45,this.backgroundScaleFactor)),this}};Zr.typeName="MText";let Xs=Zr;const Kr=class Kr extends ht{get dxfTypeName(){return"SPLINE"}constructor(t,e,s,n,r){super(),this.rebuild(t,e,s,n,r)}rebuild(t,e,s,n,r){const o=+(t!==void 0)+ +(e!==void 0)+ +(s!==void 0)+ +(n!==void 0)+ +(r!==void 0);if(o<2||o>5)throw wt.ILLEGAL_PARAMETERS;!Array.isArray(e)?this._geo=new Ht(t,e,s,n):this._geo=new Ht(t,e,s,n,r)}get geometricExtents(){return this._geo.box}get closed(){return this._geo.closed}set closed(t){this._geo.closed=t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:n.push(this._geo.startPoint),n.push(this._geo.endPoint);break}}transformBy(t){return this._geo.transform(t),this}subWorldDraw(t){const e=this._geo.getPoints(100);return t.lines(e)}dxfOutFields(t){var s;const e=this._geo;super.dxfOutFields(t),t.writeSubclassMarker("AcDbSpline"),t.writeInt16(70,this.closed?1:0),t.writeInt16(71,e.degree),t.writeInt16(72,e.knots.length),t.writeInt16(73,e.controlPoints.length),t.writeInt16(74,((s=e.fitPoints)==null?void 0:s.length)??0);for(const n of e.knots)t.writeDouble(40,n);for(const n of e.weights)t.writeDouble(41,n);for(const n of e.controlPoints)t.writePoint3d(10,n);for(const n of e.fitPoints??[])t.writePoint3d(11,n);return this}};Kr.typeName="Spline";let $s=Kr;const Fc=new _,Qr=class Qr extends Je{get dxfTypeName(){return"ACAD_TABLE"}constructor(t,e,s){super(t),this._attachmentPoint=ot.TopLeft,this._numColumns=s,this._numRows=e,this._columnWidth=new Array(s),this._rowHeight=new Array(e),this._cells=new Array(e*s)}get attachmentPoint(){return this._attachmentPoint}set attachmentPoint(t){this._attachmentPoint=t}get numRows(){return this._numRows}set numRows(t){this._numRows=t}get numColumns(){return this._numColumns}set numColumns(t){this._numColumns=t}numContents(t,e){return 1}rowHeight(t){return this._rowHeight[t]}setRowHeight(t,e){this._rowHeight[t]=e}setUniformRowHeight(t){this._rowHeight.fill(t)}columnWidth(t){return this._columnWidth[t]}setUniformColumnWidth(t){this._columnWidth.fill(t)}setColumnWidth(t,e){this._columnWidth[t]=e}cell(t){if(!(t<0||t>=this._cells.length))return this._cells[t]}setCell(t,e){this._cells[t]=e}textString(t,e,s){var r;const n=t*this._numColumns+e;return(r=this._cells[n])==null?void 0:r.text}setTextString(t,e,s){const n=t*this._numColumns+e;if(!this._cells[n]){this._cells[n]={text:s,attachmentPoint:this._attachmentPoint,cellType:1,textHeight:0};return}this._cells[n].text=s}isEmpty(t,e){var n;const s=t*this._numColumns+e;return!((n=this._cells[s])!=null&&n.text)}get geometricExtents(){return new N}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"table",properties:[{name:"numRows",type:"string",editable:!0,accessor:{get:()=>this.numRows,set:t=>{this.numRows=t}}},{name:"numColumns",type:"float",editable:!0,accessor:{get:()=>this.numColumns,set:t=>{this.numColumns=t}}},{name:"tableWidth",type:"float",editable:!1,accessor:{get:()=>this._columnWidth.reduce((t,e)=>t+e,0)}},{name:"tableHeight",type:"float",editable:!1,accessor:{get:()=>this._rowHeight.reduce((t,e)=>t+e,0)}}]},{groupName:"geometry",properties:[{name:"positionX",type:"float",editable:!0,accessor:{get:()=>this.position.x,set:t=>{this.position.x=t}}},{name:"positionY",type:"float",editable:!0,accessor:{get:()=>this.position.y,set:t=>{this.position.y=t}}},{name:"positionZ",type:"float",editable:!0,accessor:{get:()=>this.position.z,set:t=>{this.position.z=t}}}]}]}}subWorldDraw(t){const e=this.blockTableRecord;if(!this.hasRenderableCellContent()&&e&&e.newIterator().count>0){const g=this.drawAnonymousTableBlock(t,e);if(g)return g}let s=0,n=0;const r=new Uint16Array(this.numColumns*this.numRows*8),o=new Float32Array((this.numColumns+1)*(this.numRows+1)*3);let a=0;for(let g=0;g<=this.numRows;g++){s-=g>0?this.rowHeight(g-1):0,n=0;for(let m=0;m<=this.numColumns;m++)n+=m>0?this.columnWidth(m-1):0,o[a++]=n,o[a++]=s,o[a++]=0}const h=[],c=new Array(this.numRows*this.numColumns).fill(!1);n=0,a=0;let d=0;for(let g=0;g<this.numColumns;g++){n+=g>0?this.columnWidth(g-1):0,s=0;for(let m=0;m<this.numRows;m++){s+=m>0?this.rowHeight(m-1):0;const y=this.cell(m*this.numColumns+g);if(d=m*this.numColumns+g,y&&!c[d]){const b=y.borderWidth??1,x=y.borderHeight??1;this.fillVisited(c,d,this.numColumns,b,x),r[a++]=g+m*(this.numColumns+1),r[a++]=g+m*(this.numColumns+1)+b;const I=o[r[a-1]*3]-n,S=g+(m+x)*(this.numColumns+1)+b;g+b==this.numColumns&&(r[a++]=g+m*(this.numColumns+1)+b,r[a++]=S);const L=-o[S*3+1]-s;if(m+x==this.numRows&&(r[a++]=g+(m+x)*(this.numColumns+1)+x,r[a++]=g+(m+x)*(this.numColumns+1)),r[a++]=g+(m+x)*(this.numColumns+1),r[a++]=g+m*(this.numColumns+1),y.text){const A=y.attachmentPoint||this.attachmentPoint||ot.MiddleCenter,H=this.getTableTextOffset(A,I,L),M={text:y.text,height:this.getCellTextHeight(y,L),width:I,position:Fc.set(n,-s,0).clone().add(H),rotation:this.rotation,attachmentPoint:A},X=this.getTextStyle(y);h.push(t.mtext(M,X))}}}}h.push(t.lineSegments(o,3,r));const u=t.group(h),p=new ss;return p.setFromAxisAngle(_.Z_AXIS,this.rotation),yi.compose(this.position,p,this.scaleFactors),u.applyMatrix(yi),u}hasRenderableCellContent(){return this._cells.some(t=>!!t&&(!!t.text||!!t.blockTableRecordId))}drawAnonymousTableBlock(t,e){const s=[],n=e.newIterator();for(const a of n){let h;a.color.isByBlock&&this.rgbColor?(Co.copy(a.color),a.color.setRGBValue(this.rgbColor),h=a.worldDraw(t),a.color.copy(Co)):h=a.worldDraw(t),h&&(h.objectId=this.objectId,h.ownerId=this.ownerId,h.layerName=this.layer,h.visible=this.visibility&&a.visibility,s.push(h))}const r=t.group(s);r.applyMatrix(this.blockTransform);const o=this.normal;return o&&(o.x!==0||o.y!==0||o.z!==1)&&(yi.setFromExtrusionDirection(o),r.applyMatrix(yi)),r}fillVisited(t,e,s,n,r){if(r==1&&n==1)t[e]=!0;else for(let o=0;o<n;++o)for(let a=0;a<r;++a)t[e+o+a*s]=!0}getTextStyle(t){const e=this.database.tables.textStyleTable,s=(t.textStyle?e.getAt(t.textStyle):void 0)??e.getAt(this.database.textstyle)??e.getAt(Z);if(!s)throw new Error("No valid text style found in text style table.");return s.textStyle}getTableTextOffset(t,e,s){const n=new _;switch(t){case 1:break;case 2:n.setX(e/2);break;case 3:n.setX(e);break;case 4:n.setY(-s/2);break;case 5:n.set(e/2,-s/2,0);break;case 6:n.set(e,-s/2,0);break;case 7:n.setY(-s);break;case 8:n.set(e/2,-s,0);break;case 9:n.set(e,-s,0);break}return n}getCellTextHeight(t,e){return t.textHeight&&t.textHeight>0?t.textHeight:Math.max(e/2,1)}dxfOutFields(t){var r,o,a,h,c,d,u;super.dxfOutFields(t),t.writeSubclassMarker("AcDbTable");const e=t.version??((r=t.database)==null?void 0:r.version)??((o=this.database)==null?void 0:o.version),s=(e==null?void 0:e.value)!=null?e.value>=27:!1;t.writeInt16(280,this.tableDataVersion),t.writeObjectId(342,this.tableStyleId),t.writeObjectId(343,this.owningBlockRecordId),t.writeVector3d(11,this.horizontalDirection),t.writeUInt32(90,this.tableValueFlag),t.writeUInt32(93,this.tableOverrideFlag),t.writeUInt32(94,this.borderColorOverrideFlag),t.writeUInt32(95,this.borderLineweightOverrideFlag),t.writeUInt32(96,this.borderVisibilityOverrideFlag),t.writeInt16(71,this.attachmentPoint),t.writeInt32(91,this.numRows),t.writeInt32(92,this.numColumns);for(let p=0;p<this.numRows;++p)t.writeDouble(141,this.rowHeight(p));for(let p=0;p<this.numColumns;++p)t.writeDouble(142,this.columnWidth(p));const n=this._cells.length>0?this._cells.length:this.numRows*this.numColumns;for(let p=0;p<n;p++){const g=this._cells[p],m=(g==null?void 0:g.cellType)??(g!=null&&g.blockTableRecordId?2:1);if(t.writeInt16(171,m),t.writeInt16(172,(g==null?void 0:g.flagValue)??0),t.writeInt16(173,(g==null?void 0:g.mergedValue)??0),t.writeBoolean(174,g==null?void 0:g.autoFit),t.writeInt16(175,g==null?void 0:g.borderWidth),t.writeInt16(176,g==null?void 0:g.borderHeight),(g==null?void 0:g.overrideFlag)!=null&&(s?t.writeInt32(91,g.overrideFlag):t.writeInt16(177,g.overrideFlag)),t.writeInt16(178,g==null?void 0:g.virtualEdgeFlag),t.writeAngle(145,g==null?void 0:g.rotation),s&&t.writeInt16(92,g==null?void 0:g.extendedCellFlags),m===1)g!=null&&g.fieldObjetId?t.writeObjectId(344,g.fieldObjetId):this.writeCellText(t,(g==null?void 0:g.text)??"",s,g==null?void 0:g.cellValueBlockBegin);else if(m===2){if(t.writeObjectId(340,g==null?void 0:g.blockTableRecordId),t.writeDouble(144,g==null?void 0:g.blockScale),t.writeInt16(179,g==null?void 0:g.blockAttrNum),(a=g==null?void 0:g.attrDefineId)!=null&&a.length)for(const y of g.attrDefineId)t.writeObjectId(331,y);if((g==null?void 0:g.attrText)!=null)if(Array.isArray(g.attrText))for(const y of g.attrText)t.writeString(300,y);else t.writeString(300,g.attrText)}g!=null&&g.textStyle&&t.writeString(7,g.textStyle),(g==null?void 0:g.textHeight)!=null&&t.writeDouble(140,g.textHeight),(g==null?void 0:g.attachmentPoint)!=null&&t.writeInt16(170,g.attachmentPoint),(g==null?void 0:g.topBorderVisibility)!=null&&t.writeInt16(289,g.topBorderVisibility?1:0),(g==null?void 0:g.rightBorderVisibility)!=null&&t.writeInt16(285,g.rightBorderVisibility?1:0),(g==null?void 0:g.bottomBorderVisibility)!=null&&t.writeInt16(286,g.bottomBorderVisibility?1:0),(g==null?void 0:g.leftBorderVisibility)!=null&&t.writeInt16(288,g.leftBorderVisibility?1:0)}if(t.writeInt16(70,this.flowDirection),t.writeDouble(40,this.horizontalCellMargin),t.writeDouble(41,this.verticalCellMargin),this.suppressTitle!=null&&t.writeInt16(280,this.suppressTitle?1:0),this.suppressHeader!=null&&t.writeInt16(281,this.suppressHeader?1:0),(h=this.cellTypeOverrides)!=null&&h.length)for(const p of this.cellTypeOverrides){t.writeString(7,p.textStyle),t.writeDouble(140,p.textHeight),t.writeInt16(170,p.alignment),t.writeInt16(63,p.backgroundColor),t.writeInt16(64,p.contentColor),p.backgroundColorEnabled!=null&&t.writeInt16(283,p.backgroundColorEnabled?1:0);const g=p.borderLineweights;g&&(t.writeInt16(274,g.top),t.writeInt16(275,g.right),t.writeInt16(276,g.bottom),t.writeInt16(277,g.left),t.writeInt16(278,g.insideHorizontal),t.writeInt16(279,g.insideVertical));const m=p.borderVisibility;m&&(t.writeInt16(284,m.top?1:0),t.writeInt16(285,m.right?1:0),t.writeInt16(286,m.bottom?1:0),t.writeInt16(287,m.left?1:0),t.writeInt16(288,m.insideHorizontal?1:0),t.writeInt16(289,m.insideVertical?1:0))}if(this.tableBorderColors&&(t.writeInt16(63,this.tableBorderColors.left),t.writeInt16(64,this.tableBorderColors.top),t.writeInt16(65,this.tableBorderColors.insideHorizontal),t.writeInt16(66,this.tableBorderColors.bottom),t.writeInt16(68,this.tableBorderColors.insideVertical),t.writeInt16(69,this.tableBorderColors.right)),(c=this.rowDataTypes)!=null&&c.length)for(const p of this.rowDataTypes)t.writeInt16(97,p);if((d=this.rowUnitTypes)!=null&&d.length)for(const p of this.rowUnitTypes)t.writeInt16(98,p);if((u=this.rowFormats)!=null&&u.length)for(const p of this.rowFormats)t.writeString(4,p);return this}writeCellText(t,e,s,n){if(!s){if(e.length<=250){t.writeString(1,e);return}const a=Math.ceil(e.length/250);for(let h=0;h<a;h++){const c=h*250,d=c+250,u=e.slice(c,d);h===a-1?t.writeString(1,u):t.writeString(2,u)}return}if(t.writeString(301,n??"CELL_VALUE"),e.length<=250){t.writeString(302,e),t.writeString(304,"ACVALUE_END");return}const o=Math.ceil(e.length/250);for(let a=0;a<o;a++){const h=a*250,c=h+250,d=e.slice(h,c);a===o-1?t.writeString(302,d):t.writeString(303,d)}t.writeString(304,"ACVALUE_END")}};Qr.typeName="Table";let Ui=Qr;const yi=new D,Co=new j,Jr=class Jr extends ht{get dxfTypeName(){return"TRACE"}constructor(){super(),this._elevation=0,this._thickness=1,this._vertices=[new w,new w,new w,new w]}get elevation(){return this._elevation}set elevation(t){this._elevation=t}get closed(){return!0}get thickness(){return this._thickness}set thickness(t){this._thickness=t}getPointAt(t){return t<0?this._vertices[0]:t>3?this._vertices[3]:this._vertices[t]}setPointAt(t,e){if(t<0&&this._vertices[0].copy(e),t>3)return this._vertices[3].copy(e);this._vertices[t].copy(e)}get geometricExtents(){return new N().setFromPoints(this._vertices)}subGetGripPoints(){const t=new Array;return t.push(...this._vertices),t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:n.push(...this._vertices);break}}transformBy(t){return this._vertices.forEach(e=>e.applyMatrix4(t)),this._elevation=this._vertices[0].z,this}subWorldDraw(t){const e=new at(this._vertices,!0),s=new Pe;s.add(e);const n=t.subEntityTraits;return n.fillType={solidFill:!0,patternAngle:0,definitionLines:[]},t.area(s)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbTrace"),t.writeDouble(38,this.elevation),t.writeDouble(39,this.thickness),t.writePoint3d(10,this.getPointAt(0)),t.writePoint3d(11,this.getPointAt(1)),t.writePoint3d(12,this.getPointAt(2)),t.writePoint3d(13,this.getPointAt(3)),this}};Jr.typeName="Trace";let Yi=Jr;const to=class to extends ht{get dxfTypeName(){return"LWPOLYLINE"}constructor(){super(),this._elevation=0,this._geo=new at}get numberOfVertices(){return this._geo.numberOfVertices}get elevation(){return this._elevation}set elevation(t){this._elevation=t}get closed(){return this._geo.closed}set closed(t){this._geo.closed=t}addVertexAt(t,e,s=0,n=-1,r=-1){const o=n<0?void 0:n,a=r<0?void 0:r,h={x:e.x,y:e.y,bulge:s,startWidth:o,endWidth:a};this._geo.addVertexAt(t,h)}removeVertexAt(t){this._geo.removeVertexAt(t)}reset(t,e){this._geo.reset(t,e)}getPoint2dAt(t){return this._geo.getPointAt(t)}getPoint3dAt(t){const e=this.getPoint2dAt(t);return new w(e.x,e.y,this._elevation)}get geometricExtents(){const t=this._geo.box;return new N({x:t.min.x,y:t.min.y,z:this._elevation},{x:t.max.x,y:t.max.y,z:this._elevation})}subGetGripPoints(){const t=new Array;for(let e=0;e<this.numberOfVertices;++e)t.push(this.getPoint3dAt(e));return t}subGetOsnapPoints(t,e,s,n){const r=new Array;for(let o=0;o<this.numberOfVertices;++o)r.push(this.getPoint3dAt(o));switch(t){case z.EndPoint:n.push(...r);break}}transformBy(t){const e=t.determinant()<0;let s=this._elevation;return this._geo.vertices.forEach(n=>{const r=new w(n.x,n.y,this._elevation).applyMatrix4(t);n.x=r.x,n.y=r.y,s=r.z,e&&n.bulge!=null&&(n.bulge=-n.bulge)}),this._elevation=s,this._geo._boundingBoxNeedsUpdate=!0,this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"vertices",type:"array",editable:!1,itemSchema:{properties:[{name:"x",type:"float",editable:!0},{name:"y",type:"float",editable:!0}]},accessor:{get:()=>this._geo.vertices}},{name:"elevation",type:"float",editable:!0,accessor:{get:()=>this.elevation,set:t=>{this.elevation=t}}},{name:"length",type:"float",editable:!1,accessor:{get:()=>this._geo.length}}]},{groupName:"others",properties:[{name:"closed",type:"float",editable:!0,accessor:{get:()=>this.closed,set:t=>{this.closed=t}}}]}]}}subWorldDraw(t){const e=this._geo.getPoints(100),s=this.createWidthProfile();if(s!=null){const r=zc(s,this.closed);if(r!=null){const o=t.subEntityTraits;return o.fillType={solidFill:!0,patternAngle:0,definitionLines:[]},t.area(r)}}const n=[];return e.forEach(r=>n.push(new w().set(r.x,r.y,this.elevation))),t.lines(n)}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbPolyline"),t.writeInt32(90,this.numberOfVertices),t.writeInt16(70,this.closed?1:0),t.writeDouble(38,this.elevation);for(let e=0;e<this.numberOfVertices;++e)t.writePoint2d(10,this.getPoint2dAt(e));return this}createWidthProfile(){const t=this._geo.vertices,e=t.length;if(e<2)return null;const s=this.closed?e:e-1,n=[];let r=!1;for(let o=0;o<s;o++){const a=t[o],h=t[(o+1)%e],c=Math.max(0,a.startWidth??0),d=Math.max(0,a.endWidth??0);(c>Mt||d>Mt)&&(r=!0);const u=this.sampleSegment(a,h),p=u.length-1;for(let g=0;g<=p;g++){if(g===0&&n.length>0||this.closed&&o===s-1&&g===p)continue;const m=p>0?g/p:0;n.push({x:u[g].x,y:u[g].y,width:Wc(c,d,m)})}}return r&&n.length>=2?n:null}sampleSegment(t,e){if(t.bulge&&Math.abs(t.bulge)>Mt){const n=new Te(t,e,t.bulge).getPoints(32);if(n.length>1)return n.map(r=>new v(r.x,r.y))}return[new v(t.x,t.y),new v(e.x,e.y)]}};to.typeName="Polyline";let Xi=to;const Mt=1e-6,Oo=4;function zc(i,t){if(i.length<2)return null;const e=Dc(i,t);if(e.length<2)return null;const{left:s,right:n}=Vc(e,t);if(s.length<2||n.length<2)return null;const r=new Pe;if(t){if(!Pn(s)||!Pn(n))return null;const a=Math.abs($n(s)),h=Math.abs($n(n)),[c,d]=a>=h?[s,n]:[n,s];return r.add(new at(c,!0)),r.add(new at(d,!0)),r}const o=[...s,...n.reverse()];return Pn(o)?(r.add(new at(o,!0)),r):null}function Vc(i,t){const e=[],s=[];for(let n=0;n<i.length;n++){const r=i[n],o=Math.max(0,r.width)/2;if(o<=Mt)continue;const a=jc(i,n,t);a!=null&&(e.push({x:r.x+a.x*o,y:r.y+a.y*o}),s.push({x:r.x-a.x*o,y:r.y-a.y*o}))}return{left:e,right:s}}function Dc(i,t){const e=[];if(i.forEach(s=>{const n=e[e.length-1];(!n||Math.abs(n.x-s.x)>Mt||Math.abs(n.y-s.y)>Mt||Math.abs(n.width-s.width)>Mt)&&e.push(s)}),t&&e.length>1){const s=e[0],n=e[e.length-1];Math.abs(s.x-n.x)<=Mt&&Math.abs(s.y-n.y)<=Mt&&e.pop()}return e}function jc(i,t,e){const s=i.length,n=i[t],r=i[(t-1+s)%s],o=i[(t+1)%s];let a=No(n.x-r.x,n.y-r.y),h=No(o.x-n.x,o.y-n.y);if(e||(t===0&&(a=h),t===s-1&&(h=a)),a==null&&h==null)return null;if(a==null)return _i(h);if(h==null)return _i(a);const c=_i(a),d=_i(h),u=c.x+d.x,p=c.y+d.y,g=Math.hypot(u,p);if(g<=Mt)return d;const m={x:u/g,y:p/g},y=Math.abs(m.x*d.x+m.y*d.y),b=y<=Mt?Oo:Math.min(1/y,Oo);return{x:m.x*b,y:m.y*b}}function No(i,t){const e=Math.hypot(i,t);return e<=Mt?null:{x:i/e,y:t/e}}function _i(i){return{x:-i.y,y:i.x}}function $n(i){let t=0;const e=i.length;for(let s=0;s<e;s++){const n=i[s],r=i[(s+1)%e];t+=n.x*r.y-r.x*n.y}return t/2}function Pn(i){return i.length>=3&&Math.abs($n(i))>Mt}function Wc(i,t,e){return i+(t-i)*e}const eo=class eo extends lt{get dxfTypeName(){return"POINT"}constructor(){super(),this._geo=new w}get position(){return this._geo}set position(t){this._geo.set(t.x,t.y,t.z||0)}get geometricExtents(){return new N().expandByPoint(this._geo)}subGetOsnapPoints(t,e,s,n){z.Node===t&&n.push(this._geo)}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"positionX",type:"float",editable:!0,accessor:{get:()=>this.position.x,set:t=>{this.position.x=t}}},{name:"positionY",type:"float",editable:!0,accessor:{get:()=>this.position.y,set:t=>{this.position.y=t}}},{name:"positionZ",type:"float",editable:!0,accessor:{get:()=>this.position.z,set:t=>{this.position.z=t}}}]}]}}transformBy(t){return this._geo.applyMatrix4(t),this}subWorldDraw(t){return t.point(this._geo,{displayMode:this.database.pdmode,displaySize:this.database.pdsize})}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbPoint"),t.writePoint3d(10,this.position),this}};eo.typeName="Point";let $i=eo;var tl=(i=>(i[i.Invalid=0]="Invalid",i[i.Rect=1]="Rect",i[i.Poly=2]="Poly",i))(tl||{}),el=(i=>(i[i.Show=1]="Show",i[i.ShowUnAligned=2]="ShowUnAligned",i[i.Clip=4]="Clip",i[i.Transparent=8]="Transparent",i))(el||{});const so=class so extends lt{get dxfTypeName(){return"IMAGE"}constructor(){super(),this._brightness=50,this._contrast=50,this._fade=0,this._width=0,this._height=0,this._position=new w,this._scale=new $(1,1),this._rotation=0,this._imageSize=new v,this._clipBoundaryType=1,this._clipBoundary=[],this._isClipped=!1,this._isShownClipped=!1,this._isImageShown=!0,this._isImageTransparent=!1,this._imageDefId=""}get brightness(){return this._brightness}set brightness(t){this._brightness=t}get contrast(){return this._contrast}set contrast(t){this._contrast=t}get fade(){return this._fade}set fade(t){this._fade=t}get height(){return this._height}set height(t){this._height=t}get width(){return this._width}set width(t){this._width=t}get position(){return this._position}set position(t){this._position=t}get rotation(){return this._rotation}set rotation(t){this._rotation=t}get scale(){return this._scale}set scale(t){this._scale.copy(t)}get imageSize(){return this._imageSize}set imageSize(t){this._imageSize.copy(t)}get clipBoundaryType(){return this._clipBoundaryType}set clipBoundaryType(t){this._clipBoundaryType=t}get clipBoundary(){return this._clipBoundary}set clipBoundary(t){this._clipBoundary=[],this._clipBoundary.push(...t)}get isClipped(){return this._isClipped}set isClipped(t){this._isClipped=t}get isShownClipped(){return this._isShownClipped}set isShownClipped(t){this._isShownClipped=t}get isImageShown(){return this._isImageShown}set isImageShown(t){this._isImageShown=t}get isImageTransparent(){return this._isImageTransparent}set isImageTransparent(t){this._isImageTransparent=t}get image(){return this._image}set image(t){this._image=t}get imageDefId(){return this._imageDefId}set imageDefId(t){this._imageDefId=t}get imageFileName(){if(this._imageDefId){const t=this.database.objects.imageDefinition.getIdAt(this._imageDefId);if(t)return t.sourceFileName}return""}get geometricExtents(){const t=new N;return t.min.copy(this._position),t.max.set(this._position.x+this._width,this._position.y+this._height,0),t}subGetGripPoints(){return this.boundaryPath()}subWorldDraw(t){const e=this.boundaryPath();return this._image?t.image(this._image,{boundary:e,roation:this._rotation}):t.lines(e)}transformBy(t){const e=this._width*this._scale.x,s=this._height*this._scale.y,n=new _(e*Math.cos(this._rotation),e*Math.sin(this._rotation),0),r=new _(-s*Math.sin(this._rotation),s*Math.cos(this._rotation),0),o=this._position.clone(),a=this._position.clone().add(n),h=this._position.clone().add(r);o.applyMatrix4(t),a.applyMatrix4(t),h.applyMatrix4(t);const c=new _(a).sub(o),d=new _(h).sub(o);return this._position.copy(o),this._rotation=Math.atan2(c.y,c.x),this._width=c.length(),this._height=d.length(),this._scale.set(1,1),this}boundaryPath(){const t=[];if(this.isClipped&&this._clipBoundary.length>3){const e=this._width,s=this._height,n=new _t;n.setFromPoints(this._clipBoundary);const r=new v;r.setX(this._position.x-n.min.x*e),r.setY(this._position.y-n.min.y*s),this._clipBoundary.forEach(o=>{const a=o.x*e+r.x,h=o.y*s+r.y;t.push(new w(a,h,this._position.z))})}else{if(t.push(this._position),t.push(this._position.clone().setX(this._position.x+this._width)),t.push(this._position.clone().set(this._position.x+this._width,this._position.y+this._height,this._position.z)),t.push(this._position.clone().setY(this._position.y+this._height)),this._rotation>0){Bo.copy(t[1]);for(let e=1;e<4;e++)xi.copy(t[e]),xi.rotateAround(Bo,this._rotation),t[e].setX(xi.x),t[e].setY(xi.y)}t.push(t[0])}return t}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbRasterImage"),t.writePoint3d(10,this.position);const e=this.width*this.scale.x,s=this.height*this.scale.y,n=this._imageSize.x>0&&this._imageSize.y>0?this._imageSize:{x:e,y:s},r=n.x>0?e/n.x:e,o=n.y>0?s/n.y:s,a=Math.cos(this._rotation),h=Math.sin(this._rotation);t.writePoint3d(11,{x:r*a,y:r*h,z:0}),t.writePoint3d(12,{x:-o*h,y:o*a,z:0}),t.writePoint2d(13,n),t.writeObjectId(340,this.imageDefId);const c=(this.isImageShown?1:0)|(this.isShownClipped?4:0)|(this.isImageTransparent?8:0);if(t.writeInt16(70,c),t.writeInt16(280,this.isClipped?1:0),t.writeInt16(281,this.brightness),t.writeInt16(282,this.contrast),t.writeInt16(283,this.fade),t.writeInt16(71,this.clipBoundaryType),this.isClipped){t.writeInt16(91,this.clipBoundary.length);for(const d of this.clipBoundary)t.writePoint2d(14,d)}return this}};so.typeName="RasterImage";let qs=so;const Bo=new v,xi=new v,io=class io extends ht{get dxfTypeName(){return"RAY"}constructor(){super(),this._basePoint=new w,this._unitDir=new _}get basePoint(){return this._basePoint}set basePoint(t){this._basePoint.copy(t)}get unitDir(){return this._unitDir}set unitDir(t){this._unitDir.copy(t)}get closed(){return!1}get geometricExtents(){const t=new N;return t.expandByPoint(this._unitDir.clone().multiplyScalar(10).add(this._basePoint)),t.expandByPoint(this._unitDir.clone().multiplyScalar(-10).add(this._basePoint)),t}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"basePointX",type:"float",editable:!0,accessor:{get:()=>this.basePoint.x,set:t=>{this.basePoint.x=t}}},{name:"basePointY",type:"float",editable:!0,accessor:{get:()=>this.basePoint.y,set:t=>{this.basePoint.y=t}}},{name:"basePointZ",type:"float",editable:!0,accessor:{get:()=>this.basePoint.z,set:t=>{this.basePoint.z=t}}},{name:"unitDirX",type:"float",editable:!0,accessor:{get:()=>this.unitDir.x,set:t=>{this.unitDir.x=t}}},{name:"unitDirY",type:"float",editable:!0,accessor:{get:()=>this.unitDir.y,set:t=>{this.unitDir.y=t}}},{name:"unitDirZ",type:"float",editable:!0,accessor:{get:()=>this.unitDir.z,set:t=>{this.unitDir.z=t}}}]}]}}subGetGripPoints(){const t=new Array;return t.push(this.basePoint),t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:n.push(this.basePoint);break}}transformBy(t){return this._basePoint.applyMatrix4(t),this._unitDir.transformDirection(t),this}subWorldDraw(t){const e=[];return e.push(this.basePoint),e.push(this._unitDir.clone().multiplyScalar(1e6).add(this._basePoint)),t.lines(e)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbRay"),t.writePoint3d(10,this.basePoint),t.writeVector3d(11,this.unitDir),this}};io.typeName="Ray";let qi=io;const no=class no extends lt{get dxfTypeName(){return"VIEWPORT"}constructor(){super(),this._centerPoint=new w,this._height=0,this._width=0,this._viewCenter=new w,this._viewHeight=0,this._number=-1}get number(){return this._number}set number(t){this._number=t}get centerPoint(){return this._centerPoint}set centerPoint(t){this._centerPoint=t}get height(){return this._height}set height(t){this._height=t}get width(){return this._width}set width(t){this._width=t}get viewCenter(){return this._viewCenter}set viewCenter(t){this._viewCenter=t}get viewHeight(){return this._viewHeight}set viewHeight(t){this._viewHeight=t}get geometricExtents(){return new N}transformBy(t){const e=this._centerPoint.clone(),s=this._centerPoint.clone().add(new _(this._width,0,0)),n=this._centerPoint.clone().add(new _(0,this._height,0));e.applyMatrix4(t),s.applyMatrix4(t),n.applyMatrix4(t);const r=new _(s).sub(e),o=new _(n).sub(e),a=this._height!==0?o.length()/this._height:1;return this._centerPoint.copy(e),this._width=r.length(),this._height=o.length(),this._viewHeight*=a,this}subWorldDraw(t){if(this._number>1&&this.ownerId!=this.database.tables.blockTable.modelSpace.objectId){const e=this.toGiViewport();return t.group(this.createViewportRect(e,t))}}toGiViewport(){const t=new ja;return t.id=this.objectId,t.groupId=this.ownerId,t.number=this.number,t.centerPoint=this.centerPoint,t.width=this.width,t.height=this.height,t.viewHeight=this.viewHeight,t.viewCenter=this.viewCenter,t}createViewportRect(t,e){const s=[];return s.push(e.lines([new w(t.centerPoint.x-t.width/2,t.centerPoint.y-t.height/2,0),new w(t.centerPoint.x+t.width/2,t.centerPoint.y-t.height/2,0)])),s.push(e.lines([new w(t.centerPoint.x+t.width/2,t.centerPoint.y-t.height/2,0),new w(t.centerPoint.x+t.width/2,t.centerPoint.y+t.height/2,0)])),s.push(e.lines([new w(t.centerPoint.x+t.width/2,t.centerPoint.y+t.height/2,0),new w(t.centerPoint.x-t.width/2,t.centerPoint.y+t.height/2,0)])),s.push(e.lines([new w(t.centerPoint.x-t.width/2,t.centerPoint.y+t.height/2,0),new w(t.centerPoint.x-t.width/2,t.centerPoint.y-t.height/2,0)])),s}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbViewport"),t.writePoint3d(10,this.centerPoint),t.writeDouble(40,this.height),t.writeDouble(41,this.width),t.writePoint3d(12,this.viewCenter),t.writeDouble(45,this.viewHeight),t.writeInt32(69,this.number),this}};no.typeName="Viewport";let Zi=no;const ro=class ro extends qs{get dxfTypeName(){return"WIPEOUT"}subWorldDraw(t){const e=this.boundaryPath(),s=new Pe;return s.add(new at(e)),t.area(s)}dxfOutFields(t){return super.dxfOutFields(t),this}};ro.typeName="Wipeout";let Ki=ro;const oo=class oo extends ht{get dxfTypeName(){return"XLINE"}constructor(){super(),this._basePoint=new w,this._unitDir=new _}get basePoint(){return this._basePoint}set basePoint(t){this._basePoint.copy(t)}get unitDir(){return this._unitDir}set unitDir(t){this._unitDir.copy(t)}get closed(){return!1}get geometricExtents(){const t=new N;return t.expandByPoint(this._unitDir.clone().multiplyScalar(10).add(this._basePoint)),t.expandByPoint(this._unitDir.clone().multiplyScalar(-10).add(this._basePoint)),t}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"basePointX",type:"float",editable:!0,accessor:{get:()=>this.basePoint.x,set:t=>{this.basePoint.x=t}}},{name:"basePointY",type:"float",editable:!0,accessor:{get:()=>this.basePoint.y,set:t=>{this.basePoint.y=t}}},{name:"basePointZ",type:"float",editable:!0,accessor:{get:()=>this.basePoint.z,set:t=>{this.basePoint.z=t}}},{name:"unitDirX",type:"float",editable:!0,accessor:{get:()=>this.unitDir.x,set:t=>{this.unitDir.x=t}}},{name:"unitDirY",type:"float",editable:!0,accessor:{get:()=>this.unitDir.y,set:t=>{this.unitDir.y=t}}},{name:"unitDirZ",type:"float",editable:!0,accessor:{get:()=>this.unitDir.z,set:t=>{this.unitDir.z=t}}}]}]}}subGetGripPoints(){const t=new Array;return t.push(this.basePoint),t}transformBy(t){return this._basePoint.applyMatrix4(t),this._unitDir.transformDirection(t),this}subWorldDraw(t){const e=[];return e.push(this._unitDir.clone().multiplyScalar(-1e6).add(this._basePoint)),e.push(this._unitDir.clone().multiplyScalar(1e6).add(this._basePoint)),t.lines(e)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbXline"),t.writePoint3d(10,this.basePoint),t.writeVector3d(11,this.unitDir),this}};oo.typeName="Xline";let Qi=oo;class sl{constructor(t){this.position=new w(t.x,t.y,t.z||0)}}const ao=class ao extends ht{get dxfTypeName(){return"POLYLINE"}constructor(t,e,s,n=!1,r=!1){super(),this._mCount=t,this._nCount=e,this._closedM=n,this._closedN=r,this._vertices=s.map(o=>new sl(o))}get mCount(){return this._mCount}get nCount(){return this._nCount}get closedM(){return this._closedM}get closedN(){return this._closedN}get closed(){return this._closedM}set closed(t){this._closedM=t}get numberOfVertices(){return this._vertices.length}getVertexAt(t){if(t<0||t>=this._vertices.length)throw new Error("Vertex index out of bounds");return this._vertices[t]}getVertexAtMN(t,e){const s=t*this._nCount+e;return this.getVertexAt(s)}get geometricExtents(){if(this._vertices.length===0)return new N(new w(0,0,0),new w(0,0,0));let t=Number.MAX_VALUE,e=Number.MAX_VALUE,s=Number.MAX_VALUE,n=-Number.MAX_VALUE,r=-Number.MAX_VALUE,o=-Number.MAX_VALUE;return this._vertices.forEach(a=>{t=Math.min(t,a.position.x),e=Math.min(e,a.position.y),s=Math.min(s,a.position.z),n=Math.max(n,a.position.x),r=Math.max(r,a.position.y),o=Math.max(o,a.position.z)}),new N(new w(t,e,s),new w(n,r,o))}subGetGripPoints(){const t=new Array;return this._vertices.forEach(e=>{t.push(e.position)}),t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:this._vertices.forEach(r=>{n.push(r.position)});break}}transformBy(t){return this._vertices.forEach(e=>{e.position.applyMatrix4(t)}),this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"mCount",type:"float",editable:!1,accessor:{get:()=>this._mCount}},{name:"nCount",type:"float",editable:!1,accessor:{get:()=>this._nCount}},{name:"vertices",type:"array",editable:!1,itemSchema:{properties:[{name:"x",type:"float",editable:!0},{name:"y",type:"float",editable:!0},{name:"z",type:"float",editable:!0}]},accessor:{get:()=>this._vertices.map(t=>({x:t.position.x,y:t.position.y,z:t.position.z}))}}]},{groupName:"others",properties:[{name:"closedM",type:"boolean",editable:!0,accessor:{get:()=>this._closedM,set:t=>{this._closedM=t}}},{name:"closedN",type:"boolean",editable:!0,accessor:{get:()=>this._closedN,set:t=>{this._closedN=t}}}]}]}}subWorldDraw(t){const e=[];for(let s=0;s<this._mCount;s++)for(let n=0;n<this._nCount;n++){const r=this.getVertexAtMN(s,n);let o=n+1;if(o>=this._nCount)if(this._closedN)o=0;else continue;const a=this.getVertexAtMN(s,o);e.push(r.position),e.push(a.position)}for(let s=0;s<this._nCount;s++)for(let n=0;n<this._mCount;n++){const r=this.getVertexAtMN(n,s);let o=n+1;if(o>=this._mCount)if(this._closedM)o=0;else continue;const a=this.getVertexAtMN(o,s);e.push(r.position),e.push(a.position)}return t.lines(e)}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbPolygonMesh");let e=16;return this._closedM&&(e|=1),this._closedN&&(e|=32),t.writeInt16(66,1),t.writeInt16(70,e),t.writeInt32(71,this._mCount),t.writeInt32(72,this._nCount),this}dxfOut(t,e=!1){super.dxfOut(t,e);for(let s=0;s<this.numberOfVertices;s++){const n=this.getVertexAt(s);t.writeStart("VERTEX"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDbPolygonMeshVertex"),t.writePoint3d(10,n.position),t.writeInt16(70,16)}return t.writeStart("SEQEND"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),this}};ao.typeName="PolygonMesh";let Ji=ao;class il{constructor(t){this.position=new w(t.x,t.y,t.z||0)}}class nl{constructor(t){this.vertexIndices=t}}const lo=class lo extends ht{get dxfTypeName(){return"POLYLINE"}constructor(t,e){super(),this._vertices=t.map(s=>new il(s)),this._faces=e.map(s=>new nl(s))}get numberOfVertices(){return this._vertices.length}get numberOfFaces(){return this._faces.length}get closed(){return!1}set closed(t){}getVertexAt(t){if(t<0||t>=this._vertices.length)throw new Error("Vertex index out of bounds");return this._vertices[t]}getFaceAt(t){if(t<0||t>=this._faces.length)throw new Error("Face index out of bounds");return this._faces[t]}get geometricExtents(){if(this._vertices.length===0)return new N(new w(0,0,0),new w(0,0,0));let t=Number.MAX_VALUE,e=Number.MAX_VALUE,s=Number.MAX_VALUE,n=-Number.MAX_VALUE,r=-Number.MAX_VALUE,o=-Number.MAX_VALUE;return this._vertices.forEach(a=>{t=Math.min(t,a.position.x),e=Math.min(e,a.position.y),s=Math.min(s,a.position.z),n=Math.max(n,a.position.x),r=Math.max(r,a.position.y),o=Math.max(o,a.position.z)}),new N(new w(t,e,s),new w(n,r,o))}subGetGripPoints(){const t=new Array;return this._vertices.forEach(e=>{t.push(e.position)}),t}subGetOsnapPoints(t,e,s,n){switch(t){case z.EndPoint:this._vertices.forEach(r=>{n.push(r.position)});break}}transformBy(t){return this._vertices.forEach(e=>{e.position.applyMatrix4(t)}),this}get properties(){return{type:this.type,groups:[this.getGeneralProperties(),{groupName:"geometry",properties:[{name:"vertices",type:"array",editable:!1,itemSchema:{properties:[{name:"x",type:"float",editable:!0},{name:"y",type:"float",editable:!0},{name:"z",type:"float",editable:!0}]},accessor:{get:()=>this._vertices.map(t=>({x:t.position.x,y:t.position.y,z:t.position.z}))}},{name:"faces",type:"array",editable:!1,itemSchema:{properties:[{name:"vertexIndices",type:"array",editable:!1,itemSchema:{properties:[{name:"index",type:"int",editable:!1}]}}]},accessor:{get:()=>this._faces.map(t=>({vertexIndices:t.vertexIndices}))}}]}]}}subWorldDraw(t){const e=[];return this._faces.forEach(s=>{const n=[];if(s.vertexIndices.forEach(r=>{const o=Math.abs(r)-1;o>=0&&o<this._vertices.length&&n.push(this._vertices[o].position)}),n.length>=3)for(let r=0;r<n.length;r++){const o=n[r],a=n[(r+1)%n.length];e.push(o),e.push(a)}}),t.lines(e)}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbPolyFaceMesh");const e=64;return t.writeInt16(66,1),t.writeInt16(70,e),this}dxfOut(t,e=!1){super.dxfOut(t,e);for(let s=0;s<this.numberOfVertices;s++){const n=this.getVertexAt(s);t.writeStart("VERTEX"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDbPolyFaceMeshVertex"),t.writePoint3d(10,n.position),t.writeInt16(70,64)}for(let s=0;s<this.numberOfFaces;s++){const n=this.getFaceAt(s);t.writeStart("VERTEX"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeSubclassMarker("AcDbVertex"),t.writeSubclassMarker("AcDbPolyFaceMeshVertex"),t.writeInt16(70,128),n.vertexIndices.forEach((r,o)=>{t.writeInt32(10+o,r)})}return t.writeStart("SEQEND"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),this}};lo.typeName="PolyFaceMesh";let tn=lo;var en=(i=>(i[i.AtLeast=1]="AtLeast",i[i.Exactly=2]="Exactly",i))(en||{});const ho=class ho extends lt{get dxfTypeName(){return"DIMENSION"}constructor(){super(),this._dimBlockId=null,this._dimBlockPosition=new w,this._dimensionStyleName=null,this._dimensionText=null,this._textLineSpacingFactor=1,this._textLineSpacingStyle=1,this._textPosition=new w,this._textRotation=0,this._normal=new _(0,0,1)}get dimBlockId(){return this._dimBlockId}set dimBlockId(t){this._dimBlockId=t}get dimBlockPosition(){return this._dimBlockPosition}set dimBlockPosition(t){this._dimBlockPosition.copy(t)}get dimensionStyleName(){return this._dimensionStyleName}set dimensionStyleName(t){this._dimensionStyleName=t,this._dimStyle=void 0}get dimensionStyle(){if(this._dimStyle==null){let t;this.dimensionStyleName&&(t=this.database.tables.dimStyleTable.getAt(this.dimensionStyleName)),t==null&&(t=new ts),this._dimStyle=t}return this._dimStyle}get dimensionText(){return this._dimensionText}set dimensionText(t){this._dimensionText=t}get measurement(){return this._measurement}set measurement(t){this._measurement=t}get textLineSpacingFactor(){return this._textLineSpacingFactor}set textLineSpacingFactor(t){this._textLineSpacingFactor=t}get textLineSpacingStyle(){return this._textLineSpacingStyle}set textLineSpacingStyle(t){this._textLineSpacingStyle=t}get textPosition(){return this._textPosition}set textPosition(t){this._textPosition.copy(t)}get textRotation(){return this._textRotation}set textRotation(t){this._textRotation=t}get normal(){return this._normal}set normal(t){this._normal.copy(t).normalize()}get properties(){return this.getBaseProperties()}getBaseProperties(){return{type:this.type,groups:[this.getGeneralProperties(),this.getDimensionProperties()]}}transformBy(t){const e=this._textPosition.clone(),s=this._textPosition.clone().add(new _(Math.cos(this._textRotation),Math.sin(this._textRotation),0));this._dimBlockPosition.applyMatrix4(t),this._textPosition.applyMatrix4(t),this._normal.transformDirection(t),e.applyMatrix4(t),s.applyMatrix4(t);const n=new _(s).sub(e);return n.lengthSq()>0&&(this._textRotation=Math.atan2(n.y,n.x)),this.subTransformBy(t),this}subGetOsnapPoints(t,e,s,n,r){const o=this.getDimBlockTableRecord();if(!o)return;const a=this.getFullDimBlockTransform(),h=new w(e).applyMatrix4(a.clone().invert()),c=new w(s).applyMatrix4(a.clone().invert()),d=(u,p)=>{const g=[];u.subGetOsnapPoints(t,h,c,g,p,a),u instanceof Je?g.forEach(m=>n.push(m.clone())):g.forEach(m=>n.push(new w(m).applyMatrix4(a)))};if(r){const u=o.getIdAt(r);if(u&&(d(u,r),n.length>0))return}for(const u of o.newIterator())d(u)}subWorldDraw(t){const e=this.getDimBlockTableRecord();if(e){const n=this.computeDimBlockTransform();return es.instance.draw(t,e,this.rgbColor,[],!1,n,this._normal)}return t.group([])}getDimBlockGeometricExtents(){const t=new N,e=this.getDimBlockTableRecord();if(!e)return t;for(const s of e.newIterator())t.union(s.geometricExtents);return t.applyMatrix4(this.getFullDimBlockTransform()),t}getDimBlockTableRecord(){return this.dimBlockId?this.database.tables.blockTable.getAt(this.dimBlockId):void 0}getDimensionProperties(){return{groupName:"dimension",properties:[this.createProperty("dimensionStyleName","string",()=>this.dimensionStyleName??"",t=>{this.dimensionStyleName=t.trim()===""?null:t}),this.createProperty("dimensionText","string",()=>this.dimensionText??"",t=>{this.dimensionText=t}),this.createProperty("measurement","float",()=>this.getMeasurementPropertyValue()),this.createProperty("dimBlockId","string",()=>this.dimBlockId??""),...this.createPoint3dProperties("dimBlockPosition",()=>this.dimBlockPosition),...this.createPoint3dProperties("textPosition",()=>this.textPosition),this.createProperty("textRotation","float",()=>this.textRotation,t=>{this.textRotation=t}),this.createProperty("textLineSpacingFactor","float",()=>this.textLineSpacingFactor,t=>{this.textLineSpacingFactor=t}),this.createProperty("textLineSpacingStyle","enum",()=>this.textLineSpacingStyle,t=>{this.textLineSpacingStyle=t},[{label:en[1],value:1},{label:en[2],value:2}]),...this.createPoint3dProperties("normal",()=>this.normal)]}}createProperty(t,e,s,n,r){return{name:t,type:e,editable:n!=null,options:r,accessor:n?{get:s,set:n}:{get:s}}}createPoint3dProperties(t,e){return[this.createProperty(`${t}X`,"float",()=>e().x,s=>{e().x=s}),this.createProperty(`${t}Y`,"float",()=>e().y,s=>{e().y=s}),this.createProperty(`${t}Z`,"float",()=>e().z,s=>{e().z=s})]}getMeasurementPropertyValue(){return this.measurement}getFullDimBlockTransform(){const t=this.computeDimBlockTransform();if(this._normal.x===0&&this._normal.y===0&&this._normal.z===1)return t;const e=new D().setFromExtrusionDirection(this._normal);return new D().multiplyMatrices(e,t)}get arrowScaleFactor(){return this.dimensionStyle.dimasz}get firstArrowStyle(){return{type:this.firstArrowType,scale:this.arrowScaleFactor,appended:this.isAppendArrow,visible:this.dimensionStyle.dimse1==0}}get secondArrowStyle(){return{type:this.secondArrowType,scale:this.arrowScaleFactor,appended:this.isAppendArrow,visible:this.dimensionStyle.dimse2==0}}get isAppendArrow(){return!0}get firstArrowTypeBtrId(){const t=this.dimensionStyle;return t.dimsah==0?t.dimblk:t.dimblk1}get firstArrowType(){const t=this.firstArrowTypeBtrId;return this.getArrowName(t)}get secondArrowTypeBtrId(){const t=this.dimensionStyle;return t.dimsah==0?t.dimblk:t.dimblk2}get secondArrowType(){const t=this.secondArrowTypeBtrId;return this.getArrowName(t)}get arrowLineCount(){return 1}findPointOnLine1(t,e,s){const n=new w().subVectors(e,t).normalize();return new w(e).addScaledVector(n,s)}findPointOnLine2(t,e,s){const n=t.x+s*Math.cos(e),r=t.y+s*Math.sin(e);return{x:n,y:r}}adjustExtensionLine(t){const e=this.dimensionStyle;t.extend(e.dimexe),t.extend(-e.dimexo,!0)}getArrowName(t){const e=this.database.tables.blockTable.getIdAt(t);return e?e.name.toUpperCase():yr.Closed}computeDimBlockTransform(){const t=this.dimBlockId?this.database.tables.blockTable.getAt(this.dimBlockId):void 0,e=(t==null?void 0:t.origin)??w.ORIGIN,s=new D().makeTranslation(-e.x,-e.y,-e.z),n=new D().makeTranslation(this._dimBlockPosition.x,this._dimBlockPosition.y,this._dimBlockPosition.z);return new D().multiplyMatrices(n,s)}subTransformBy(t){}dxfOutFields(t){super.dxfOutFields(t);const e=this.dimensionStyleName!=null?this.database.tables.dimStyleTable.getAt(this.dimensionStyleName):void 0;return t.writeSubclassMarker("AcDbDimension"),t.writeInt16(280,0),t.writeString(2,this.dimBlockId??void 0),t.writeString(3,this.dimensionStyleName??this.dimensionStyle.name),t.writePoint3d(10,this.dimBlockPosition),t.writeString(1,this.dimensionText??""),t.writeAngle(53,this.textRotation),t.writePoint3d(11,this.textPosition),t.writeInt16(70,0),t.writeInt16(72,this.textLineSpacingStyle),t.writeDouble(41,this.textLineSpacingFactor),t.writeDouble(42,this.measurement),t.writeVector3d(210,this.normal),t.writeObjectId(340,e==null?void 0:e.objectId),this}};ho.typeName="Dimension";let ge=ho;const co=class co extends ge{constructor(t,e,s,n,r=null,o=null){super(),this._centerPoint=new w().copy(t),this._xLine1Point=new w().copy(e),this._xLine2Point=new w().copy(s),this._arcPoint=new w().copy(n),this.dimensionText=r,this.dimensionStyleName=o}get arcPoint(){return this._arcPoint}set arcPoint(t){this._arcPoint.copy(t)}get centerPoint(){return this._centerPoint}set centerPoint(t){this._centerPoint.copy(t)}get xLine1Point(){return this._xLine1Point}set xLine1Point(t){this._xLine1Point.copy(t)}get xLine2Point(){return this._xLine2Point}set xLine2Point(t){this._xLine2Point.copy(t)}get properties(){const t=this.getBaseProperties();return{type:this.type,groups:[...t.groups,{groupName:"geometry",properties:[...this.createPoint3dProperties("centerPoint",()=>this.centerPoint),...this.createPoint3dProperties("xLine1Point",()=>this.xLine1Point),...this.createPoint3dProperties("xLine2Point",()=>this.xLine2Point),...this.createPoint3dProperties("arcPoint",()=>this.arcPoint)]}]}}subTransformBy(t){this._arcPoint.applyMatrix4(t),this._centerPoint.applyMatrix4(t),this._xLine1Point.applyMatrix4(t),this._xLine2Point.applyMatrix4(t)}get geometricExtents(){return new N}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDb3PointAngularDimension"),t.writePoint3d(13,this.xLine1Point),t.writePoint3d(14,this.xLine2Point),t.writePoint3d(15,this.centerPoint),t.writePoint3d(16,this.arcPoint),this}};co.typeName="3PointAngularDimension";let sn=co;const uo=class uo extends ge{constructor(t,e,s,n=null,r=null){super(),this._dimLinePoint=new w().copy(s),this._xLine1Point=new w().copy(t),this._xLine2Point=new w().copy(e),this._oblique=0,this._rotation=0,this.calculateRotation(),n?this.dimensionText=n:this.dimensionText=this._xLine1Point.distanceTo(this._xLine2Point).toFixed(3),this.dimensionStyleName=r}get dimLinePoint(){return this._dimLinePoint}set dimLinePoint(t){this._dimLinePoint.copy(t)}get xLine1Point(){return this._xLine1Point}set xLine1Point(t){this._xLine1Point.copy(t)}get xLine2Point(){return this._xLine2Point}set xLine2Point(t){this._xLine2Point.copy(t)}get rotation(){return this._rotation}set rotation(t){this._rotation=t}get oblique(){return this._oblique}set oblique(t){this._oblique=t}get properties(){const t=this.getBaseProperties();return{type:this.type,groups:[...t.groups,{groupName:"geometry",properties:[...this.createPoint3dProperties("xLine1Point",()=>this.xLine1Point),...this.createPoint3dProperties("xLine2Point",()=>this.xLine2Point),...this.createPoint3dProperties("dimLinePoint",()=>this.dimLinePoint),this.createProperty("rotation","float",()=>this.rotation,e=>{this.rotation=e}),this.createProperty("oblique","float",()=>this.oblique,e=>{this.oblique=e})]}]}}subTransformBy(t){this._dimLinePoint.applyMatrix4(t),this._xLine1Point.applyMatrix4(t),this._xLine2Point.applyMatrix4(t),this.calculateRotation()}get geometricExtents(){return this.getDimBlockGeometricExtents()}get isAppendArrow(){return!1}createDimBlock(t){const e=new J;e.name=t;const s=this.createLines();s.forEach(a=>e.appendEntity(new Ys(a.startPoint,a.endPoint))),this.createArrows(s[0]).forEach(a=>e.appendEntity(a));const r=s[0].midPoint,o=this.createMText(r,this._rotation);return o&&e.appendEntity(o),e}createMText(t,e){const s=n=>({x:Math.cos(n),y:Math.sin(n),z:0});if(this.dimensionText){const n=new Xs;return n.attachmentPoint=ot.MiddleLeft,n.layer="0",n.color=new j(P.ByBlock),n.location=t,n.contents=this.dimensionText??"",n.height=10,n.direction=s(e),n.styleName=this.dimensionStyle.dimtxsty,n}}createArrows(t){const e=[];return e.push(this.createArrow(t.startPoint,this.rotation+Math.PI,10)),e.push(this.createArrow(t.endPoint,this.rotation,10)),e}createArrow(t,e,s){const n="_CAXARROW",r=new Je(n);return r.position=t,r.rotation=e,r.scaleFactors={x:s,y:s,z:s},r}createLines(){const t=[],e=this.createExtensionLine(this._xLine1Point),s=this.createExtensionLine(this._xLine2Point),n=this.findIntersectionPoint(e,this._dimLinePoint),r=this.findIntersectionPoint(s,this._dimLinePoint),o=new Ee(n,r);return t.push(o),e.endPoint=n,this.adjustExtensionLine(e),t.push(e),s.endPoint=r,this.adjustExtensionLine(s),t.push(s),t}createExtensionLine(t){const e=this.rotation+Math.PI/2,s=this.findPointOnLine2(t,e,100);return new Ee(t,{...s,z:t.z})}findIntersectionPoint(t,e){const s=t.startPoint,n=t.endPoint,r=new _().subVectors(n,s).normalize(),a=new _().subVectors(e,s).dot(r),h=new _().copy(r).multiplyScalar(a);return new _().addVectors(s,h)}calculateRotation(){const t=this._xLine1Point,e=this._xLine2Point,s=e.x-t.x,n=e.y-t.y;this._rotation=Math.atan2(n,s)}get dxfSubclassMarker(){return"AcDbAlignedDimension"}getMeasurementPropertyValue(){return this.measurement??this.xLine1Point.distanceTo(this.xLine2Point)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker(this.dxfSubclassMarker),t.writePoint3d(13,this.xLine1Point),t.writePoint3d(14,this.xLine2Point),t.writePoint3d(15,this.dimLinePoint),t.writeAngle(50,this.rotation),t.writeAngle(52,this.oblique),this}};uo.typeName="AlignedDimension";let Zs=uo;const go=class go extends ge{constructor(t,e,s,n,r=null,o=null){super(),this._arcPoint=new w().copy(n),this._xLine1Point=new w().copy(e),this._xLine2Point=new w().copy(s),this._centerPoint=new w().copy(t),this.dimensionText=r,this.dimensionStyleName=o}get arcPoint(){return this._arcPoint}set arcPoint(t){this._arcPoint.copy(t)}get centerPoint(){return this._centerPoint}set centerPoint(t){this._centerPoint.copy(t)}get xLine1Point(){return this._xLine1Point}set xLine1Point(t){this._xLine1Point.copy(t)}get xLine2Point(){return this._xLine2Point}set xLine2Point(t){this._xLine2Point.copy(t)}get properties(){const t=this.getBaseProperties();return{type:this.type,groups:[...t.groups,{groupName:"geometry",properties:[...this.createPoint3dProperties("centerPoint",()=>this.centerPoint),...this.createPoint3dProperties("xLine1Point",()=>this.xLine1Point),...this.createPoint3dProperties("xLine2Point",()=>this.xLine2Point),...this.createPoint3dProperties("arcPoint",()=>this.arcPoint)]}]}}subTransformBy(t){this._arcPoint.applyMatrix4(t),this._centerPoint.applyMatrix4(t),this._xLine1Point.applyMatrix4(t),this._xLine2Point.applyMatrix4(t)}get geometricExtents(){return new N}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbArcDimension"),t.writePoint3d(13,this.xLine1Point),t.writePoint3d(14,this.xLine2Point),t.writePoint3d(15,this.centerPoint),t.writePoint3d(16,this.arcPoint),this}};go.typeName="ArcDimension";let qn=go;const po=class po extends ge{constructor(t,e,s=0,n=null,r=null){super(),this._chordPoint=new w().copy(t),this._farChordPoint=new w().copy(e),this._extArcStartAngle=0,this._extArcEndAngle=0,this._leaderLength=s,this.dimensionText=n,this.dimensionStyleName=r}get chordPoint(){return this._chordPoint}set chordPoint(t){this._chordPoint.copy(t)}get farChordPoint(){return this._farChordPoint}set farChordPoint(t){this._farChordPoint.copy(t)}get extArcStartAngle(){return this._extArcStartAngle}set extArcStartAngle(t){this._extArcStartAngle=t}get extArcEndAngle(){return this._extArcEndAngle}set extArcEndAngle(t){this._extArcEndAngle=t}get leaderLength(){return this._leaderLength}set leaderLength(t){this._leaderLength=t}get properties(){const t=this.getBaseProperties();return{type:this.type,groups:[...t.groups,{groupName:"geometry",properties:[...this.createPoint3dProperties("chordPoint",()=>this.chordPoint),...this.createPoint3dProperties("farChordPoint",()=>this.farChordPoint),this.createProperty("leaderLength","float",()=>this.leaderLength,e=>{this.leaderLength=e}),this.createProperty("extArcStartAngle","float",()=>this.extArcStartAngle,e=>{this.extArcStartAngle=e}),this.createProperty("extArcEndAngle","float",()=>this.extArcEndAngle,e=>{this.extArcEndAngle=e})]}]}}subTransformBy(t){this._chordPoint.applyMatrix4(t),this._farChordPoint.applyMatrix4(t)}getMeasurementPropertyValue(){return this.measurement??this.chordPoint.distanceTo(this.farChordPoint)}get geometricExtents(){return new N}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbDiametricDimension"),t.writePoint3d(15,this.chordPoint),t.writePoint3d(16,this.farChordPoint),t.writeDouble(40,this.leaderLength),t.writeAngle(52,this.extArcStartAngle),t.writeAngle(53,this.extArcEndAngle),this}};po.typeName="DiametricDimension";let nn=po;const mo=class mo extends ge{constructor(t,e,s=null,n=null){super(),this._definingPoint=new w().copy(t),this._leaderEndPoint=new w().copy(e),this.dimensionText=s,this.dimensionStyleName=n}get definingPoint(){return this._definingPoint}set definingPoint(t){this._definingPoint.copy(t)}get leaderEndPoint(){return this._leaderEndPoint}set leaderEndPoint(t){this._leaderEndPoint.copy(t)}get properties(){const t=this.getBaseProperties();return{type:this.type,groups:[...t.groups,{groupName:"geometry",properties:[...this.createPoint3dProperties("definingPoint",()=>this.definingPoint),...this.createPoint3dProperties("leaderEndPoint",()=>this.leaderEndPoint)]}]}}subTransformBy(t){this._definingPoint.applyMatrix4(t),this._leaderEndPoint.applyMatrix4(t)}get geometricExtents(){return new N}get arrowLineCount(){return 0}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbOrdinateDimension"),t.writePoint3d(13,this.definingPoint),t.writePoint3d(14,this.leaderEndPoint),this}};mo.typeName="OrdinateDimension";let rn=mo;const yo=class yo extends ge{constructor(t,e,s,n=null,r=null){super(),this._center=new w().copy(t),this._chordPoint=new w().copy(e),this._leaderLength=s,this._extArcStartAngle=0,this._extArcEndAngle=0,this.dimensionText=n,this.dimensionStyleName=r}get center(){return this._center}set center(t){this._center.copy(t)}get chordPoint(){return this._chordPoint}set chordPoint(t){this._chordPoint.copy(t)}get extArcStartAngle(){return this._extArcStartAngle}set extArcStartAngle(t){this._extArcStartAngle=t}get extArcEndAngle(){return this._extArcEndAngle}set extArcEndAngle(t){this._extArcEndAngle=t}get leaderLength(){return this._leaderLength}set leaderLength(t){this._leaderLength=t}set leaderLenght(t){this._leaderLength=t}get properties(){const t=this.getBaseProperties();return{type:this.type,groups:[...t.groups,{groupName:"geometry",properties:[...this.createPoint3dProperties("center",()=>this.center),...this.createPoint3dProperties("chordPoint",()=>this.chordPoint),this.createProperty("leaderLength","float",()=>this.leaderLength,e=>{this.leaderLength=e}),this.createProperty("extArcStartAngle","float",()=>this.extArcStartAngle,e=>{this.extArcStartAngle=e}),this.createProperty("extArcEndAngle","float",()=>this.extArcEndAngle,e=>{this.extArcEndAngle=e})]}]}}subTransformBy(t){this._center.applyMatrix4(t),this._chordPoint.applyMatrix4(t)}getMeasurementPropertyValue(){return this.measurement??this.center.distanceTo(this.chordPoint)}get geometricExtents(){return new N}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbRadialDimension"),t.writePoint3d(15,this.center),t.writePoint3d(13,this.chordPoint),t.writeDouble(40,this.leaderLength),t.writeAngle(52,this.extArcStartAngle),t.writeAngle(53,this.extArcEndAngle),this}};yo.typeName="RadialDimension";let on=yo;const _o=class _o extends Zs{get dxfSubclassMarker(){return"AcDbRotatedDimension"}};_o.typeName="RotatedDimension";let an=_o;var rl=(i=>(i[i.kInches=0]="kInches",i[i.kMillimeters=1]="kMillimeters",i[i.kPixels=2]="kPixels",i))(rl||{}),ol=(i=>(i[i.k0degrees=0]="k0degrees",i[i.k90degrees=1]="k90degrees",i[i.k180degrees=2]="k180degrees",i[i.k270degrees=3]="k270degrees",i))(ol||{}),al=(i=>(i[i.kDisplay=0]="kDisplay",i[i.kExtents=1]="kExtents",i[i.kLimits=2]="kLimits",i[i.kView=3]="kView",i[i.kWindow=4]="kWindow",i[i.kLayout=5]="kLayout",i))(al||{}),we=(i=>(i[i.kDraft=0]="kDraft",i[i.kPreview=1]="kPreview",i[i.kNormal=2]="kNormal",i[i.kPresentation=3]="kPresentation",i[i.kMaximum=4]="kMaximum",i[i.kCustom=5]="kCustom",i))(we||{}),os=(i=>(i[i.kAsDisplayed=0]="kAsDisplayed",i[i.kWireframe=1]="kWireframe",i[i.kHidden=2]="kHidden",i[i.kRendered=3]="kRendered",i[i.kVisualStyle=4]="kVisualStyle",i[i.kRenderPreset=5]="kRenderPreset",i))(os||{}),ll=(i=>(i[i.kScaleToFit=0]="kScaleToFit",i[i.k1_128in_1ft=1]="k1_128in_1ft",i[i.k1_64in_1ft=2]="k1_64in_1ft",i[i.k1_32in_1ft=3]="k1_32in_1ft",i[i.k1_16in_1ft=4]="k1_16in_1ft",i[i.k3_32in_1ft=5]="k3_32in_1ft",i[i.k1_8in_1ft=6]="k1_8in_1ft",i[i.k3_16in_1ft=7]="k3_16in_1ft",i[i.k1_4in_1ft=8]="k1_4in_1ft",i[i.k3_8in_1ft=9]="k3_8in_1ft",i[i.k1_2in_1ft=10]="k1_2in_1ft",i[i.k3_4in_1ft=11]="k3_4in_1ft",i[i.k1in_1ft=12]="k1in_1ft",i[i.k3in_1ft=13]="k3in_1ft",i[i.k6in_1ft=14]="k6in_1ft",i[i.k1ft_1ft=15]="k1ft_1ft",i[i.k1_1=16]="k1_1",i[i.k1_2=17]="k1_2",i[i.k1_4=18]="k1_4",i[i.k1_5=19]="k1_5",i[i.k1_8=20]="k1_8",i[i.k1_10=21]="k1_10",i[i.k1_16=22]="k1_16",i[i.k1_20=23]="k1_20",i[i.k1_30=24]="k1_30",i[i.k1_40=25]="k1_40",i[i.k1_50=26]="k1_50",i[i.k1_100=27]="k1_100",i[i.k2_1=28]="k2_1",i[i.k4_1=29]="k4_1",i[i.k8_1=30]="k8_1",i[i.k10_1=31]="k10_1",i[i.k100_1=32]="k100_1",i[i.k1000_1=33]="k1000_1",i[i.k1and1_2in_1ft=34]="k1and1_2in_1ft",i))(ll||{});const Hc={0:0,1:1/1536,2:1/768,3:1/384,4:1/192,5:1/128,6:1/96,7:1/64,8:1/48,9:1/32,10:1/24,11:1/16,12:1/12,13:1/4,14:1/2,15:1,16:1,17:1/2,18:1/4,19:1/5,20:1/8,21:1/10,22:1/16,23:1/20,24:1/30,25:1/40,26:1/50,27:1/100,28:2,29:4,30:8,31:10,32:100,33:1e3,34:1/8};class hl extends Ft{constructor(t=!1){super(),this._plotSettingsName="",this._plotCfgName="",this._canonicalMediaName="",this._currentStyleSheet="",this._plotOrigin=new v,this._customPrintScale={numerator:1,denominator:1},this._plotPaperSize=new v,this._plotPaperMargins={left:0,right:0,top:0,bottom:0},this._plotViewName="",this._plotWindowArea=new _t,this._modelType=t,this._plotCentered=!1,this._plotHidden=!1,this._plotPaperUnits=1,this._plotPlotStyles=!0,this._plotRotation=0,this._plotType=5,this._plotViewportBorders=!1,this._printLineweights=!0,this._scaleLineweights=!1,this._drawViewportsFirst=!1,this._showPlotStyles=!0,this._shadePlotType=0,this._shadePlotResLevel=2,this._shadePlotCustomDpi=300,this._shadePlotId=void 0,this._stdScaleType=0,this._useStandardScale=!0}get plotSettingsName(){return this._plotSettingsName}set plotSettingsName(t){this._plotSettingsName=t}getPlotSettingsName(){return this._plotSettingsName}setPlotSettingsName(t){this._plotSettingsName=t}get plotCfgName(){return this._plotCfgName}set plotCfgName(t){this._plotCfgName=t}getPlotCfgName(){return this._plotCfgName}get canonicalMediaName(){return this._canonicalMediaName}set canonicalMediaName(t){this._canonicalMediaName=t}getCanonicalMediaName(){return this._canonicalMediaName}get currentStyleSheet(){return this._currentStyleSheet}set currentStyleSheet(t){this._currentStyleSheet=t}getCurrentStyleSheet(){return this._currentStyleSheet}get plotOrigin(){return this._plotOrigin}set plotOrigin(t){this._plotOrigin=t}getPlotOrigin(){return this._plotOrigin}get customPrintScale(){return this._customPrintScale}set customPrintScale(t){this._customPrintScale=t}getCustomPrintScale(){return this._customPrintScale}get plotPaperSize(){return this._plotPaperSize}set plotPaperSize(t){this._plotPaperSize=t}getPlotPaperSize(){return this._plotPaperSize}get plotPaperMargins(){return this._plotPaperMargins}set plotPaperMargins(t){this._plotPaperMargins=t}getPlotPaperMargins(){return this._plotPaperMargins}get plotViewName(){return this._plotViewName}set plotViewName(t){this._plotViewName=t}getPlotViewName(){return this._plotViewName}get plotWindowArea(){return this._plotWindowArea}set plotWindowArea(t){this._plotWindowArea=t}getPlotWindowArea(){return this._plotWindowArea}get modelType(){return this._modelType}set modelType(t){this._modelType=t}getModelType(){return this._modelType}setModelType(t){this._modelType=t}get drawViewportsFirst(){return this._drawViewportsFirst}set drawViewportsFirst(t){this._drawViewportsFirst=t}setDrawViewportsFirst(t){this._drawViewportsFirst=t}get plotCentered(){return this._plotCentered}set plotCentered(t){this._plotCentered=t}setPlotCentered(t){this._plotCentered=t}get plotHidden(){return this._plotHidden}set plotHidden(t){this._plotHidden=t}setPlotHidden(t){this._plotHidden=t}get plotPaperUnits(){return this._plotPaperUnits}set plotPaperUnits(t){this._plotPaperUnits=t}get plotPlotStyles(){return this._plotPlotStyles}set plotPlotStyles(t){this._plotPlotStyles=t}setPlotPlotStyles(t){this._plotPlotStyles=t}get plotRotation(){return this._plotRotation}set plotRotation(t){this._plotRotation=t}get plotType(){return this._plotType}set plotType(t){this._plotType=t}get plotViewportBorders(){return this._plotViewportBorders}set plotViewportBorders(t){this._plotViewportBorders=t}setPlotViewportBorders(t){this._plotViewportBorders=t}get printLineweights(){return this._printLineweights}set printLineweights(t){this._printLineweights=t}setPrintLineweights(t){this._printLineweights=t}get scaleLineweights(){return this._scaleLineweights}set scaleLineweights(t){this._scaleLineweights=t}setScaleLineweights(t){this._scaleLineweights=t}get showPlotStyles(){return this._showPlotStyles}set showPlotStyles(t){this._showPlotStyles=t}setShowPlotStyles(t){this._showPlotStyles=t}get shadePlot(){return this._shadePlotType}set shadePlot(t){this._shadePlotType=t}setShadePlot(t){this._shadePlotType=t}get shadePlotResLevel(){return this._shadePlotResLevel}set shadePlotResLevel(t){this._shadePlotResLevel=t}setShadePlotResLevel(t){this._shadePlotResLevel=t}get shadePlotCustomDPI(){return this._shadePlotCustomDpi}set shadePlotCustomDPI(t){this._shadePlotCustomDpi=t}setShadePlotCustomDPI(t){this._shadePlotCustomDpi=t}get shadePlotId(){return this._shadePlotId}set shadePlotId(t){this._shadePlotId=t}get plotWireframe(){return this._shadePlotType===1}get plotAsRaster(){return this._shadePlotType===3||this._shadePlotType===4||this._shadePlotType===5}get stdScaleType(){return this._stdScaleType}set stdScaleType(t){this._stdScaleType=t}get stdScale(){return Hc[this._stdScaleType]??1}get useStandardScale(){return this._useStandardScale}set useStandardScale(t){this._useStandardScale=t}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbPlotSettings"),t.writeString(1,this.plotSettingsName),t.writeString(2,this.plotCfgName),t.writeString(4,this.canonicalMediaName),t.writeString(6,this.plotViewName),t.writeDouble(40,this.plotPaperMargins.left),t.writeDouble(41,this.plotPaperMargins.bottom),t.writeDouble(42,this.plotPaperMargins.right),t.writeDouble(43,this.plotPaperMargins.top),t.writeDouble(44,this.plotPaperSize.x),t.writeDouble(45,this.plotPaperSize.y),t.writeDouble(46,this.plotOrigin.x),t.writeDouble(47,this.plotOrigin.y),t.writeDouble(48,this.plotWindowArea.min.x),t.writeDouble(49,this.plotWindowArea.min.y),t.writeDouble(140,this.plotWindowArea.max.x),t.writeDouble(141,this.plotWindowArea.max.y),t.writeDouble(142,this.customPrintScale.numerator),t.writeDouble(143,this.customPrintScale.denominator);let e=0;return this.plotViewportBorders&&(e|=1),this.showPlotStyles&&(e|=2),this.plotCentered&&(e|=4),this.plotHidden&&(e|=8),this.useStandardScale&&(e|=16),this.plotPlotStyles&&(e|=32),this.scaleLineweights&&(e|=64),this.printLineweights&&(e|=128),this.drawViewportsFirst&&(e|=512),this.modelType&&(e|=1024),t.writeInt16(70,e),t.writeInt16(72,this.plotPaperUnits),t.writeInt16(73,this.plotRotation),t.writeInt16(74,this.plotType),t.writeString(7,this.currentStyleSheet),t.writeInt16(75,this.stdScaleType),t.writeInt16(76,this.shadePlot),t.writeInt16(77,this.shadePlotResLevel),t.writeInt16(78,this.shadePlotCustomDPI),t.writeDouble(147,this.stdScale),t.writeObjectId(333,this.shadePlotId),this}}class ii extends hl{constructor(){super(),this._tabOrder=-1,this._tabSelected=!1,this._blockTableRecordId="",this._layoutName="",this._limits=new _t,this._extents=new N,this._viewportArray=[]}get layoutName(){return this._layoutName}set layoutName(t){this._layoutName=t.length>256?t.slice(0,256):t}get tabOrder(){return this._tabOrder}set tabOrder(t){this._tabOrder=t}get tabSelected(){return this._tabSelected}set tabSelected(t){this._tabSelected=t}get blockTableRecordId(){return this._blockTableRecordId}set blockTableRecordId(t){this._blockTableRecordId=t}get limits(){return this._limits}set limits(t){this._limits.copy(t)}get extents(){return this._extents}set extents(t){this._extents.copy(t)}get viewportArray(){return this._viewportArray}set viewportArray(t){this._viewportArray=t.slice()}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbLayout"),t.writeString(1,this.layoutName),t.writeInt16(70,this.tabSelected?1:0),t.writeInt16(71,this.tabOrder),t.writeObjectId(330,this.blockTableRecordId),t.writeObjectId(331,this._viewportArray.length>0?this._viewportArray[0]:"0"),t.writePoint2d(10,this.limits.min),t.writePoint2d(11,this.limits.max),t.writePoint3d(14,this.extents.min),t.writePoint3d(15,this.extents.max),this}}class ni{constructor(t){this.i=0,this._records=t,this._keys=Array.from(t.keys())}get count(){return this._records.size}toArray(){return Array.from(this._records.values())}[Symbol.iterator](){return this}next(){for(;this.i<this._keys.length;){const t=this._records.get(this._keys[this.i]);return this.i+=1,{value:t,done:!1}}return{value:null,done:!0}}}class Ze extends Ft{constructor(t){super(),this.database=t,this.objectId=t.generateHandle(),this._recordsByName=new Map,this._recordsById=new Map}get numEntries(){return this._recordsByName.size}setAt(t,e){e.database=this.database,e.ownerId=this.objectId,this.database.commitObjectHandle(e,s=>this.hasId(s)),this._recordsByName.set(t,e),this._recordsById.set(e.objectId,e),this.database.events.dictObjetSet.dispatch({database:this.database,object:e,key:t})}remove(t){const e=this.getAt(t);return e?(this._recordsByName.delete(t.toUpperCase()),this._recordsById.delete(this.objectId),this.database.events.dictObjectErased.dispatch({database:this.database,object:e,key:t}),!0):!1}removeId(t){const e=this.getIdAt(t);return e?(this._recordsById.delete(this.objectId),this._recordsByName.forEach((s,n)=>{s===e&&(this._recordsByName.delete(n),this.database.events.dictObjectErased.dispatch({database:this.database,object:e,key:n}))}),!0):!1}removeAll(){this._recordsByName.forEach((t,e)=>{this.database.events.dictObjectErased.dispatch({database:this.database,object:t,key:e})}),this._recordsByName.clear(),this._recordsById.clear()}has(t){return this._recordsByName.has(t.toUpperCase())}hasId(t){return this._recordsById.has(t)}getAt(t){return this._recordsByName.get(t)}getIdAt(t){return this._recordsById.get(t)}newIterator(){return new ni(this._recordsByName)}entries(){return this._recordsByName.entries()}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbDictionary"),t.writeInt16(280,1),t.writeInt16(281,1);for(const[e,s]of this._recordsByName)t.writeString(3,e),t.writeObjectId(350,s.objectId);return this}}class cl extends Ze{getBtrIdAt(t){for(const[e,s]of this._recordsByName)if(s.blockTableRecordId==t)return s}get maxTabOrder(){let t=-1;return this._recordsByName.forEach(e=>{e.tabOrder>t&&(t=e.tabOrder)}),t}}class Me extends Ft{constructor(t,e){t=t||{},Qs(t,{name:""}),super(t,e)}get name(){return this.getAttr("name")}set name(t){this.setAttr("name",t)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbSymbolTableRecord"),this}}var dl=(i=>(i[i.Any=0]="Any",i[i.Uniform=1]="Uniform",i))(dl||{});const be=class be extends Me{static isModelSapceName(t){return t.toLowerCase()==be.MODEL_SPACE_NAME.toLowerCase()}static isPaperSapceName(t){return t.toLowerCase().startsWith(be.PAPER_SPACE_NAME_PREFIX.toLowerCase())}constructor(){super(),this._origin=new w,this._layoutId="",this._entities=new Map,this._blockInsertUnits=0,this._explodability=1,this._blockScaling=1,this._bmpPreview=void 0}get isModelSapce(){return be.isModelSapceName(this.name)}get isPaperSapce(){return be.isPaperSapceName(this.name)}get origin(){return this._origin}set origin(t){this._origin.copy(t)}get layoutId(){return this._layoutId}set layoutId(t){this._layoutId=t}get blockInsertUnits(){return this._blockInsertUnits}set blockInsertUnits(t){this._blockInsertUnits=t}get explodability(){return this._explodability}set explodability(t){this._explodability=t}get blockScaling(){return this._blockScaling}set blockScaling(t){this._blockScaling=t}get bmpPreview(){return this._bmpPreview}set bmpPreview(t){this._bmpPreview=t}appendEntity(t){const e=s=>{s.database=this.database,s.ownerId=this.objectId,this.database.ensureEntityStyleDefaults(s),this.database.commitObjectHandle(s,n=>this._entities.has(n)),s.resolveEffectiveProperties(),this._entities.set(s.objectId,s)};if(Array.isArray(t))for(let s=0;s<t.length;++s)e(t[s]);else e(t);(this.isModelSapce||this.isPaperSapce)&&this.database.events.entityAppended.dispatch({database:this.database,entity:t})}removeEntity(t){const e=Array.isArray(t)?t:[t],s=[];return e.forEach(n=>{const r=this._entities.get(n);r&&s.push(r),this._entities.delete(n)}),s.length>0&&this.database.events.entityErased.dispatch({database:this.database,entity:s}),s.length>0}newIterator(){return new ni(this._entities)}getIdAt(t){return this._entities.get(t)}dxfOutBlockRecord(t){return t.writeStart("BLOCK_RECORD"),this.dxfOut(t),this}dxfOutBlockBegin(t){return t.writeStart("BLOCK"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeString(8,"0"),t.writeSubclassMarker("AcDbBlockBegin"),t.writeString(2,this.name),t.writeInt16(70,0),t.writePoint3d(10,this.origin),t.writeString(3,this.name),this}dxfOutBlockEnd(t){return t.writeStart("ENDBLK"),t.writeHandle(5,this.database.generateHandle()),t.writeObjectId(330,this.objectId),t.writeSubclassMarker("AcDbEntity"),t.writeSubclassMarker("AcDbBlockEnd"),this}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbBlockTableRecord"),t.writeString(2,this.name),t.writeInt16(70,this.blockInsertUnits),t.writeInt16(280,this.explodability),t.writeInt16(281,this.blockScaling),(this.isModelSapce||this.isPaperSapce)&&t.writeObjectId(340,this.layoutId),this}};be.MODEL_SPACE_NAME="*Model_Space",be.PAPER_SPACE_NAME_PREFIX="*Paper_Space";let J=be;class ul{constructor(){this.events={layoutCreated:new Q,layoutRemoved:new Q,layoutRenamed:new Q,layoutSwitched:new Q}}countLayouts(t){return this.getWorkingDatabase(t).objects.layout.numEntries}findLayoutNamed(t,e){return this.getWorkingDatabase(e).objects.layout.getAt(t)}findActiveLayout(){const t=this.getActiveLayout();return t?t.layoutName:"Model"}setCurrentLayoutId(t,e){const s=this.getWorkingDatabase(e),n=s.objects.layout.getIdAt(t);return this.setCurrentLayoutInternal(n,s)}setCurrentLayoutBtrId(t,e){const s=this.getWorkingDatabase(e),n=s.objects.layout.getBtrIdAt(t);return this.setCurrentLayoutInternal(n,s)}setCurrentLayout(t,e){const s=this.getWorkingDatabase(e),n=s.objects.layout.getAt(t);return this.setCurrentLayoutInternal(n,s)}renameLayout(t,e,s){const r=this.getWorkingDatabase(s).objects.layout.getAt(t);return r?(r.layoutName=e,this.events.layoutRenamed.dispatch({layout:r,oldName:t,newName:e}),!0):!1}layoutExists(t,e){return this.getWorkingDatabase(e).objects.layout.has(t)}deleteLayout(t,e){const s=this.getWorkingDatabase(e).objects.layout,n=s.getAt(t);let r=!1;return n&&(r=s.remove(t),r&&this.events.layoutRemoved.dispatch({layout:n})),r}createLayout(t,e){const s=this.getWorkingDatabase(e),n=new ii;n.layoutName=t,n.tabOrder=s.objects.layout.maxTabOrder;const r=new J;return r.name=`*Paper_Space${n.tabOrder}`,s.tables.blockTable.add(r),s.objects.layout.setAt(t,n),this.events.layoutCreated.dispatch({layout:n}),{layout:n,btr:r}}getActiveLayout(t){const e=this.getWorkingDatabase(t);return e.objects.layout.getBtrIdAt(e.currentSpaceId)}getWorkingDatabase(t){return t||tr().workingDatabase}setCurrentLayoutInternal(t,e){return t?(this.events.layoutSwitched.dispatch({layout:t}),e.currentSpaceId=t.blockTableRecordId,!0):!1}}sa(()=>new ul);class fr extends Ft{constructor(){super(),this._contentType=2,this._drawMLeaderOrderType=1,this._drawLeaderOrderType=0,this._bitFlags=0,this._maxLeaderSegmentsPoints=-1,this._firstSegmentAngleConstraint=0,this._secondSegmentAngleConstraint=0,this._leaderLineType=1,this._leaderLineColor=new j(P.ByLayer),this._leaderLineWeight=-2,this._enableLanding=!0,this._landingGap=2,this._enableDogleg=!0,this._doglegLength=8,this._description="",this._arrowSize=4,this._defaultMTextContents="",this._textLeftAttachmentType=1,this._textAngleType=1,this._textAlignmentType=0,this._textRightAttachmentType=1,this._textColor=new j(P.ByLayer),this._textHeight=4,this._enableFrameText=!1,this._textAlignAlwaysLeft=!1,this._alignSpace=0,this._blockColor=new j(P.ByBlock),this._blockScale=new _(1,1,1),this._enableBlockScale=!0,this._blockRotation=0,this._enableBlockRotation=!1,this._blockConnectionType=0,this._scale=1,this._overwritePropChanged=!1,this._annotative=!1,this._breakSize=0,this._textAttachmentDirection=0,this._bottomTextAttachmentType=9,this._topTextAttachmentType=9,this._extendLeaderToText=!1}get unknown1(){return this._unknown1}set unknown1(t){this._unknown1=t}get contentType(){return this._contentType}set contentType(t){this._contentType=t}get drawMLeaderOrderType(){return this._drawMLeaderOrderType}set drawMLeaderOrderType(t){this._drawMLeaderOrderType=t}get drawLeaderOrderType(){return this._drawLeaderOrderType}set drawLeaderOrderType(t){this._drawLeaderOrderType=t}get bitFlags(){return this._bitFlags}set bitFlags(t){this._bitFlags=t}get maxLeaderSegmentsPoints(){return this._maxLeaderSegmentsPoints}set maxLeaderSegmentsPoints(t){this._maxLeaderSegmentsPoints=t}get maxLeaderSegmentPoints(){return this.maxLeaderSegmentsPoints}set maxLeaderSegmentPoints(t){this.maxLeaderSegmentsPoints=t}get firstSegmentAngleConstraint(){return this._firstSegmentAngleConstraint}set firstSegmentAngleConstraint(t){this._firstSegmentAngleConstraint=t}get secondSegmentAngleConstraint(){return this._secondSegmentAngleConstraint}set secondSegmentAngleConstraint(t){this._secondSegmentAngleConstraint=t}get leaderLineType(){return this._leaderLineType}set leaderLineType(t){this._leaderLineType=t}get leaderLineColor(){return this._leaderLineColor}set leaderLineColor(t){this._leaderLineColor.copy(t)}get leaderLineTypeId(){return this._leaderLineTypeId}set leaderLineTypeId(t){this._leaderLineTypeId=t}get leaderLineWeight(){return this._leaderLineWeight}set leaderLineWeight(t){this._leaderLineWeight=t}get enableLanding(){return this._enableLanding}set enableLanding(t){this._enableLanding=t}get landingEnabled(){return this.enableLanding}set landingEnabled(t){this.enableLanding=t}get landingGap(){return this._landingGap}set landingGap(t){this._landingGap=t}get enableDogleg(){return this._enableDogleg}set enableDogleg(t){this._enableDogleg=t}get doglegEnabled(){return this.enableDogleg}set doglegEnabled(t){this.enableDogleg=t}get doglegLength(){return this._doglegLength}set doglegLength(t){this._doglegLength=t}get description(){return this._description}set description(t){this._description=t}get arrowSymbolId(){return this._arrowSymbolId}set arrowSymbolId(t){this._arrowSymbolId=t}get arrowheadId(){return this.arrowSymbolId}set arrowheadId(t){this.arrowSymbolId=t}get arrowSize(){return this._arrowSize}set arrowSize(t){this._arrowSize=t}get arrowheadSize(){return this.arrowSize}set arrowheadSize(t){this.arrowSize=t}get defaultMTextContents(){return this._defaultMTextContents}set defaultMTextContents(t){this._defaultMTextContents=t}get defaultMText(){return this.defaultMTextContents}set defaultMText(t){this.defaultMTextContents=t}get textString(){return this.defaultMTextContents}set textString(t){this.defaultMTextContents=t}get textStyleId(){return this._textStyleId}set textStyleId(t){this._textStyleId=t}get textStyle(){return this.textStyleId}set textStyle(t){this.textStyleId=t}get textLeftAttachmentType(){return this._textLeftAttachmentType}set textLeftAttachmentType(t){this._textLeftAttachmentType=t}get textAngleType(){return this._textAngleType}set textAngleType(t){this._textAngleType=t}get textAlignmentType(){return this._textAlignmentType}set textAlignmentType(t){this._textAlignmentType=t}get textRightAttachmentType(){return this._textRightAttachmentType}set textRightAttachmentType(t){this._textRightAttachmentType=t}get textColor(){return this._textColor}set textColor(t){this._textColor.copy(t)}get textHeight(){return this._textHeight}set textHeight(t){this._textHeight=t}get enableFrameText(){return this._enableFrameText}set enableFrameText(t){this._enableFrameText=t}get textFrameEnabled(){return this.enableFrameText}set textFrameEnabled(t){this.enableFrameText=t}get textAlignAlwaysLeft(){return this._textAlignAlwaysLeft}set textAlignAlwaysLeft(t){this._textAlignAlwaysLeft=t}get alignSpace(){return this._alignSpace}set alignSpace(t){this._alignSpace=t}get blockId(){return this._blockId}set blockId(t){this._blockId=t}get blockContentId(){return this.blockId}set blockContentId(t){this.blockId=t}get blockColor(){return this._blockColor}set blockColor(t){this._blockColor.copy(t)}get blockContentColor(){return this.blockColor}set blockContentColor(t){this.blockColor=t}get blockScale(){return this._blockScale.clone()}set blockScale(t){this._blockScale.copy(t)}get blockContentScale(){return this.blockScale}set blockContentScale(t){this.blockScale=t}get enableBlockScale(){return this._enableBlockScale}set enableBlockScale(t){this._enableBlockScale=t}get blockContentScaleEnabled(){return this.enableBlockScale}set blockContentScaleEnabled(t){this.enableBlockScale=t}get blockRotation(){return this._blockRotation}set blockRotation(t){this._blockRotation=t}get blockContentRotation(){return this.blockRotation}set blockContentRotation(t){this.blockRotation=t}get enableBlockRotation(){return this._enableBlockRotation}set enableBlockRotation(t){this._enableBlockRotation=t}get blockContentRotationEnabled(){return this.enableBlockRotation}set blockContentRotationEnabled(t){this.enableBlockRotation=t}get blockConnectionType(){return this._blockConnectionType}set blockConnectionType(t){this._blockConnectionType=t}get blockContentConnectionType(){return this.blockConnectionType}set blockContentConnectionType(t){this.blockConnectionType=t}get scale(){return this._scale}set scale(t){this._scale=t}get scaleFactor(){return this.scale}set scaleFactor(t){this.scale=t}get overwritePropChanged(){return this._overwritePropChanged}set overwritePropChanged(t){this._overwritePropChanged=t}get overwritePropertyValue(){return this.overwritePropChanged}set overwritePropertyValue(t){this.overwritePropChanged=t}get annotative(){return this._annotative}set annotative(t){this._annotative=t}get breakSize(){return this._breakSize}set breakSize(t){this._breakSize=t}get breakGapSize(){return this.breakSize}set breakGapSize(t){this.breakSize=t}get textAttachmentDirection(){return this._textAttachmentDirection}set textAttachmentDirection(t){this._textAttachmentDirection=t}get bottomTextAttachmentType(){return this._bottomTextAttachmentType}set bottomTextAttachmentType(t){this._bottomTextAttachmentType=t}get bottomTextAttachmentDirection(){return this.bottomTextAttachmentType}set bottomTextAttachmentDirection(t){this.bottomTextAttachmentType=t}get topTextAttachmentType(){return this._topTextAttachmentType}set topTextAttachmentType(t){this._topTextAttachmentType=t}get topTextAttachmentDirection(){return this.topTextAttachmentType}set topTextAttachmentDirection(t){this.topTextAttachmentType=t}get extendLeaderToText(){return this._extendLeaderToText}set extendLeaderToText(t){this._extendLeaderToText=t}get unknown2(){return this._unknown2}set unknown2(t){this._unknown2=t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbMLeaderStyle"),t.writeInt16(179,this.unknown1),t.writeInt16(170,this.contentType),t.writeInt16(171,this.drawMLeaderOrderType),t.writeInt16(172,this.drawLeaderOrderType),t.writeInt32(90,this.maxLeaderSegmentsPoints),t.writeDouble(40,this.firstSegmentAngleConstraint),t.writeDouble(41,this.secondSegmentAngleConstraint),t.writeInt16(173,this.leaderLineType),t.writeInt32(91,Ti(this.leaderLineColor)),t.writeHandle(340,this.leaderLineTypeId),t.writeInt32(92,this.leaderLineWeight),t.writeBoolean(290,this.enableLanding),t.writeDouble(42,this.landingGap),t.writeBoolean(291,this.enableDogleg),t.writeDouble(43,this.doglegLength),t.writeString(3,this.description),t.writeHandle(341,this.arrowSymbolId),t.writeDouble(44,this.arrowSize),t.writeString(300,this.defaultMTextContents),t.writeHandle(342,this.textStyleId),t.writeInt16(174,this.textLeftAttachmentType),t.writeInt16(175,this.textAngleType),t.writeInt16(176,this.textAlignmentType),t.writeInt16(178,this.textRightAttachmentType),t.writeInt32(93,Ti(this.textColor)),t.writeDouble(45,this.textHeight),t.writeBoolean(292,this.enableFrameText),t.writeBoolean(297,this.textAlignAlwaysLeft),t.writeDouble(46,this.alignSpace),t.writeHandle(343,this.blockId),t.writeInt32(94,Ti(this.blockColor)),t.writeDouble(47,this._blockScale.x),t.writeDouble(49,this._blockScale.y),t.writeDouble(140,this._blockScale.z),t.writeBoolean(293,this.enableBlockScale),t.writeDouble(141,this.blockRotation),t.writeBoolean(294,this.enableBlockRotation),t.writeInt16(177,this.blockConnectionType),t.writeDouble(142,this.scale),t.writeBoolean(295,this.overwritePropChanged),t.writeBoolean(296,this.annotative),t.writeDouble(143,this.breakSize),t.writeInt16(271,this.textAttachmentDirection),t.writeInt16(272,this.bottomTextAttachmentType),t.writeInt16(273,this.topTextAttachmentType),t.writeBoolean(298,this.unknown2),this}}class Sr extends Ft{constructor(){super(),this._styleName="STANDARD",this._flags=0,this._description="",this._fillColor=new j,this._startAngle=90,this._endAngle=90,this._elements=[]}get styleName(){return this._styleName}set styleName(t){this._styleName=t}get flags(){return this._flags}set flags(t){this._flags=t}get description(){return this._description}set description(t){this._description=t}get fillColor(){return this._fillColor}set fillColor(t){this._fillColor.copy(t)}get startAngle(){return this._startAngle}set startAngle(t){this._startAngle=t}get endAngle(){return this._endAngle}set endAngle(t){this._endAngle=t}get elementCount(){return this._elements.length}get elements(){return this._elements.map(t=>({offset:t.offset,color:t.color.clone(),lineType:t.lineType}))}set elements(t){this._elements=t.map(e=>({offset:e.offset,color:e.color.clone(),lineType:e.lineType}))}addElement(t){this._elements.push({offset:t.offset,color:t.color.clone(),lineType:t.lineType})}removeElementAt(t){if(t<0||t>=this._elements.length)throw new Error("The element index is out of range!");this._elements.splice(t,1)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbMlineStyle"),t.writeString(2,this.styleName),t.writeInt16(70,this.flags),t.writeString(3,this.description),t.writeCmColor(this.fillColor),t.writeDouble(51,this.startAngle),t.writeDouble(52,this.endAngle),t.writeInt16(71,this.elementCount),this._elements.forEach(e=>{t.writeDouble(49,e.offset),t.writeCmColor(e.color),t.writeString(6,e.lineType)}),this}}class gl extends Ft{constructor(){super(),this._sourceFileName=""}get sourceFileName(){return this._sourceFileName}set sourceFileName(t){this._sourceFileName=t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbRasterImageDef"),t.writeString(1,this.sourceFileName),t.writeInt16(280,1),t.writeInt16(281,0),this}}var pl=(i=>(i[i.NotApplicable=0]="NotApplicable",i[i.Ignore=1]="Ignore",i[i.Replace=2]="Replace",i[i.XrefMangleName=3]="XrefMangleName",i[i.MangleName=4]="MangleName",i))(pl||{});class Gc extends Ft{constructor(){super(...arguments),this._data=null}get data(){return this._data}set data(t){this._data=t}clear(){var t;(t=this._data)==null||t.clear()}clone(){return super.clone()}getDuplicateRecordCloning(){return 0}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbXrecord"),t.writeInt16(280,1),t.writeResultBuffer(this.data),this}}class ml{constructor(t){this.db=t}createDefaultLayer(){const t=new j;return t.colorIndex=7,this.db.tables.layerTable.add(new mn({name:"0",standardFlags:0,linetype:"Continuous",lineWeight:0,isOff:!1,color:t,isPlottable:!0}))}createDefaultLineType(){this.db.tables.linetypeTable.add(new Ae({name:"ByBlock",standardFlag:0,description:"",totalPatternLength:0})),this.db.tables.linetypeTable.add(new Ae({name:"ByLayer",standardFlag:0,description:"",totalPatternLength:0})),this.db.tables.linetypeTable.add(new Ae({name:"Continuous",standardFlag:0,description:"Solid line",totalPatternLength:0}))}createDefaultTextStyle(){this.db.tables.textStyleTable.add(new yn({name:Z,standardFlag:0,fixedTextHeight:0,widthFactor:1,obliqueAngle:0,textGenerationFlag:0,lastHeight:.2,font:"SimKai",bigFont:"",extendedFont:"SimKai"}))}createDefaultDimStyle(){this.db.tables.dimStyleTable.add(new ts({name:Z,dimtxsty:Z}))}createDefaultLayout(){const t=new ii;t.layoutName="Model",t.tabOrder=0,t.blockTableRecordId=this.db.tables.blockTable.modelSpace.objectId,t.limits.min.copy({x:0,y:0}),t.limits.max.copy({x:1e6,y:1e6}),t.extents.min.copy({x:0,y:0,z:0}),t.extents.max.copy({x:1e6,y:1e6,z:0}),this.db.objects.layout.setAt(t.layoutName,t),this.db.tables.blockTable.modelSpace.layoutId=t.objectId}createArrowBlock(){if(!this.db.tables.blockTable.getAt("_CAXARROW")){const e=new Us;e.patternName="SOLID";const s=new Gs;s.add(new Wt({x:0,y:0},{x:-1,y:.125})),s.add(new Wt({x:-1,y:.125},{x:-1,y:-.125})),s.add(new Wt({x:-1,y:-.125},{x:0,y:0})),e.add(s);const n=new J;n.name="_CAXARROW",n.appendEntity(e),this.db.tables.blockTable.add(n)}}}var yl=(i=>(i.ClosedFilled="",i.Dot="_DOT",i.DotSmall="_DOTSMALL",i.DotBlank="_DOTBLANK",i.Origin="_ORIGIN",i.Origin2="_ORIGIN2",i.Open="_OPEN",i.Open90="_OPEN90",i.Open30="_OPEN30",i.Closed="_CLOSED",i.Small="_SMALL",i.None="_NONE",i.Oblique="_OBLIQUE",i.BoxFilled="_BOXFILLED",i.Box="_BOXBLANK",i.ClosedBlank="_CLOSEDBLANK",i.DatumBlank="_DATUMBLANK",i.DatumFilled="_DATUMFILLED",i.Integral="_INTEGRAL",i.ArchTick="_ARCHTICK",i))(yl||{});const Ir=192,ln=193,Ar=194,Pr=195,_l=200;function Ti(i){if(i.isByBlock)return ln<<24>>0;if(i.isByLayer)return Ir<<24>>0;const t=i.colorIndex;if(t!=null&&t>0&&t<256)return(Pr<<24|t&255)>>0;const e=i.RGB;return e!=null?(Ar<<24|e&16777215)>>0:ln<<24>>0}function zs(i){const t=new j(P.ByBlock);switch(i>>>24&255){case Ir:t.setByLayer();break;case ln:case _l:t.setByBlock();break;case Pr:t.colorIndex=i&255;break;case Ar:t.setRGBValue(i&16777215);break;default:i>=0&&i<=256&&(t.colorIndex=i);break}return t}var Tr=(i=>(i[i.Undefined=0]="Undefined",i[i.Inches=1]="Inches",i[i.Feet=2]="Feet",i[i.Miles=3]="Miles",i[i.Millimeters=4]="Millimeters",i[i.Centimeters=5]="Centimeters",i[i.Meters=6]="Meters",i[i.Kilometers=7]="Kilometers",i[i.Microinches=8]="Microinches",i[i.Mils=9]="Mils",i[i.Yards=10]="Yards",i[i.Angstroms=11]="Angstroms",i[i.Nanometers=12]="Nanometers",i[i.Microns=13]="Microns",i[i.Decimeters=14]="Decimeters",i[i.Dekameters=15]="Dekameters",i[i.Hectometers=16]="Hectometers",i[i.Gigameters=17]="Gigameters",i[i.Astronomical=18]="Astronomical",i[i.LightYears=19]="LightYears",i[i.Parsecs=20]="Parsecs",i[i.USSurveyFeet=21]="USSurveyFeet",i[i.USSurveyInch=22]="USSurveyInch",i[i.USSurveyYard=23]="USSurveyYard",i[i.USSurveyMile=24]="USSurveyMile",i[i.Max=24]="Max",i))(Tr||{});function Uc(i){return i==4||i==5||i==6||i==7||i==12||i==13||i==14||i==15||i==16||i==17}function Yc(i){return i==1||i==2||i==3||i==8||i==9||i==10||i==21}class pe extends Ft{constructor(t){super(),this.database=t,this.objectId=t.generateHandle(),this.ownerId=t.objectId,this._recordsByName=new Map,this._recordsById=new Map}get numEntries(){return this._recordsByName.size}add(t){t.database=this.database,t.ownerId=this.objectId,this.database.commitObjectHandle(t,s=>this.hasId(s));const e=this.normalizeName(t.name);this._recordsByName.set(e,t),this._recordsById.set(t.objectId,t)}remove(t){const e=this.normalizeName(t),s=this._recordsByName.get(e);return s?(this._recordsById.delete(s.objectId),this._recordsByName.delete(e),!0):!1}removeId(t){const e=this._recordsById.get(t);return e?(this._recordsByName.delete(this.normalizeName(e.name)),this._recordsById.delete(t),!0):!1}removeAll(){this._recordsByName.clear(),this._recordsById.clear()}has(t){const e=this.normalizeName(t);return this._recordsByName.has(e)}hasId(t){return this._recordsById.has(t)}getAt(t){const e=this.normalizeName(t);return this._recordsByName.get(e)}getIdAt(t){return this._recordsById.get(t)}getOwnerIdAt(t){return this._recordsById.get(t)}newIterator(){return new ni(this._recordsByName)}normalizeName(t){return t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbSymbolTable"),t.writeInt16(70,this.numEntries),this}}class xl extends pe{constructor(t){super(t)}get modelSpace(){let t=this.getAt(J.MODEL_SPACE_NAME);return t||(t=new J,t.name=J.MODEL_SPACE_NAME,this.add(t)),t}getEntityById(t){for(const e of this.database.tables.blockTable.newIterator()){const s=e.getIdAt(t);if(s)return s}}removeEntity(t){let e=!1;for(const s of this.database.tables.blockTable.newIterator())if(s.removeEntity(t)){e=!0;break}return e}normalizeName(t){let e=t;if(J.isModelSapceName(t))e=J.MODEL_SPACE_NAME;else if(J.isPaperSapceName(t)){const s=J.PAPER_SPACE_NAME_PREFIX,n=t.substring(s.length);e=s+n}return e}}class wl extends pe{constructor(t){super(t)}}var bl=(i=>(i[i.Center=0]="Center",i[i.Left=1]="Left",i[i.Right=2]="Right",i[i.OverFirst=3]="OverFirst",i[i.OverSecond=4]="OverSecond",i))(bl||{}),fl=(i=>(i[i.Center=0]="Center",i[i.Above=1]="Above",i[i.Outside=2]="Outside",i[i.JIS=3]="JIS",i[i.Below=4]="Below",i))(fl||{}),Sl=(i=>(i[i.Feet=0]="Feet",i[i.None=1]="None",i[i.Inch=2]="Inch",i[i.FeetAndInch=3]="FeetAndInch",i[i.Leading=4]="Leading",i[i.Trailing=8]="Trailing",i[i.LeadingAndTrailing=12]="LeadingAndTrailing",i))(Sl||{}),Il=(i=>(i[i.None=0]="None",i[i.Leading=1]="Leading",i[i.Trailing=2]="Trailing",i[i.LeadingAndTrailing=3]="LeadingAndTrailing",i))(Il||{}),Al=(i=>(i[i.Bottom=0]="Bottom",i[i.Middle=1]="Middle",i[i.Top=2]="Top",i))(Al||{});const dn=class dn extends Me{constructor(t,e){t=t||{},Qs(t,dn.DEFAULT_DIM_VALUES),super(t,e)}get dimpost(){return this.getAttr("dimpost")}set dimpost(t){this.setAttr("dimpost",t)}get dimapost(){return this.getAttr("dimapost")}set dimapost(t){this.setAttr("dimapost",t)}get dimscale(){return this.getAttr("dimscale")}set dimscale(t){this.setAttr("dimscale",t)}get dimasz(){return this.getAttr("dimasz")}set dimasz(t){this.setAttr("dimasz",t)}get dimexo(){return this.getAttr("dimexo")}set dimexo(t){this.setAttr("dimexo",t)}get dimdli(){return this.getAttr("dimdli")}set dimdli(t){this.setAttr("dimdli",t)}get dimexe(){return this.getAttr("dimexe")}set dimexe(t){this.setAttr("dimexe",t)}get dimrnd(){return this.getAttr("dimrnd")}set dimrnd(t){this.setAttr("dimrnd",t)}get dimdle(){return this.getAttr("dimdle")}set dimdle(t){this.setAttr("dimdle",t)}get dimtp(){return this.getAttr("dimtp")}set dimtp(t){this.setAttr("dimtp",t)}get dimtm(){return this.getAttr("dimtm")}set dimtm(t){this.setAttr("dimtm",t)}get dimtxt(){return this.getAttr("dimtxt")}set dimtxt(t){this.setAttr("dimtxt",t)}get dimcen(){return this.getAttr("dimcen")}set dimcen(t){this.setAttr("dimcen",t)}get dimtsz(){return this.getAttr("dimtsz")}set dimtsz(t){this.setAttr("dimtsz",t)}get dimaltf(){return this.getAttr("dimaltf")}set dimaltf(t){this.setAttr("dimaltf",t)}get dimlfac(){return this.getAttr("dimlfac")}set dimlfac(t){this.setAttr("dimlfac",t)}get dimtvp(){return this.getAttr("dimtvp")}set dimtvp(t){this.setAttr("dimtvp",t)}get dimtfac(){return this.getAttr("dimtfac")}set dimtfac(t){this.setAttr("dimtfac",t)}get dimgap(){return this.getAttr("dimgap")}set dimgap(t){this.setAttr("dimgap",t)}get dimaltrnd(){return this.getAttr("dimaltrnd")}set dimaltrnd(t){this.setAttr("dimaltrnd",t)}get dimtol(){return this.getAttr("dimtol")}set dimtol(t){this.setAttr("dimtol",t)}get dimlim(){return this.getAttr("dimlim")}set dimlim(t){this.setAttr("dimlim",t)}get dimtih(){return this.getAttr("dimtih")}set dimtih(t){this.setAttr("dimtih",t)}get dimtoh(){return this.getAttr("dimtoh")}set dimtoh(t){this.setAttr("dimtoh",t)}get dimse1(){return this.getAttr("dimse1")}set dimse1(t){this.setAttr("dimse1",t)}get dimse2(){return this.getAttr("dimse2")}set dimse2(t){this.setAttr("dimse2",t)}get dimtad(){return this.getAttr("dimtad")}set dimtad(t){this.setAttr("dimtad",t)}get dimzin(){return this.getAttr("dimzin")}set dimzin(t){this.setAttr("dimzin",t)}get dimazin(){return this.getAttr("dimazin")}set dimazin(t){this.setAttr("dimazin",t)}get dimalt(){return this.getAttr("dimalt")}set dimalt(t){this.setAttr("dimalt",t)}get dimaltd(){return this.getAttr("dimaltd")}set dimaltd(t){this.setAttr("dimaltd",t)}get dimtofl(){return this.getAttr("dimtofl")}set dimtofl(t){this.setAttr("dimtofl",t)}get dimsah(){return this.getAttr("dimsah")}set dimsah(t){this.setAttr("dimsah",t)}get dimtix(){return this.getAttr("dimtix")}set dimtix(t){this.setAttr("dimtix",t)}get dimsoxd(){return this.getAttr("dimsoxd")}set dimsoxd(t){this.setAttr("dimsoxd",t)}get dimclrd(){return this.getAttr("dimclrd")}set dimclrd(t){this.setAttr("dimclrd",t)}get dimclre(){return this.getAttr("dimclre")}set dimclre(t){this.setAttr("dimclre",t)}get dimclrt(){return this.getAttr("dimclrt")}set dimclrt(t){this.setAttr("dimclrt",t)}get dimadec(){return this.getAttr("dimadec")}set dimadec(t){this.setAttr("dimadec",t)}get dimunit(){return this.getAttr("dimunit")}set dimunit(t){this.setAttr("dimunit",t)}get dimdec(){return this.getAttr("dimdec")}set dimdec(t){this.setAttr("dimdec",t)}get dimtdec(){return this.getAttr("dimtdec")}set dimtdec(t){this.setAttr("dimtdec",t)}get dimaltu(){return this.getAttr("dimaltu")}set dimaltu(t){this.setAttr("dimaltu",t)}get dimalttd(){return this.getAttr("dimalttd")}set dimalttd(t){this.setAttr("dimalttd",t)}get dimaunit(){return this.getAttr("dimaunit")}set dimaunit(t){this.setAttr("dimaunit",t)}get dimfrac(){return this.getAttr("dimfrac")}set dimfrac(t){this.setAttr("dimfrac",t)}get dimlunit(){return this.getAttr("dimlunit")}set dimlunit(t){this.setAttr("dimlunit",t)}get dimdsep(){return this.getAttr("dimdsep")}set dimdsep(t){this.setAttr("dimdsep",t)}get dimtmove(){return this.getAttr("dimtmove")}set dimtmove(t){this.setAttr("dimtmove",t)}get dimjust(){return this.getAttr("dimjust")}set dimjust(t){this.setAttr("dimjust",t)}get dimsd1(){return this.getAttr("dimsd1")}set dimsd1(t){this.setAttr("dimsd1",t)}get dimsd2(){return this.getAttr("dimsd2")}set dimsd2(t){this.setAttr("dimsd2",t)}get dimtolj(){return this.getAttr("dimtolj")}set dimtolj(t){this.setAttr("dimtolj",t)}get dimtzin(){return this.getAttr("dimtzin")}set dimtzin(t){this.setAttr("dimtzin",t)}get dimaltz(){return this.getAttr("dimaltz")}set dimaltz(t){this.setAttr("dimaltz",t)}get dimalttz(){return this.getAttr("dimalttz")}set dimalttz(t){this.setAttr("dimalttz",t)}get dimfit(){return this.getAttr("dimfit")}set dimfit(t){this.setAttr("dimfit",t)}get dimupt(){return this.getAttr("dimupt")}set dimupt(t){this.setAttr("dimupt",t)}get dimatfit(){return this.getAttr("dimatfit")}set dimatfit(t){this.setAttr("dimatfit",t)}get dimtxsty(){return this.getAttr("dimtxsty")}set dimtxsty(t){this.setAttr("dimtxsty",t)}get dimldrblk(){return this.getAttr("dimldrblk")}set dimldrblk(t){this.setAttr("dimldrblk",t)}get dimblk(){return this.getAttr("dimblk")}set dimblk(t){this.setAttr("dimblk",t)}get dimblk1(){return this.getAttr("dimblk1")}set dimblk1(t){this.setAttr("dimblk1",t)}get dimblk2(){return this.getAttr("dimblk2")}set dimblk2(t){this.setAttr("dimblk2",t)}get dimlwd(){return this.getAttr("dimlwd")}set dimlwd(t){this.setAttr("dimlwd",t)}get dimlwe(){return this.getAttr("dimlwe")}set dimlwe(t){this.setAttr("dimlwe",t)}dxfOutFields(t){super.dxfOutFields(t);const e=this.database.tables.textStyleTable.getAt(this.dimtxsty),s=this.database.tables.blockTable.getAt(this.dimldrblk),n=this.database.tables.blockTable.getAt(this.dimblk),r=this.database.tables.blockTable.getAt(this.dimblk1),o=this.database.tables.blockTable.getAt(this.dimblk2);return t.writeSubclassMarker("AcDbDimStyleTableRecord"),t.writeString(2,this.name),t.writeInt16(70,0),t.writeString(3,this.dimpost),t.writeString(4,this.dimapost),t.writeDouble(40,this.dimscale),t.writeDouble(41,this.dimasz),t.writeDouble(42,this.dimexo),t.writeDouble(43,this.dimdli),t.writeDouble(44,this.dimexe),t.writeDouble(140,this.dimtxt),t.writeDouble(147,this.dimgap),t.writeInt16(170,this.dimalt),t.writeInt16(171,this.dimtol),t.writeInt16(172,this.dimlim),t.writeInt16(173,this.dimtih),t.writeInt16(174,this.dimtoh),t.writeObjectId(340,e==null?void 0:e.objectId),t.writeObjectId(341,s==null?void 0:s.objectId),t.writeObjectId(342,n==null?void 0:n.objectId),t.writeObjectId(343,r==null?void 0:r.objectId),t.writeObjectId(344,o==null?void 0:o.objectId),t.writeInt16(371,this.dimlwd),t.writeInt16(372,this.dimlwe),this}};dn.DEFAULT_DIM_VALUES={name:"",dimpost:"",dimapost:"",dimscale:1,dimasz:2.5,dimexo:.625,dimdli:.38,dimexe:.18,dimrnd:0,dimdle:0,dimtp:0,dimtm:0,dimtxt:2.5,dimcen:2.5,dimtsz:0,dimaltf:0,dimlfac:1,dimtvp:0,dimtfac:1,dimgap:1,dimaltrnd:0,dimtol:0,dimlim:0,dimtih:0,dimtoh:0,dimse1:0,dimse2:0,dimtad:0,dimzin:0,dimazin:0,dimalt:0,dimaltd:2,dimtofl:0,dimsah:0,dimtix:0,dimsoxd:0,dimclrd:0,dimclre:0,dimclrt:0,dimadec:0,dimunit:2,dimdec:4,dimtdec:4,dimaltu:2,dimalttd:2,dimaunit:0,dimfrac:0,dimlunit:2,dimdsep:".",dimtmove:0,dimjust:0,dimsd1:0,dimsd2:0,dimtolj:0,dimtzin:0,dimaltz:0,dimalttz:0,dimfit:0,dimupt:0,dimatfit:3,dimtxsty:Z,dimldrblk:"",dimblk:"",dimblk1:"",dimblk2:"",dimlwd:-2,dimlwe:-2};let ts=dn;class Pl extends pe{constructor(t){super(t)}add(t){super.add(t),this.database.events.layerAppended.dispatch({database:this.database,layer:t})}}class mn extends Me{constructor(t,e){t=t||{},Qs(t,{color:new j,description:"",standardFlags:0,isHidden:!1,isInUse:!0,isOff:!1,isPlottable:!0,transparency:new gn,linetype:"",lineWeight:1,materialId:-1}),super(t,e),this.attrs.events.attrChanged.addEventListener(s=>{this.database.events.layerModified.dispatch({database:this.database,layer:this,changes:s.object.changedAttributes()})})}get color(){return this.getAttr("color")}set color(t){this.setAttr("color",t.clone())}get description(){return this.getAttr("description")}set description(t){this.setAttr("description",t)}get standardFlags(){return this.getAttr("standardFlags")}set standardFlags(t){this.setAttr("standardFlags",t)}get isFrozen(){return(this.standardFlags&1)==1}set isFrozen(t){const e=t?1:0;this.standardFlags=this.standardFlags|e}get isHidden(){return this.getAttr("isHidden")}set isHidden(t){this.setAttr("isHidden",t)}get isInUse(){return this.getAttr("isInUse")}set isInUse(t){this.setAttr("isInUse",t)}get isLocked(){return(this.standardFlags&4)==4}set isLocked(t){const e=t?4:0;this.standardFlags=this.standardFlags|e}get isOff(){return this.getAttr("isOff")}set isOff(t){this.setAttr("isOff",t)}get isPlottable(){return this.getAttr("isPlottable")}set isPlottable(t){this.setAttr("isPlottable",t)}get transparency(){return this.getAttr("transparency")}set transparency(t){this.setAttr("transparency",t.clone())}get linetype(){return this.getAttr("linetype")}set linetype(t){this.setAttr("linetype",t)}get lineStyle(){var e;const t=(e=this.database)==null?void 0:e.tables.linetypeTable.getAt(this.linetype);if(t)return{type:"UserSpecified",...t.linetype}}get lineWeight(){return this.getAttr("lineWeight")}set lineWeight(t){this.setAttr("lineWeight",t)}get materialId(){return this.getAttr("materialId")}set materialId(t){this.setAttr("materialId",t)}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbLayerTableRecord"),t.writeString(2,this.name),t.writeInt16(70,this.standardFlags),t.writeCmColor(this.color),t.writeString(6,this.linetype),t.writeInt16(290,this.isPlottable?1:0),t.writeInt16(370,this.lineWeight),t.writeTransparency(this.transparency),this.description&&t.writeString(4,this.description),this}}class Tl extends pe{constructor(t){super(t)}}class Ae extends Me{constructor(t){super(),this.name=t.name,this._linetype=t}get numDashes(){return this._linetype.pattern?this._linetype.pattern.length:0}get patternLength(){return this._linetype.totalPatternLength}get comments(){return this._linetype.description}get linetype(){return this._linetype}dashLengthAt(t){if(t<0||t>=this.numDashes)throw new Error('Index must be greater than or equal to zero, but less than the value of property "numDashes".');return this._linetype.pattern[t].elementLength}toPreviewSvgString(t){const e=Math.max((t==null?void 0:t.width)??220,1),s=Math.max((t==null?void 0:t.height)??36,1),n=Math.min(Math.max((t==null?void 0:t.padding)??8,0),Math.floor(e/2)),r=Math.max((t==null?void 0:t.strokeWidth)??2,.5),o=this.escapeSvgAttribute((t==null?void 0:t.stroke)??"currentColor"),a=Math.max((t==null?void 0:t.repeats)??4,1),h=s/2,c=n,d=Math.max(e-n,c+1),u=d-c,p=this._linetype.pattern??[];if(p.length===0||this.patternLength<=0||!p.some(S=>S.elementLength!==0))return this.buildSvgString({width:e,height:s,stroke:o,strokeWidth:r,lineSegments:[[c,d]],dots:[],y:h});const g=[],m=[],y=u/(this.patternLength*a),b=.5,x=Math.max(r*2,2);let I=c;for(;I<d;)for(const S of p){if(I>=d)break;const L=S.elementLength;if(L===0){m.push(I),I=Math.min(I+x,d);continue}const A=Math.max(Math.abs(L)*y,b),H=Math.min(I+A,d);L>0&&H>I&&g.push([I,H]),I=H}return this.buildSvgString({width:e,height:s,stroke:o,strokeWidth:r,lineSegments:g,dots:m,y:h})}buildSvgString(t){const{width:e,height:s,stroke:n,strokeWidth:r,lineSegments:o,dots:a,y:h}=t,c=o.map(([u,p])=>`<line x1="${u.toFixed(2)}" y1="${h.toFixed(2)}" x2="${p.toFixed(2)}" y2="${h.toFixed(2)}" stroke="${n}" stroke-width="${r.toFixed(2)}" stroke-linecap="round" />`).join(""),d=a.map(u=>`<circle cx="${u.toFixed(2)}" cy="${h.toFixed(2)}" r="${(r/2).toFixed(2)}" fill="${n}" />`).join("");return`<svg xmlns="http://www.w3.org/2000/svg" width="${e}" height="${s}" viewBox="0 0 ${e} ${s}" role="img" aria-label="${this.escapeSvgAttribute(this.name)} linetype preview">${c}${d}</svg>`}escapeSvgAttribute(t){return t.replace(/&/g,"&amp;").replace(/"/g,"&quot;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/'/g,"&#39;")}dxfOutFields(t){super.dxfOutFields(t),t.writeSubclassMarker("AcDbLinetypeTableRecord"),t.writeString(2,this.name),t.writeInt16(70,this.linetype.standardFlag),t.writeString(3,this.comments),t.writeInt16(72,65),t.writeInt16(73,this.numDashes),t.writeDouble(40,this.patternLength);for(const e of this.linetype.pattern??[])t.writeDouble(49,e.elementLength),t.writeInt16(74,e.elementTypeFlag);return this}}class El extends pe{constructor(t){super(t)}get fonts(){const t=new Set,e=n=>{if(n){const r=n.lastIndexOf(".");if(r>=0){const o=n.substring(0,r).toLowerCase();t.add(o)}else t.add(n.toLowerCase())}},s=this.newIterator();for(const n of s)e(n.fileName),e(n.bigFontFileName);return Array.from(t)}}class yn extends Me{constructor(t){super(),this.name=t.name,this._textStyle=t,this._textStyle.font=this.getFileNameWithoutExtension(this._textStyle.font||this._textStyle.extendedFont||this.name),this._isVertical=!1}get obliquingAngle(){return this._textStyle.obliqueAngle}set obliquingAngle(t){this._textStyle.obliqueAngle=t}get priorSize(){return this._textStyle.lastHeight}set priorSize(t){this._textStyle.lastHeight=t}get textSize(){return this._textStyle.fixedTextHeight}set textSize(t){this._textStyle.fixedTextHeight=t}get xScale(){return this._textStyle.widthFactor}set xScale(t){this._textStyle.widthFactor=t}get isVertical(){return this._isVertical}set isVertical(t){this._isVertical=t}get fileName(){return this._textStyle.font}set fileName(t){this._textStyle.font=t}get bigFontFileName(){return this._textStyle.bigFont}set bigFontFileName(t){this._textStyle.bigFont=t}get textStyle(){return this._textStyle}getFileNameWithoutExtension(t){const e=t.split("/").pop();if(e){const s=e.lastIndexOf(".");return s===-1?e:e.substring(0,s)}return t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbTextStyleTableRecord"),t.writeString(2,this.name),t.writeInt16(70,this.textStyle.standardFlag),t.writeDouble(40,this.textSize),t.writeDouble(41,this.xScale),t.writeAngle(50,this.obliquingAngle),t.writeInt16(71,this.isVertical?4:this.textStyle.textGenerationFlag),t.writeDouble(42,this.priorSize),t.writeString(3,this.fileName),t.writeString(4,this.bigFontFileName),this}}class Ll extends pe{constructor(t){super(t)}}class Ml extends pe{constructor(t){super(t)}}const Xc=()=>({center:new v,viewDirectionFromTarget:new w(0,0,1),viewTarget:new w(0,0,0),lensLength:500,frontClippingPlane:0,backClippingPlane:0,viewHeight:1e3,viewTwistAngle:0,frozenLayers:[],styleSheet:"",renderMode:_r.OPTIMIZED_2D,viewMode:0,ucsIconSetting:0,ucsOrigin:new w(0,0,0),ucsXAxis:new w(1,0,0),ucsYAxis:new w(0,1,0),orthographicType:xr.TOP,shadePlotSetting:0,shadePlotObjectId:void 0,visualStyleObjectId:void 0,isDefaultLightingOn:!1,defaultLightingType:wr.ONE_DISTANT_LIGHT,brightness:0,contrast:0,ambientColor:void 0});class Er extends Me{constructor(){super(),this._gsView=Xc(),this._centerPoint=this._gsView.center}get gsView(){return this._gsView}get centerPoint(){return this._centerPoint}set centerPoint(t){this._centerPoint.copy(t)}get viewDirectionFromTarget(){return this._gsView.viewDirectionFromTarget}set viewDirectionFromTarget(t){this._gsView.viewDirectionFromTarget.copy(t)}get viewTarget(){return this._gsView.viewTarget}set viewTarget(t){this._gsView.viewTarget.copy(t)}get viewHeight(){return this._gsView.viewHeight}set viewHeight(t){this._gsView.viewHeight=t}get viewTwistAngle(){return this._gsView.viewTwistAngle}set viewTwistAngle(t){this._gsView.viewTwistAngle=t}get lensLength(){return this._gsView.lensLength}set lensLength(t){this._gsView.lensLength=t}get frontClippingPlane(){return this._gsView.frontClippingPlane}set frontClippingPlane(t){this._gsView.frontClippingPlane=t}get backClippingPlane(){return this._gsView.backClippingPlane}set backClippingPlane(t){this._gsView.backClippingPlane=t}get renderMode(){return this._gsView.renderMode}set renderMode(t){this._gsView.renderMode=t}get viewMode(){return this._gsView.viewMode}set viewMode(t){this._gsView.viewMode=t}get ucsIconSetting(){return this._gsView.ucsIconSetting}set ucsIconSetting(t){this._gsView.ucsIconSetting=t}get ucsOrigin(){return this._gsView.ucsOrigin}set ucsOrigin(t){this._gsView.ucsOrigin.copy(t)}get ucsXAxis(){return this._gsView.ucsXAxis}set ucsXAxis(t){this._gsView.ucsXAxis.copy(t)}get ucsYAxis(){return this._gsView.ucsYAxis}set ucsYAxis(t){this._gsView.ucsYAxis.copy(t)}get orthographicType(){return this._gsView.orthographicType}set orthographicType(t){this._gsView.orthographicType=t}get shadePlotSetting(){return this._gsView.shadePlotSetting}set shadePlotSetting(t){this._gsView.shadePlotSetting=t}get shadePlotObjectId(){return this._gsView.shadePlotObjectId}set shadePlotObjectId(t){this._gsView.shadePlotObjectId=t}get visualStyleObjectId(){return this._gsView.visualStyleObjectId}set visualStyleObjectId(t){this._gsView.visualStyleObjectId=t}get isDefaultLightingOn(){return this._gsView.isDefaultLightingOn}set isDefaultLightingOn(t){this._gsView.isDefaultLightingOn=t}get defaultLightingType(){return this._gsView.defaultLightingType}set defaultLightingType(t){this._gsView.defaultLightingType=t}get brightness(){return this._gsView.brightness}set brightness(t){this._gsView.brightness=t}get contrast(){return this._gsView.contrast}set contrast(t){this._gsView.contrast=t}get ambientColor(){return this._gsView.ambientColor}set ambientColor(t){this._gsView.ambientColor=t}}class Lr extends Er{constructor(){super(),this._circleSides=100,this._lowerLeftCorner=new v(0,0),this._upperRightCorner=new v(1,1),this._snapBase=new v(0,0),this._snapAngle=0,this._snapSpacing=new v(0,0),this._standardFlag=0,this._gridSpacing=new v,this._gridMajor=10}get circleSides(){return this._circleSides}set circleSides(t){this._circleSides=t}get center(){return this.centerPoint}set center(t){this.centerPoint=t}get lowerLeftCorner(){return this._lowerLeftCorner}set lowerLeftCorner(t){this._lowerLeftCorner.copy(t)}get upperRightCorner(){return this._upperRightCorner}set upperRightCorner(t){this._upperRightCorner.copy(t)}get snapBase(){return this._snapBase}set snapBase(t){this._snapBase.copy(t)}get snapAngle(){return this._snapAngle}set snapAngle(t){this._snapAngle=t}get snapIncrements(){return this._snapSpacing}set snapIncrements(t){this._snapSpacing.copy(t)}get gridMajor(){return this._gridMajor}set gridMajor(t){this._gridMajor=t}get gridIncrements(){return this._gridSpacing}set gridIncrements(t){this._gridSpacing.copy(t)}get standardFlag(){return this._standardFlag}set standardFlag(t){this._standardFlag=t}get snapEnabled(){return!!(this._standardFlag&256)}get backgroundObjectId(){return this._backgroundObjectId}set backgroundObjectId(t){this._backgroundObjectId=t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbViewportTableRecord"),t.writeString(2,this.name),t.writeDouble(45,this.gsView.viewHeight),t.writePoint2d(10,this.lowerLeftCorner),t.writePoint2d(11,this.upperRightCorner),t.writePoint2d(12,this.center),t.writePoint2d(13,this.snapBase),t.writePoint2d(14,this.snapIncrements),t.writePoint2d(15,this.gridIncrements),t.writeInt16(70,this.standardFlag),t.writeInt16(71,this.circleSides),t.writeDouble(42,this.gsView.lensLength),t.writePoint3d(16,this.gsView.viewDirectionFromTarget),t.writePoint3d(17,this.gsView.viewTarget),t.writeAngle(50,this.snapAngle),t.writeAngle(51,this.gsView.viewTwistAngle),t.writeInt16(61,this.gridMajor),t.writeInt16(281,this.backgroundObjectId?1:0),t.writeObjectId(332,this.backgroundObjectId),this}}class kl extends pe{constructor(t){super(t)}}class Zn extends Me{constructor(t){super(),this.name=t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbRegAppTableRecord"),t.writeString(2,this.name),t.writeInt16(70,0),this}}const B={ACADVER:"ACADVER",ANGBASE:"ANGBASE",ANGDIR:"ANGDIR",AUNITS:"AUNITS",CECOLOR:"CECOLOR",CELTYPE:"CELTYPE",CELTSCALE:"CELTSCALE",CELWEIGHT:"CELWEIGHT",CLAYER:"CLAYER",CMLSTYLE:"CMLSTYLE",CMLSCALE:"CMLSCALE",CMLEADERSTYLE:"CMLEADERSTYLE",COLORTHEME:"COLORTHEME",DYNMODE:"DYNMODE",DYNPROMPT:"DYNPROMPT",EXTMAX:"EXTMAX",EXTMIN:"EXTMIN",INSUNITS:"INSUNITS",LTSCALE:"LTSCALE",LWDISPLAY:"LWDISPLAY",MEASUREMENTCOLOR:"MEASUREMENTCOLOR",OSMODE:"OSMODE",PDMODE:"PDMODE",PDSIZE:"PDSIZE",PICKBOX:"PICKBOX",SHORTCUTMENU:"SHORTCUTMENU",TEXTSTYLE:"TEXTSTYLE",WHITEBKCOLOR:"WHITEBKCOLOR"},$c=Object.freeze(Object.values(B)),un=class un{constructor(){this.registry=new Map,this.cache=new Map,this.events={sysVarChanged:new Q},this.registerVar({name:B.CECOLOR,type:"color",isDbVar:!0,defaultValue:new j(P.ByLayer)}),this.registerVar({name:B.CELTSCALE,type:"number",isDbVar:!0,defaultValue:-1}),this.registerVar({name:B.CELTYPE,type:"string",isDbVar:!0,defaultValue:dt}),this.registerVar({name:B.CELWEIGHT,type:"number",isDbVar:!0,defaultValue:Qe.ByLayer}),this.registerVar({name:B.CLAYER,type:"string",isDbVar:!0,defaultValue:"0"}),this.registerVar({name:B.CMLSTYLE,type:"string",isDbVar:!0,defaultValue:ce}),this.registerVar({name:B.CMLSCALE,type:"number",isDbVar:!0,defaultValue:1}),this.registerVar({name:B.CMLEADERSTYLE,type:"string",isDbVar:!0,defaultValue:de}),this.registerVar({name:B.COLORTHEME,type:"number",isDbVar:!1,defaultValue:"0"}),this.registerVar({name:B.DYNMODE,type:"number",isDbVar:!1,defaultValue:3}),this.registerVar({name:B.DYNPROMPT,type:"boolean",isDbVar:!1,defaultValue:!0}),this.registerVar({name:B.LWDISPLAY,type:"boolean",isDbVar:!0,defaultValue:!1}),this.registerVar({name:B.MEASUREMENTCOLOR,type:"color",isDbVar:!1,defaultValue:(()=>{const t=new j(P.ByColor);return t.setRGB(96,165,250),t})()}),this.registerVar({name:B.OSMODE,type:"number",isDbVar:!0,defaultValue:0}),this.registerVar({name:B.PICKBOX,type:"number",isDbVar:!1,defaultValue:10}),this.registerVar({name:B.SHORTCUTMENU,type:"number",isDbVar:!1,defaultValue:0}),this.registerVar({name:B.TEXTSTYLE,type:"string",isDbVar:!0,defaultValue:Z}),this.registerVar({name:B.WHITEBKCOLOR,type:"boolean",isDbVar:!1,defaultValue:!1})}static instance(){return this._instance||(this._instance=new un),this._instance}registerVar(t){const e=this.normalizeName(t.name);this.registry.set(e,{...t,name:e}),t.isDbVar||this.cache.set(e,t.defaultValue)}registerMany(t){t.forEach(e=>this.registerVar(e))}getVar(t,e){t=this.normalizeName(t);const s=this.getDescriptor(t);if(!s)throw new Error(`System variable ${t} not found!`);if(s.isDbVar)return e[t.toLowerCase()];if(this.cache.has(t))return this.cache.get(t)}getDefaultValue(t){t=this.normalizeName(t);const e=this.getDescriptor(t);if(!e)throw new Error(`System variable ${t} not found!`);return e.defaultValue}setVar(t,e,s){t=this.normalizeName(t);const n=this.getDescriptor(t);if(n){const r=this.getVar(t,s);if(n.type!=="string"&&(typeof e=="string"||e instanceof String)){if(n.type==="number"){const o=Number(e);if(Number.isNaN(o))throw new Error("Invalid number input!");e=o}else if(n.type==="boolean")e=this.parseBoolean(e);else if(n.type==="color"){const o=j.fromString(e);if(o==null)throw new Error("Invalid color value!");e=o}}n.isDbVar?s[t.toLowerCase()]=e:(this.cache.set(t,e),this.hasValueChanged(r,e)&&this.events.sysVarChanged.dispatch({database:s,name:t,newVal:e,oldVal:r}))}else throw new Error(`System variable ${t} not found!`)}getDescriptor(t){return this.registry.get(this.normalizeName(t))}getAllDescriptors(){return[...this.registry.values()]}parseBoolean(t){if(t==null)return!1;const e=String(t).trim().toLowerCase(),s=new Set(["true","t","1","yes","y"]),n=new Set(["false","f","0","no","n"]);return s.has(e)?!0:(n.has(e),!1)}hasValueChanged(t,e){return t instanceof j&&e instanceof j?!t.equals(e):!Object.is(t,e)}normalizeName(t){return t.toLowerCase()}};un._instance=null;let Ks=un;class qc extends Ft{constructor(){super({objectId:"0"}),this.events={dictObjetSet:new Q,dictObjectErased:new Q,entityAppended:new Q,entityModified:new Q,entityErased:new Q,layerAppended:new Q,layerModified:new Q,layerErased:new Q,openProgress:new Q},this._version=new kt("AC1014"),this._angBase=0,this._angDir=0,this._aunits=ir.DecimalDegrees,this._celtscale=1,this._cecolor=new j,this._celtype=dt,this._celweight=Qe.ByLayer,this._clayer="0",this._cmlstyle=ce,this._cmlscale=1,this._cmleaderstyle=de,this._textstyle=Z,this._extents=new N,this._insunits=Tr.Millimeters,this._ltscale=1,this._lwdisplay=!1,this._pdmode=0,this._pdsize=0,this._osmode=0,this._maxHandle=0,this._tables={appIdTable:new kl(this),blockTable:new xl(this),dimStyleTable:new wl(this),linetypeTable:new Tl(this),textStyleTable:new El(this),viewTable:new Ll(this),layerTable:new Pl(this),viewportTable:new Ml(this)},this._objects={dictionary:new Ze(this),imageDefinition:new Ze(this),layout:new cl(this),mleaderStyle:new Ze(this),mlineStyle:new Ze(this),xrecord:new Ze(this)}}get tables(){return this._tables}get objects(){return this._objects}generateHandle(){return this._maxHandle++,this._maxHandle.toString(16).toUpperCase()}updateMaxHandle(t){const e=parseInt(t,16);!isNaN(e)&&e>this._maxHandle&&(this._maxHandle=e)}commitObjectHandle(t,e){const s=t.getAttrWithoutException("objectId");!s||t.isTemp||e&&e(s)?t.objectId=this.generateHandle():this.updateMaxHandle(s)}get currentSpaceId(){return this._currentSpace||(this._currentSpace=this._tables.blockTable.modelSpace),this._currentSpace.objectId}set currentSpaceId(t){const e=this.tables.blockTable.getIdAt(t);if(e==null)throw new Error(`[AcDbDatabase] The specified block table record id '${t}' doesn't exist in the drawing database!`);this._currentSpace=e}get aunits(){return this._aunits}set aunits(t){this.updateSysVar(B.AUNITS,this._aunits,t??0,e=>{this._aunits=e})}get version(){return this._version}set version(t){this.updateSysVar(B.ACADVER,this._version,new kt(t),e=>{this._version=e})}get insunits(){return this._insunits}set insunits(t){this.updateSysVar(B.INSUNITS,this._insunits,t??4,e=>{this._insunits=e})}get ltscale(){return this._ltscale}set ltscale(t){this.updateSysVar(B.LTSCALE,this._ltscale,t??1,e=>{this._ltscale=e})}get lwdisplay(){return this._lwdisplay}set lwdisplay(t){this.updateSysVar(B.LWDISPLAY,this._lwdisplay,t??!1,e=>{this._lwdisplay=e})}get cecolor(){return this._cecolor}set cecolor(t){this.updateSysVar(B.CECOLOR,this._cecolor,t||0,e=>{this._cecolor=e.clone()})}get celtscale(){return this._celtscale}set celtscale(t){this.updateSysVar(B.CELTSCALE,this._celtscale,t??1,e=>{this._celtscale=e})}get celtype(){return this._celtype}set celtype(t){const e=this.normalizeLinetypeName(t??dt);this.updateSysVar(B.CELTYPE,this._celtype,e,s=>{this._celtype=s})}get celweight(){return this._celweight}set celweight(t){this.updateSysVar(B.CELWEIGHT,this._celweight,t??Qe.ByLayer,e=>{this._celweight=e})}get clayer(){return this._clayer}set clayer(t){this.updateSysVar(B.CLAYER,this._clayer,t??"0",e=>{this._clayer=e})}get cmlstyle(){return this._cmlstyle}set cmlstyle(t){this.updateSysVar(B.CMLSTYLE,this._cmlstyle,t??ce,e=>{this._cmlstyle=e})}get cmlscale(){return this._cmlscale}set cmlscale(t){this.updateSysVar(B.CMLSCALE,this._cmlscale,t??1,e=>{this._cmlscale=e})}get cmleaderstyle(){return this._cmleaderstyle}set cmleaderstyle(t){this.updateSysVar(B.CMLEADERSTYLE,this._cmleaderstyle,t??de,e=>{this._cmleaderstyle=e})}get textstyle(){return this._textstyle}set textstyle(t){this.updateSysVar(B.TEXTSTYLE,this._textstyle,t??Z,e=>{this._textstyle=e})}get angBase(){return this._angBase}set angBase(t){this.updateSysVar(B.ANGBASE,this._angBase,t??0,e=>{this._angBase=e})}get angDir(){return this._angDir}set angDir(t){this.updateSysVar(B.ANGDIR,this._angDir,t??0,e=>{this._angDir=e})}get extmax(){return this._extents.max}set extmax(t){if(t){const e=this._extents.max.clone();this._extents.expandByPoint(t),this._extents.max.equals(e)||this.triggerSysVarChangedEvent(B.EXTMAX,e,this._extents.max)}}get extmin(){return this._extents.min}set extmin(t){if(t){const e=this._extents.min.clone();this._extents.expandByPoint(t),this._extents.min.equals(e)||this.triggerSysVarChangedEvent(B.EXTMIN,e,this._extents.min)}}get extents(){return this._extents}get pdmode(){return this._pdmode}set pdmode(t){this.updateSysVar(B.PDMODE,this._pdmode,t??0,e=>{this._pdmode=e})}get pdsize(){return this._pdsize}set pdsize(t){this.updateSysVar(B.PDSIZE,this._pdsize,t??0,e=>{this._pdsize=e})}get osmode(){return this._osmode}set osmode(t){this.updateSysVar(B.OSMODE,this._osmode,t??0,e=>{this._osmode=e})}async read(t,e,s=Os.DXF){const n=Vt.instance.get(s);if(n==null)throw new Error(`Database converter for file type '${s}' isn't registered and can can't read this file!`);this.clear(),await n.read(t,this,e&&e.minimumChunkSize||10,async(r,o,a,h)=>{if(this.events.openProgress.dispatch({database:this,percentage:r,stage:"CONVERSION",subStage:o,subStageStatus:a,data:h}),e&&e.fontLoader&&o=="FONT"&&a=="END"){const c=h||this.tables.textStyleTable.fonts;await e.fontLoader.load(c)}},e==null?void 0:e.timeout,e==null?void 0:e.sysVars),this.ensureDatabaseDefaults()}async openUri(t,e){var g;this.events.openProgress.dispatch({database:this,percentage:0,stage:"FETCH_FILE",subStageStatus:"START"});const s=await fetch(t);if(!s.ok)throw this.events.openProgress.dispatch({database:this,percentage:100,stage:"FETCH_FILE",subStageStatus:"ERROR"}),new Error(`Failed to fetch file '${t}' with HTTP status code '${s.status}'!`);const n=s.headers.get("content-length"),r=n?parseInt(n,10):null;let o=0;const a=(g=s.body)==null?void 0:g.getReader();if(!a)throw new Error("Failed to get response reader");const h=[];for(;;){const{done:m,value:y}=await a.read();if(m)break;if(h.push(y),o+=y.length,r!==null){const b=Math.round(o/r*100);this.events.openProgress.dispatch({database:this,percentage:b,stage:"FETCH_FILE",subStageStatus:"IN-PROGRESS"})}}const c=new Uint8Array(o);let d=0;for(const m of h)c.set(m,d),d+=m.length;const p=this.getFileNameFromUri(t).toLowerCase().split(".").pop();p==="dwg"?await this.read(c.buffer,e,Os.DWG):p==="dxf"?await this.read(c.buffer,e,Os.DXF):await this.read(c.buffer,e,p),this.events.openProgress.dispatch({database:this,percentage:100,stage:"FETCH_FILE",subStageStatus:"END"})}dxfOut(t,e=16,s=this.version.name,n=!1){this.ensureDatabaseDefaults();const r=s instanceof kt?s:new kt(s),o=new Ho({database:this,precision:e,version:r});return this.writeDxfHeaderSection(o),this.writeDxfTablesSection(o,r),this.writeDxfBlocksSection(o),this.writeDxfEntitiesSection(o),this.writeDxfObjectsSection(o),o.writeStart("EOF"),o.toString()}async regen(){await new Kh(this).read(null,this,500,async(e,s,n,r)=>{this.events.openProgress.dispatch({database:this,percentage:e,stage:"CONVERSION",subStage:s,subStageStatus:n,data:r})})}createDefaultData(t={layer:!0,lineType:!0,textStyle:!0,dimStyle:!0,layout:!0}){const e=new ml(this);t.layer&&e.createDefaultLayer(),t.lineType&&e.createDefaultLineType(),t.textStyle&&e.createDefaultTextStyle(),t.dimStyle&&e.createDefaultDimStyle(),t.layout&&e.createDefaultLayout()}ensureEntityStyleDefaults(t){if(t.dxfTypeName==="MLINE"){this.ensureMLineStyle(this._cmlstyle||ce);return}t.dxfTypeName==="MULTILEADER"&&this.ensureMLeaderStyle(this._cmleaderstyle||de)}ensureDatabaseDefaults(){if(!this.tables.layerTable.has("0")){const e=new j;e.colorIndex=7,this.tables.layerTable.add(new mn({name:"0",standardFlags:0,linetype:Se,lineWeight:0,isOff:!1,color:e,isPlottable:!0}))}if(this.tables.linetypeTable.has(fe)||this.tables.linetypeTable.add(new Ae({name:fe,standardFlag:0,description:"",totalPatternLength:0})),this.tables.linetypeTable.has(dt)||this.tables.linetypeTable.add(new Ae({name:dt,standardFlag:0,description:"",totalPatternLength:0})),this.tables.linetypeTable.has(Se)||this.tables.linetypeTable.add(new Ae({name:Se,standardFlag:0,description:"Solid line",totalPatternLength:0})),this.tables.textStyleTable.has(Z)||this.tables.textStyleTable.add(new yn({name:Z,standardFlag:0,fixedTextHeight:0,widthFactor:1,obliqueAngle:0,textGenerationFlag:0,lastHeight:.2,font:"SimKai",bigFont:"",extendedFont:"SimKai"})),this.tables.dimStyleTable.has(Z)||this.tables.dimStyleTable.add(new ts({name:Z,dimtxsty:Z})),!this.tables.viewportTable.has("*Active")){const e=new Lr;e.name="*Active",this.tables.viewportTable.add(e)}this.ensureMLineStyle(this._cmlstyle||ce),this.ensureMLeaderStyle(this._cmleaderstyle||de);const t=this.tables.blockTable.modelSpace;if(!this.objects.layout.getAt("Model")){const e=new ii;e.layoutName="Model",e.tabOrder=0,e.blockTableRecordId=t.objectId,e.limits.min.copy({x:0,y:0}),e.limits.max.copy({x:1e6,y:1e6}),e.extents.min.copy({x:0,y:0,z:0}),e.extents.max.copy({x:1e6,y:1e6,z:0}),this.objects.layout.setAt(e.layoutName,e),t.layoutId=e.objectId}this.tables.appIdTable.has(zn)||this.tables.appIdTable.add(new Zn(zn)),this.tables.appIdTable.has(Fn)||this.tables.appIdTable.add(new Zn(Fn))}ensureMLineStyle(t){const e=this.objects.mlineStyle,s=t.trim();if(!s||e.getAt(s))return;for(const[r,o]of e.entries())if(r.toUpperCase()===s.toUpperCase()||o.styleName.toUpperCase()===s.toUpperCase())return;const n=new Sr;n.styleName=s,n.elements=[{offset:.5,color:new j().setByLayer(),lineType:dt},{offset:-.5,color:new j().setByLayer(),lineType:dt}],e.setAt(s,n)}ensureMLeaderStyle(t){const e=this.objects.mleaderStyle,s=t.trim();if(!s||e.getAt(s))return;for(const[a]of e.entries())if(a.toUpperCase()===s.toUpperCase())return;const n=new fr;n.unknown1=2,n.maxLeaderSegmentsPoints=2,n.leaderLineColor=new j().setByBlock(),n.textColor=new j().setByBlock(),n.blockColor=new j().setByBlock(),n.alignSpace=4,n.breakSize=3.75,n.enableBlockRotation=!0,n.unknown2=!1;const r=this.tables.linetypeTable.getAt(fe);n.leaderLineTypeId=r==null?void 0:r.objectId;const o=this.tables.textStyleTable.getAt(Z);n.textStyleId=o==null?void 0:o.objectId,e.setAt(s,n)}writeDxfHeaderSection(t){var e;t.startSection("HEADER"),t.writeString(9,"$ACADVER"),t.writeString(1,((e=t.version)==null?void 0:e.name)??this.version.name),t.writeString(9,"$HANDSEED"),t.writeString(5,t.nextHandle.toString(16).toUpperCase()),t.version!=null&&t.version.value>=27&&(t.writeString(9,"$DWGCODEPAGE"),t.writeString(3,"UTF-8")),t.writeString(9,"$INSUNITS"),t.writeInt16(70,this.insunits),t.writeString(9,"$LTSCALE"),t.writeDouble(40,this.ltscale),t.writeString(9,"$LWDISPLAY"),t.writeInt16(70,this.lwdisplay?1:0),t.writeString(9,"$CLAYER"),t.writeString(8,this.clayer),t.writeString(9,"$CELTYPE"),t.writeString(6,this.celtype),t.writeString(9,"$CMLSTYLE"),t.writeString(2,this.cmlstyle),t.writeString(9,"$CMLSCALE"),t.writeDouble(40,this.cmlscale),t.writeString(9,"$CMLEADERSTYLE"),t.writeString(2,this.cmleaderstyle),t.writeString(9,"$TEXTSTYLE"),t.writeString(7,this.textstyle),t.writeString(9,"$ANGBASE"),t.writeAngle(50,this.angBase),t.writeString(9,"$ANGDIR"),t.writeInt16(70,this.angDir),t.writeString(9,"$EXTMIN"),t.writePoint3d(10,this.extmin),t.writeString(9,"$EXTMAX"),t.writePoint3d(10,this.extmax),t.writeString(9,"$PDMODE"),t.writeInt32(70,this.pdmode),t.writeString(9,"$PDSIZE"),t.writeDouble(40,this.pdsize),t.writeString(9,"$OSMODE"),t.writeInt32(70,this.osmode),t.endSection()}writeDxfTablesSection(t,e){t.startSection("TABLES"),this.writeDxfTable(t,"VPORT",this.tables.viewportTable,this.tables.viewportTable.newIterator(),"VPORT"),this.writeDxfTable(t,"VIEW",this.tables.viewTable,this.tables.viewTable.newIterator(),"VIEW"),this.writeDxfTable(t,"LTYPE",this.tables.linetypeTable,this.tables.linetypeTable.newIterator(),"LTYPE"),this.writeDxfTable(t,"LAYER",this.tables.layerTable,this.tables.layerTable.newIterator(),"LAYER"),this.writeDxfTable(t,"STYLE",this.tables.textStyleTable,this.tables.textStyleTable.newIterator(),"STYLE"),this.writeDxfTable(t,"APPID",this.tables.appIdTable,this.tables.appIdTable.newIterator(),"APPID"),this.writeDxfTable(t,"DIMSTYLE",this.tables.dimStyleTable,this.tables.dimStyleTable.newIterator(),"DIMSTYLE"),e.value>=19&&this.writeDxfTable(t,"BLOCK_RECORD",this.tables.blockTable,this.tables.blockTable.newIterator(),"BLOCK_RECORD"),t.endSection()}writeDxfBlocksSection(t){t.startSection("BLOCKS");for(const e of this.tables.blockTable.newIterator()){if(e.dxfOutBlockBegin(t),!e.isModelSapce&&!e.isPaperSapce)for(const s of e.newIterator())this.writeDxfEntity(t,s);e.dxfOutBlockEnd(t)}t.endSection()}writeDxfEntitiesSection(t){t.startSection("ENTITIES");for(const e of this.tables.blockTable.newIterator())if(!(!e.isModelSapce&&!e.isPaperSapce))for(const s of e.newIterator())this.writeDxfEntity(t,s);t.endSection()}writeDxfObjectsSection(t){t.startSection("OBJECTS");const e=this.objects.dictionary;e.ownerId="0";const s=o=>{t.writeStart("DICTIONARY"),o.dxfOut(t)},n=(o,a)=>{e.getAt(o)!==a&&e.setAt(o,a)},r=o=>{e.getAt(o)&&e.remove(o)};n("ACAD_LAYOUT",this.objects.layout),this.objects.mleaderStyle.numEntries>0?n("ACAD_MLEADERSTYLE",this.objects.mleaderStyle):r("ACAD_MLEADERSTYLE"),this.objects.mlineStyle.numEntries>0?n("ACAD_MLINESTYLE",this.objects.mlineStyle):r("ACAD_MLINESTYLE"),this.objects.imageDefinition.numEntries>0?n("ISM_RASTER_IMAGE_DICT",this.objects.imageDefinition):r("ISM_RASTER_IMAGE_DICT"),this.objects.xrecord.numEntries>0?n("MLIGHT_XRECORD",this.objects.xrecord):r("MLIGHT_XRECORD"),s(e),s(this.objects.layout),this.objects.mleaderStyle.numEntries>0&&s(this.objects.mleaderStyle),this.objects.mlineStyle.numEntries>0&&s(this.objects.mlineStyle),this.objects.imageDefinition.numEntries>0&&s(this.objects.imageDefinition),this.objects.xrecord.numEntries>0&&s(this.objects.xrecord);for(const[o,a]of this.objects.layout.entries())t.writeStart("LAYOUT"),a.dxfOut(t);for(const[o,a]of this.objects.imageDefinition.entries())t.writeStart("IMAGEDEF"),a.dxfOut(t);for(const[o,a]of this.objects.mleaderStyle.entries())t.writeStart("MLEADERSTYLE"),a.dxfOut(t);for(const[o,a]of this.objects.mlineStyle.entries())t.writeStart("MLINESTYLE"),a.dxfOut(t);for(const[o,a]of this.objects.xrecord.entries())t.writeStart("XRECORD"),a.dxfOut(t);t.endSection()}writeDxfTable(t,e,s,n,r){const o=[...n];t.startTable(e),s.dxfOut(t);for(const a of o){if(r==="BLOCK_RECORD"&&a instanceof J){a.dxfOutBlockRecord(t);continue}t.writeStart(r),a.dxfOut(t)}t.endTable()}writeDxfEntity(t,e){t.writeStart(e.dxfTypeName),e.dxfOut(t)}clear(){this._tables.blockTable.removeAll(),this._tables.dimStyleTable.removeAll(),this._tables.linetypeTable.removeAll(),this._tables.textStyleTable.removeAll(),this._tables.viewTable.removeAll(),this._tables.layerTable.removeAll(),this._tables.viewportTable.removeAll(),this._objects.layout.removeAll(),this._objects.imageDefinition.removeAll(),this._objects.mleaderStyle.removeAll(),this._objects.mlineStyle.removeAll(),this._objects.xrecord.removeAll(),this._currentSpace=void 0,this._extents.makeEmpty()}updateSysVar(t,e,s,n){this.hasSysVarValueChanged(e,s)&&(n(s),this.triggerSysVarChangedEvent(t,e,s))}hasSysVarValueChanged(t,e){return t instanceof j&&e instanceof j?!t.equals(e):t instanceof kt&&e instanceof kt?t.value!==e.value:!Object.is(t,e)}normalizeLinetypeName(t){const e=t.trim();return e.toUpperCase()==="BYLAYER"?dt:e.toUpperCase()==="BYBLOCK"?fe:e}triggerSysVarChangedEvent(t,e,s){const n=Ks.instance(),r=t.toLowerCase();n.getDescriptor(r)!=null&&n.events.sysVarChanged.dispatch({database:this,name:r,oldVal:e,newVal:s})}getFileNameFromUri(t){try{const s=new URL(t).pathname.split("/");return s[s.length-1]||""}catch{return""}}}const vl="Load Database",Ro=3e4,Zc=12e4,Kc=1024*1024;class xt extends Zo{constructor(t,e){super(t.stage),this.data=t,this.progress=e}async run(t){const e=Jn.getInstance().getEntry(vl),s=Date.now();this.progress&&await this.progress(this.data.progress.value,this.data.stage,"START");const n=await this.data.task(t);return this.progress&&(await this.progress(this.data.progress.value,this.data.stage,"END",n?n.data:null),this.data.progress.value+=this.data.step,this.data.progress.value>100&&(this.data.progress.value=100)),e&&(e.data[this.name]=Date.now()-s),n}}class Mr{constructor(t={}){this.config=t}async read(t,e,s,n,r,o){const a={name:vl,data:{total:0},format(){let u="";return Object.keys(this.data).forEach(p=>{p!=="total"&&(u+=`- ${p}: ${this.data[p]} ms
5
+ `)}),u+=`- total: ${this.data.total} ms`,u}};Jn.getInstance().collect(a),this.progress=n;const h={value:0},c=new Ko;c.setCompleteCallback(()=>this.onFinished()),c.setErrorCallback(u=>this.onError(u)),c.addTask(new xt({stage:"START",step:1,progress:h,task:async u=>u},n)),c.addTask(new xt({stage:"PARSE",step:5,progress:h,task:async u=>await this.parse(u,r)},n)),c.addTask(new xt({stage:"FONT",step:5,progress:h,task:async u=>{const p=this.getFonts(u.model);return{model:u.model,data:p}}},n)),c.addTask(new xt({stage:"LTYPE",step:1,progress:h,task:async u=>(this.processLineTypes(u.model,e),u)},n)),c.addTask(new xt({stage:"STYLE",step:1,progress:h,task:async u=>(this.processTextStyles(u.model,e),u)},n)),c.addTask(new xt({stage:"DIMSTYLE",step:1,progress:h,task:async u=>(this.processDimStyles(u.model,e),u)},n)),c.addTask(new xt({stage:"LAYER",step:1,progress:h,task:async u=>(this.processLayers(u.model,e),e.tables.layerTable.numEntries===0&&e.createDefaultData({layer:!0}),u)},n)),c.addTask(new xt({stage:"VPORT",step:1,progress:h,task:async u=>(this.processViewports(u.model,e),u)},n)),c.addTask(new xt({stage:"HEADER",step:1,progress:h,task:async u=>{if(this.processHeader(u.model,e),o){const p=Ks.instance();for(const[g,m]of Object.entries(o))p.setVar(g,m,e)}return u}},n)),c.addTask(new xt({stage:"BLOCK_RECORD",step:5,progress:h,task:async u=>(this.processBlockTables(u.model,e),u)},n)),c.addTask(new xt({stage:"OBJECT",step:5,progress:h,task:async u=>(this.processObjects(u.model,e),e.objects.layout.numEntries===0&&e.createDefaultData({layout:!0}),u)},n)),c.addTask(new xt({stage:"BLOCK",step:5,progress:h,task:async u=>(await this.processBlocks(u.model,e),u)},n)),c.addTask(new xt({stage:"ENTITY",step:100,progress:h,task:async u=>(await this.processEntities(u.model,e,s,h,n),u)},n)),c.addTask(new xt({stage:"END",step:0,progress:h,task:async u=>u},n));const d=Date.now();await c.run(t),a.data.total=Date.now()-d}onError(t){if(this.progress){const e=t.task;this.progress(e.data.progress.value,e.data.stage,"ERROR",void 0,t)}return t.task.name==="ENTITY"?!1:(this.onFinished(),!0)}onFinished(){this.progress&&(this.progress(100,"END","END"),es.instance.clear())}getParserWorkerTimeout(t,e){const s=e??this.config.timeout;if(s!=null)return s;const n=Math.ceil(t.byteLength/Kc),r=Ro+n*1e3;return Math.min(Zc,Math.max(Ro,r))}async parse(t,e){throw new Error("Not impelemented yet!")}getFonts(t){throw new Error("Not impelemented yet!")}processLineTypes(t,e){throw new Error("Not impelemented yet!")}processTextStyles(t,e){throw new Error("Not impelemented yet!")}processDimStyles(t,e){throw new Error("Not impelemented yet!")}processLayers(t,e){throw new Error("Not impelemented yet!")}processViewports(t,e){throw new Error("Not impelemented yet!")}processHeader(t,e){throw new Error("Not impelemented yet!")}processBlockTables(t,e){throw new Error("Not impelemented yet!")}processObjects(t,e){throw new Error("Not impelemented yet!")}processBlocks(t,e){throw new Error("Not impelemented yet!")}processEntities(t,e,s,n,r){throw new Error("Not impelemented yet!")}}class Qc extends Er{constructor(){super(),this._standardFlags=0,this._viewWidth=this.viewHeight,this._ucsAssociated=!1,this._cameraPlottable=!1,this._ucsElevation=0}get standardFlags(){return this._standardFlags}set standardFlags(t){this._standardFlags=t}get viewWidth(){return this._viewWidth}set viewWidth(t){this._viewWidth=t}get ucsAssociated(){return this._ucsAssociated}set ucsAssociated(t){this._ucsAssociated=t}get cameraPlottable(){return this._cameraPlottable}set cameraPlottable(t){this._cameraPlottable=t}get ucsElevation(){return this._ucsElevation}set ucsElevation(t){this._ucsElevation=t}get ucsObjectId(){return this._ucsObjectId}set ucsObjectId(t){this._ucsObjectId=t}get ucsBaseObjectId(){return this._ucsBaseObjectId}set ucsBaseObjectId(t){this._ucsBaseObjectId=t}get backgroundObjectId(){return this._backgroundObjectId}set backgroundObjectId(t){this._backgroundObjectId=t}get liveSectionObjectId(){return this._liveSectionObjectId}set liveSectionObjectId(t){this._liveSectionObjectId=t}dxfOutFields(t){return super.dxfOutFields(t),t.writeSubclassMarker("AcDbViewTableRecord"),t.writeString(2,this.name),t.writeInt16(70,this.standardFlags),t.writeDouble(40,this.gsView.viewHeight),t.writePoint2d(10,this.centerPoint),t.writeDouble(41,this.viewWidth),t.writePoint3d(11,this.gsView.viewDirectionFromTarget),t.writePoint3d(12,this.gsView.viewTarget),t.writeDouble(42,this.gsView.lensLength),t.writeDouble(43,this.gsView.frontClippingPlane),t.writeDouble(44,this.gsView.backClippingPlane),t.writeAngle(50,this.gsView.viewTwistAngle),t.writeInt16(71,this.gsView.viewMode),t.writeInt16(281,this.gsView.renderMode),t.writeInt16(72,this.ucsAssociated?1:0),t.writeInt16(73,this.cameraPlottable?1:0),t.writeObjectId(332,this.backgroundObjectId),t.writeObjectId(334,this.liveSectionObjectId),t.writeObjectId(348,this.gsView.visualStyleObjectId),this.ucsAssociated&&(t.writePoint3d(110,this.gsView.ucsOrigin),t.writePoint3d(111,this.gsView.ucsXAxis),t.writePoint3d(112,this.gsView.ucsYAxis),t.writeInt16(79,this.gsView.orthographicType),t.writeDouble(146,this.ucsElevation),t.writeObjectId(345,this.ucsObjectId),t.writeObjectId(346,this.ucsBaseObjectId)),this}}var st,us,q,K,gs,Ct,Oe,Yt,ut,Xt,Ot,Ne,Be,Re,ft,$t,ps,ms,Fe,ze,ys,_s,xs,St,qt,U,Ve,ws,C,gt,bs,pt,fs,Zt,W,Ss,Kt,De,Tn,En,Nt,Is,je,It,Qt,Jt,te,As,Ps,ee,We,He,Ln,Ts,Ge,se,Ue,it,ie,At,Mn,nt,kn,ne,Pt,Ye,Es,Xe,Tt,re,Et,oe,vn,$e,Lt;(st={})[st.None=0]="None",st[st.Anonymous=1]="Anonymous",st[st.NonConstant=2]="NonConstant",st[st.Xref=4]="Xref",st[st.XrefOverlay=8]="XrefOverlay",st[st.ExternallyDependent=16]="ExternallyDependent",st[st.ResolvedOrDependent=32]="ResolvedOrDependent",st[st.ReferencedXref=64]="ReferencedXref";(us={})[us.BYBLOCK=0]="BYBLOCK",us[us.BYLAYER=256]="BYLAYER";(q={})[q.Rotated=0]="Rotated",q[q.Aligned=1]="Aligned",q[q.Angular=2]="Angular",q[q.Diameter=3]="Diameter",q[q.Radius=4]="Radius",q[q.Angular3Point=5]="Angular3Point",q[q.Ordinate=6]="Ordinate",q[q.ReferenceIsExclusive=32]="ReferenceIsExclusive",q[q.IsOrdinateXTypeFlag=64]="IsOrdinateXTypeFlag",q[q.IsCustomTextPositionFlag=128]="IsCustomTextPositionFlag";(K={})[K.TopLeft=1]="TopLeft",K[K.TopCenter=2]="TopCenter",K[K.TopRight=3]="TopRight",K[K.MiddleLeft=4]="MiddleLeft",K[K.MiddleCenter=5]="MiddleCenter",K[K.MiddleRight=6]="MiddleRight",K[K.BottomLeft=7]="BottomLeft",K[K.BottomCenter=8]="BottomCenter",K[K.BottomRight=9]="BottomRight";(gs={})[gs.AtLeast=1]="AtLeast",gs[gs.Exact=2]="Exact";var Fo=((Ct={})[Ct.Center=0]="Center",Ct[Ct.Above=1]="Above",Ct[Ct.Outside=2]="Outside",Ct[Ct.JIS=3]="JIS",Ct[Ct.Below=4]="Below",Ct);(Oe={})[Oe.WithDimension=0]="WithDimension",Oe[Oe.AddLeader=1]="AddLeader",Oe[Oe.Independent=2]="Independent";(Yt={})[Yt.BothOutside=0]="BothOutside",Yt[Yt.ArrowFirst=1]="ArrowFirst",Yt[Yt.TextFirst=2]="TextFirst",Yt[Yt.Auto=3]="Auto";var ns=((ut={})[ut.Feet=0]="Feet",ut[ut.None=1]="None",ut[ut.Inch=2]="Inch",ut[ut.FeetAndInch=3]="FeetAndInch",ut[ut.Leading=4]="Leading",ut[ut.Trailing=8]="Trailing",ut[ut.LeadingAndTrailing=12]="LeadingAndTrailing",ut),Jc=((Xt={})[Xt.None=0]="None",Xt[Xt.Leading=1]="Leading",Xt[Xt.Trailing=2]="Trailing",Xt[Xt.LeadingAndTrailing=3]="LeadingAndTrailing",Xt),td=((Ot={})[Ot.Center=0]="Center",Ot[Ot.First=1]="First",Ot[Ot.Second=2]="Second",Ot[Ot.OverFirst=3]="OverFirst",Ot[Ot.OverSecond=4]="OverSecond",Ot),ed=((Ne={})[Ne.Bottom=0]="Bottom",Ne[Ne.Center=1]="Center",Ne[Ne.Top=2]="Top",Ne);(Be={})[Be.None=0]="None",Be[Be.UseDrawingBackground=1]="UseDrawingBackground",Be[Be.Custom=2]="Custom";(Re={})[Re.Horizontal=0]="Horizontal",Re[Re.Diagonal=1]="Diagonal",Re[Re.NotStacked=2]="NotStacked";(ft={})[ft.Scientific=1]="Scientific",ft[ft.Decimal=2]="Decimal",ft[ft.Engineering=3]="Engineering",ft[ft.Architectural=4]="Architectural",ft[ft.Fractional=5]="Fractional",ft[ft.WindowDesktop=6]="WindowDesktop";($t={})[$t.Decimal=0]="Decimal",$t[$t.DegreesMinutesSecond=1]="DegreesMinutesSecond",$t[$t.Gradian=2]="Gradian",$t[$t.Radian=3]="Radian";var sd=((ps={})[ps.PatternFill=0]="PatternFill",ps[ps.SolidFill=1]="SolidFill",ps);(ms={})[ms.NonAssociative=0]="NonAssociative",ms[ms.Associative=1]="Associative";(Fe={})[Fe.Normal=0]="Normal",Fe[Fe.Outer=1]="Outer",Fe[Fe.Ignore=2]="Ignore";(ze={})[ze.UserDefined=0]="UserDefined",ze[ze.Predefined=1]="Predefined",ze[ze.Custom=2]="Custom";(ys={})[ys.NotAnnotated=0]="NotAnnotated",ys[ys.Annotated=1]="Annotated";(_s={})[_s.Solid=0]="Solid",_s[_s.Gradient=1]="Gradient";(xs={})[xs.TwoColor=0]="TwoColor",xs[xs.OneColor=1]="OneColor";var id=((St={})[St.Default=0]="Default",St[St.External=1]="External",St[St.Polyline=2]="Polyline",St[St.Derived=4]="Derived",St[St.Textbox=8]="Textbox",St[St.Outermost=16]="Outermost",St),wi=((qt={})[qt.Line=1]="Line",qt[qt.Circular=2]="Circular",qt[qt.Elliptic=3]="Elliptic",qt[qt.Spline=4]="Spline",qt),nd=((U={})[U.Off=0]="Off",U[U.Solid=1]="Solid",U[U.Dashed=2]="Dashed",U[U.Dotted=3]="Dotted",U[U.ShotDash=4]="ShotDash",U[U.MediumDash=5]="MediumDash",U[U.LongDash=6]="LongDash",U[U.DoubleShortDash=7]="DoubleShortDash",U[U.DoubleMediumDash=8]="DoubleMediumDash",U[U.DoubleLongDash=9]="DoubleLongDash",U[U.DoubleMediumLongDash=10]="DoubleMediumLongDash",U[U.SparseDot=11]="SparseDot",U);nd.Off;(Ve={})[Ve.Standard=-3]="Standard",Ve[Ve.ByLayer=-2]="ByLayer",Ve[Ve.ByBlock=-1]="ByBlock";(ws={})[ws.English=0]="English",ws[ws.Metric=1]="Metric";(C={})[C.PERSPECTIVE_MODE=1]="PERSPECTIVE_MODE",C[C.FRONT_CLIPPING=2]="FRONT_CLIPPING",C[C.BACK_CLIPPING=4]="BACK_CLIPPING",C[C.UCS_FOLLOW=8]="UCS_FOLLOW",C[C.FRONT_CLIP_NOT_AT_EYE=16]="FRONT_CLIP_NOT_AT_EYE",C[C.UCS_ICON_VISIBILITY=32]="UCS_ICON_VISIBILITY",C[C.UCS_ICON_AT_ORIGIN=64]="UCS_ICON_AT_ORIGIN",C[C.FAST_ZOOM=128]="FAST_ZOOM",C[C.SNAP_MODE=256]="SNAP_MODE",C[C.GRID_MODE=512]="GRID_MODE",C[C.ISOMETRIC_SNAP_STYLE=1024]="ISOMETRIC_SNAP_STYLE",C[C.HIDE_PLOT_MODE=2048]="HIDE_PLOT_MODE",C[C.K_ISO_PAIR_TOP=4096]="K_ISO_PAIR_TOP",C[C.K_ISO_PAIR_RIGHT=8192]="K_ISO_PAIR_RIGHT",C[C.VIEWPORT_ZOOM_LOCKING=16384]="VIEWPORT_ZOOM_LOCKING",C[C.UNUSED=32768]="UNUSED",C[C.NON_RECTANGULAR_CLIPPING=65536]="NON_RECTANGULAR_CLIPPING",C[C.VIEWPORT_OFF=131072]="VIEWPORT_OFF",C[C.GRID_BEYOND_DRAWING_LIMITS=262144]="GRID_BEYOND_DRAWING_LIMITS",C[C.ADAPTIVE_GRID_DISPLAY=524288]="ADAPTIVE_GRID_DISPLAY",C[C.SUBDIVISION_BELOW_SPACING=1048576]="SUBDIVISION_BELOW_SPACING",C[C.GRID_FOLLOWS_WORKPLANE=2097152]="GRID_FOLLOWS_WORKPLANE";(gt={})[gt.OPTIMIZED_2D=0]="OPTIMIZED_2D",gt[gt.WIREFRAME=1]="WIREFRAME",gt[gt.HIDDEN_LINE=2]="HIDDEN_LINE",gt[gt.FLAT_SHADED=3]="FLAT_SHADED",gt[gt.GOURAUD_SHADED=4]="GOURAUD_SHADED",gt[gt.FLAT_SHADED_WITH_WIREFRAME=5]="FLAT_SHADED_WITH_WIREFRAME",gt[gt.GOURAUD_SHADED_WITH_WIREFRAME=6]="GOURAUD_SHADED_WITH_WIREFRAME";(bs={})[bs.UCS_UNCHANGED=0]="UCS_UNCHANGED",bs[bs.HAS_OWN_UCS=1]="HAS_OWN_UCS";(pt={})[pt.NON_ORTHOGRAPHIC=0]="NON_ORTHOGRAPHIC",pt[pt.TOP=1]="TOP",pt[pt.BOTTOM=2]="BOTTOM",pt[pt.FRONT=3]="FRONT",pt[pt.BACK=4]="BACK",pt[pt.LEFT=5]="LEFT",pt[pt.RIGHT=6]="RIGHT";(fs={})[fs.ONE_DISTANT_LIGHT=0]="ONE_DISTANT_LIGHT",fs[fs.TWO_DISTANT_LIGHTS=1]="TWO_DISTANT_LIGHTS";(Zt={})[Zt.ByLayer=0]="ByLayer",Zt[Zt.ByBlock=1]="ByBlock",Zt[Zt.ByDictionaryDefault=2]="ByDictionaryDefault",Zt[Zt.ByObject=3]="ByObject";(W={})[W.NotAllowed=0]="NotAllowed",W[W.AllowErase=1]="AllowErase",W[W.AllowTransform=2]="AllowTransform",W[W.AllowChangeColor=4]="AllowChangeColor",W[W.AllowChangeLayer=8]="AllowChangeLayer",W[W.AllowChangeLinetype=16]="AllowChangeLinetype",W[W.AllowChangeLinetypeScale=32]="AllowChangeLinetypeScale",W[W.AllowChangeVisibility=64]="AllowChangeVisibility",W[W.AllowClone=128]="AllowClone",W[W.AllowChangeLineweight=256]="AllowChangeLineweight",W[W.AllowChangePlotStyleName=512]="AllowChangePlotStyleName",W[W.AllowAllExceptClone=895]="AllowAllExceptClone",W[W.AllowAll=1023]="AllowAll",W[W.DisableProxyWarning=1024]="DisableProxyWarning",W[W.R13FormatProxy=32768]="R13FormatProxy";function O(i,t,e){return i.code===t&&(e==null||i.value===e)}function Le(i){let t={};i.rewind();let e=i.next(),s=e.code;if(t.x=e.value,(e=i.next()).code!==s+10)throw Error("Expected code for point value to be 20 but got "+e.code+".");return t.y=e.value,(e=i.next()).code!==s+20?i.rewind():t.z=e.value,t}let ri=Symbol();function E(i,t){return(e,s,n)=>{let r=function(h,c=!1){return h.reduce((d,u)=>{u.pushContext&&d.push({});let p=d[d.length-1];for(let g of typeof u.code=="number"?[u.code]:u.code){let m=p[g]??(p[g]=[]);u.isMultiple&&m.length,m.push(u)}return d},[{}])}(i,s.debug),o=!1,a=r.length-1;for(;!O(e,0,"EOF");){let h=function(b,x,I){return b.find((S,L)=>{var A;return L>=I&&((A=S[x])==null?void 0:A.length)})}(r,e.code,a),c=h==null?void 0:h[e.code],d=c==null?void 0:c[c.length-1];if(!h||!d){s.rewind();break}d.isMultiple||h[e.code].pop();let{name:u,parser:p,isMultiple:g,isReducible:m}=d,y=p==null?void 0:p(e,s,n);if(y===ri){s.rewind();break}if(u){let[b,x]=rd(n,u);g&&!m?(Object.prototype.hasOwnProperty.call(b,x)||(b[x]=[]),b[x].push(y)):b[x]=y}d.pushContext&&(a-=1),o=!0,e=s.next()}return t&&Object.setPrototypeOf(n,t),o}}function rd(i,t){let e=t.split(".");if(!e.length)throw Error("[parserGenerator::getObjectByPath] Invalid empty path");let s=i;for(let n=0;n<e.length-1;++n){let r=Cn(e[n]),o=Cn(e[n+1]);Object.prototype.hasOwnProperty.call(s,r)||(typeof o=="number"?s[r]=[]:s[r]={}),s=s[r]}return[s,Cn(e[e.length-1])]}function Cn(i){let t=Number.parseInt(i);return Number.isNaN(t)?i:t}function l({value:i}){return i}function f(i,t){return Le(t)}function T({value:i}){return!!i}function od({value:i}){return i.trim()}let ad=[{code:281,name:"isEntity",parser:T},{code:280,name:"wasProxy",parser:T},{code:91,name:"instanceCount",parser:l},{code:90,name:"proxyFlag",parser:l},{code:3,name:"appName",parser:l},{code:2,name:"cppClassName",parser:l},{code:1,name:"name",parser:l}],ld=E(ad),hd=[{code:0,name:"classes",isMultiple:!0,parser(i,t){if(i.value!=="CLASS")return ri;i=t.next();let e={};return ld(i,t,e),e}}],cd=E(hd);(Ss={})[Ss.RayTrace=0]="RayTrace",Ss[Ss.ShadowMap=1]="ShadowMap";function Gt(i,t,e){for(;O(i,102);){var s;let n=i.value;if(i=t.next(),!n.startsWith("{")){t.debug,function(o,a){for(;!O(o,102)&&!O(o,0,"EOF");)o=a.next()}(i,t),i=t.next();continue}let r=n.slice(1).trim();e.extensions??(e.extensions={}),(s=e.extensions)[r]??(s[r]=[]),function(o,a,h){for(;!O(o,102,"}")&&!O(o,0,"EOF");)h.push(o),o=a.next()}(i,t,e.extensions[r]),i=t.next()}t.rewind()}let dd=[{code:1001,name:"xdata",isMultiple:!0,parser:Cl}],ud=new Set([1010,1011,1012,1013]);function Cl(i,t){var n;if(!O(i,1001))throw Error("XData must starts with code 1001");let e={appName:i.value,value:[]};i=t.next();let s=[e.value];for(;!O(i,0,"EOF")&&!O(i,1001)&&i.code>=1e3;){let r=s[s.length-1];if(i.code===1002){i.value==="{"?s.push([]):(s.pop(),(n=s[s.length-1])==null||n.push(r)),i=t.next();continue}ud.has(i.code)?r.push(Le(t)):r.push(i.value),i=t.next()}return t.rewind(),e}(Kt={})[Kt.CAST_AND_RECEIVE=0]="CAST_AND_RECEIVE",Kt[Kt.CAST=1]="CAST",Kt[Kt.RECEIVE=2]="RECEIVE",Kt[Kt.IGNORE=3]="IGNORE";let V=[...dd,{code:284,name:"shadowMode",parser:l},{code:390,name:"plotStyleHardId",parser:l},{code:380,name:"plotStyleType",parser:l},{code:440,name:"transparency",parser:l},{code:430,name:"colorName",parser:l},{code:420,name:"color",parser:l},{code:310,name:"proxyEntity",isMultiple:!0,isReducible:!0,parser:(i,t,e)=>(e.proxyEntity??"")+i.value},{code:[92,160],name:"proxyByte",parser:l},{code:60,name:"isVisible",parser:T},{code:48,name:"lineTypeScale",parser:l},{code:370,name:"lineweight",parser:l},{code:62,name:"colorIndex",parser:l},{code:347,name:"materialObjectHardId",parser:l},{code:6,name:"lineType",parser:l},{code:8,name:"layer",parser:l},{code:410,name:"layoutTabName",parser:l},{code:67,name:"isInPaperSpace",parser:T},{code:100},{code:330,name:"ownerBlockRecordSoftId",parser:l},{code:102,parser:Gt},{code:102,parser:Gt},{code:102,parser:Gt},{code:5,name:"handle",parser:l}];function _n(i){return[{code:3,name:i,parser:(t,e,s)=>(s._code3text=(s._code3text??"")+t.value,s._code3text+(s._code1text??"")),isMultiple:!0,isReducible:!0},{code:1,name:i,parser:(t,e,s)=>(s._code1text=t.value,(s._code3text??"")+s._code1text)}]}function Ol(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let gd={extrusionDirection:{x:0,y:0,z:1}},pd=[{code:210,name:"extrusionDirection",parser:f},{code:51,name:"endAngle",parser:l},{code:50,name:"startAngle",parser:l},{code:100,name:"subclassMarker",parser:l},{code:40,name:"radius",parser:l},{code:10,name:"center",parser:f},{code:39,name:"thickness",parser:l},{code:100},...V];class Nl{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Ol(this,"parser",E(pd,gd))}}Ol(Nl,"ForEntityName","ARC");(De={})[De.BeforeText=0]="BeforeText",De[De.AboveText=1]="AboveText",De[De.None=2]="None";let kr=[{name:"DIMPOST",code:3},{name:"DIMAPOST",code:4,defaultValue:""},{name:"DIMBLK_OBSOLETE",code:5},{name:"DIMBLK1_OBSOLETE",code:6},{name:"DIMBLK2_OBSOLETE",code:7},{name:"DIMSCALE",code:40,defaultValue:1},{name:"DIMASZ",code:41,defaultValue:.25},{name:"DIMEXO",code:42,defaultValue:.625,defaultValueImperial:.0625},{name:"DIMDLI",code:43,defaultValue:3.75,defaultValueImperial:.38},{name:"DIMEXE",code:44,defaultValue:2.25,defaultValueImperial:.28},{name:"DIMRND",code:45,defaultValue:0},{name:"DIMDLE",code:46,defaultValue:0},{name:"DIMTP",code:47,defaultValue:0},{name:"DIMTM",code:48,defaultValue:0},{name:"DIMFXL",code:49,defaultValue:1},{name:"DIMJOGANG",code:50,defaultValue:45},{name:"DIMTFILL",code:69,defaultValue:0},{name:"DIMTFILLCLR",code:70,defaultValue:0},{name:"DIMTOL",code:71,defaultValue:0,defaultValueImperial:1},{name:"DIMLIM",code:72,defaultValue:0},{name:"DIMTIH",code:73,defaultValue:0,defaultValueImperial:1},{name:"DIMTOH",code:74,defaultValue:0,defaultValueImperial:1},{name:"DIMSE1",code:75,defaultValue:0},{name:"DIMSE2",code:76,defaultValue:0},{name:"DIMTAD",code:77,defaultValue:Fo.Above,defaultValueImperial:Fo.Center},{name:"DIMZIN",code:78,defaultValue:ns.Trailing,defaultValueImperial:ns.Feet},{name:"DIMAZIN",code:79,defaultValue:Jc.None},{name:"DIMARCSYM",code:90,defaultValue:0},{name:"DIMTXT",code:140,defaultValue:2.5,defaultValueImperial:.28},{name:"DIMCEN",code:141,defaultValue:2.5,defaultValueImperial:.09},{name:"DIMTSZ",code:142,defaultValue:0},{name:"DIMALTF",code:143,defaultValue:25.4},{name:"DIMLFAC",code:144,defaultValue:1},{name:"DIMTVP",code:145,defaultValue:0},{name:"DIMTFAC",code:146,defaultValue:1},{name:"DIMGAP",code:147,defaultValue:.625,defaultValueImperial:.09},{name:"DIMALTRND",code:148,defaultValue:0},{name:"DIMALT",code:170,defaultValue:0},{name:"DIMALTD",code:171,defaultValue:3,defaultValueImperial:2},{name:"DIMTOFL",code:172,defaultValue:1,defaultValueImperial:0},{name:"DIMSAH",code:173,defaultValue:0},{name:"DIMTIX",code:174,defaultValue:0},{name:"DIMSOXD",code:175,defaultValue:0},{name:"DIMCLRD",code:176,defaultValue:0},{name:"DIMCLRE",code:177,defaultValue:0},{name:"DIMCLRT",code:178,defaultValue:0},{name:"DIMADEC",code:179,defaultValue:0},{name:"DIMUNIT",code:270},{name:"DIMDEC",code:271,defaultValue:2,defaultValueImperial:4},{name:"DIMTDEC",code:272,defaultValue:2,defaultValueImperial:4},{name:"DIMALTU",code:273,defaultValue:2},{name:"DIMALTTD",code:274,defaultValue:3,defaultValueImperial:2},{name:"DIMAUNIT",code:275,defaultValue:0},{name:"DIMFRAC",code:276,defaultValue:0},{name:"DIMLUNIT",code:277,defaultValue:2},{name:"DIMDSEP",code:278,defaultValue:44,defaultValueImperial:46},{name:"DIMTMOVE",code:279,defaultValue:0},{name:"DIMJUST",code:280,defaultValue:td.Center},{name:"DIMSD1",code:281,defaultValue:0},{name:"DIMSD2",code:282,defaultValue:0},{name:"DIMTOLJ",code:283,defaultValue:ed.Center},{name:"DIMTZIN",code:284,defaultValue:ns.Trailing,defaultValueImperial:ns.Feet},{name:"DIMALTZ",code:285,defaultValue:ns.Trailing},{name:"DIMALTTZ",code:286,defaultValue:ns.Trailing},{name:"DIMFIT",code:287},{name:"DIMUPT",code:288,defaultValue:0},{name:"DIMATFIT",code:289,defaultValue:3},{name:"DIMFXLON",code:290,defaultValue:0},{name:"DIMTXTDIRECTION",code:294,defaultValue:0},{name:"DIMTXSTY",code:340,defaultValue:"Standard"},{name:"DIMLDRBLK",code:341,defaultValue:""},{name:"DIMBLK",code:342,defaultValue:""},{name:"DIMBLK1",code:343,defaultValue:""},{name:"DIMBLK2",code:344,defaultValue:""},{name:"DIMLTYPE",code:345,defaultValue:""},{name:"DIMLTEX1",code:346,defaultValue:""},{name:"DIMLTEX2",code:347,defaultValue:""},{name:"DIMLWD",code:371,defaultValue:-2},{name:"DIMLWE",code:372,defaultValue:-2}],Bl=[{code:3,name:"styleName",parser:l},{code:210,name:"extrusionDirection",parser:f},{code:51,name:"ocsRotation",parser:l},{code:53,name:"textRotation",parser:l},{code:1,name:"text",parser:l},{code:42,name:"measurement",parser:l},{code:72,name:"textLineSpacingStyle",parser:l},{code:71,name:"attachmentPoint",parser:l},{code:70,name:"dimensionType",parser:l},{code:11,name:"textPoint",parser:f},{code:10,name:"definitionPoint",parser:f},{code:2,name:"name",parser:l},{code:280,name:"version",parser:l},{code:100}],md=[{code:100},{code:52,name:"obliqueAngle",parser:l},{code:50,name:"rotationAngle",parser:l},{code:14,name:"subDefinitionPoint2",parser:f},{code:13,name:"subDefinitionPoint1",parser:f},{code:12,name:"insertionPoint",parser:f},{code:100,name:"subclassMarker",parser:l}],yd=[{code:16,name:"arcPoint",parser:f},{code:15,name:"centerPoint",parser:f},{code:14,name:"subDefinitionPoint2",parser:f},{code:13,name:"subDefinitionPoint1",parser:f},{code:100,name:"subclassMarker",parser:l}],_d=[{code:14,name:"subDefinitionPoint2",parser:f},{code:13,name:"subDefinitionPoint1",parser:f},{code:100,name:"subclassMarker",parser:l}],xd=[{code:40,name:"leaderLength",parser:l},{code:15,name:"subDefinitionPoint",parser:f},{code:100,name:"subclassMarker",parser:l}],wd=[{code:100,parser(i,t,e){let s=function(n){switch(n){case"AcDbAlignedDimension":return E(md);case"AcDb3PointAngularDimension":case"AcDb2LineAngularDimension":return E(yd);case"AcDbOrdinateDimension":return E(_d);case"AcDbRadialDimension":case"AcDbDiametricDimension":return E(xd)}return null}(i.value);if(!s)return ri;s(i,t,e)},pushContext:!0},...kr.map(i=>({...i,parser:l})),...Bl,...V];class Ei{parseEntity(t,e){let s={};return E(wd)(e,t,s),s}}(Tn="ForEntityName")in Ei?Object.defineProperty(Ei,Tn,{value:"DIMENSION",enumerable:!0,configurable:!0,writable:!0}):Ei[Tn]="DIMENSION";let bd=[{code:73},{code:17,name:"leaderEnd",parser:f},{code:16,name:"leaderStart",parser:f},{code:71,name:"hasLeader",parser:T},{code:41,name:"endAngle",parser:l},{code:40,name:"startAngle",parser:l},{code:70,name:"isPartial",parser:T},{code:15,name:"centerPoint",parser:f},{code:14,name:"xline2Point",parser:f},{code:13,name:"xline1Point",parser:f},{code:100,name:"subclassMarker",parser:l,pushContext:!0},...kr.map(i=>({...i,parser:l})),...Bl,...V];class Li{parseEntity(t,e){let s={};return E(bd)(e,t,s),s}}(En="ForEntityName")in Li?Object.defineProperty(Li,En,{value:"ARC_DIMENSION",enumerable:!0,configurable:!0,writable:!0}):Li[En]="ARC_DIMENSION";(Nt={})[Nt.NONE=0]="NONE",Nt[Nt.INVISIBLE=1]="INVISIBLE",Nt[Nt.CONSTANT=2]="CONSTANT",Nt[Nt.VERIFICATION_REQUIRED=4]="VERIFICATION_REQUIRED",Nt[Nt.PRESET=8]="PRESET";(Is={})[Is.MULTILINE=2]="MULTILINE",Is[Is.CONSTANT_MULTILINE=4]="CONSTANT_MULTILINE";(je={})[je.NONE=0]="NONE",je[je.MIRRORED_X=2]="MIRRORED_X",je[je.MIRRORED_Y=4]="MIRRORED_Y";var fd=((It={})[It.LEFT=0]="LEFT",It[It.CENTER=1]="CENTER",It[It.RIGHT=2]="RIGHT",It[It.ALIGNED=3]="ALIGNED",It[It.MIDDLE=4]="MIDDLE",It[It.FIT=5]="FIT",It),Sd=((Qt={})[Qt.BASELINE=0]="BASELINE",Qt[Qt.BOTTOM=1]="BOTTOM",Qt[Qt.MIDDLE=2]="MIDDLE",Qt[Qt.TOP=3]="TOP",Qt);function Rl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let Fl={thickness:0,rotation:0,xScale:1,obliqueAngle:0,styleName:"STANDARD",generationFlag:0,halign:fd.LEFT,valign:Sd.BASELINE,extrusionDirection:{x:0,y:0,z:1}},zl=[{code:73,name:"valign",parser:l},{code:100},{code:210,name:"extrusionDirection",parser:f},{code:11,name:"endPoint",parser:f},{code:72,name:"valign",parser:l},{code:72,name:"halign",parser:l},{code:71,name:"generationFlag",parser:l},{code:7,name:"styleName",parser:l},{code:51,name:"obliqueAngle",parser:l},{code:41,name:"xScale",parser:l},{code:50,name:"rotation",parser:l},{code:1,name:"text",parser:l},{code:40,name:"textHeight",parser:l},{code:10,name:"startPoint",parser:f},{code:39,name:"thickness",parser:l},{code:100,name:"subclassMarker",parser:l},...V];class Vl{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Rl(this,"parser",E(zl,Fl))}}function Dl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Rl(Vl,"ForEntityName","TEXT");let Id={...Fl},Ad=[{code:2},{code:40,name:"annotationScale",parser:l},{code:10,name:"alignmentPoint",parser:f},{code:340,name:"secondaryAttributesHardIds",isMultiple:!0,parser:l},{code:70,name:"numberOfSecondaryAttributes",parser:l},{code:70,name:"isReallyLocked",parser:T},{code:70,name:"mtextFlag",parser:l},{code:280,name:"isDuplicatedRecord",parser:T},{code:100},{code:280,name:"isLocked",parser:T},{code:74,name:"valign",parser:l},{code:73},{code:70,name:"attributeFlag",parser:l},{code:2,name:"tag",parser:l},{code:3,name:"prompt",parser:l},{code:280},{code:100,name:"subclassMarker",parser:l},...zl.slice(2)];class jl{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Dl(this,"parser",E(Ad,Id))}}function Pd(i,t){let e={};for(let s of i){let n=t(s);n!=null&&(e[n]??(e[n]=[]),e[n].push(s))}return e}function*hn(i,t=1/0,e=1){for(let s=i;s!==t;s+=e)yield s}function Kn(i){return{x:i.x??0,y:i.y??0,z:i.z??0}}Dl(jl,"ForEntityName","ATTDEF");var Td=[0,16711680,16776960,65280,65535,255,16711935,16777215,8421504,12632256,16711680,16744319,13369344,13395558,10027008,10046540,8323072,8339263,4980736,4990502,16727808,16752511,13382400,13401958,10036736,10051404,8331008,8343359,4985600,4992806,16744192,16760703,13395456,13408614,10046464,10056268,8339200,8347455,4990464,4995366,16760576,16768895,13408512,13415014,10056192,10061132,8347392,8351551,4995328,4997670,16776960,16777087,13421568,13421670,10000384,10000460,8355584,8355647,5000192,5000230,12582656,14679935,10079232,11717734,7510016,8755276,6258432,7307071,3755008,4344870,8388352,12582783,6736896,10079334,5019648,7510092,4161280,6258495,2509824,3755046,4194048,10485631,3394560,8375398,2529280,6264908,2064128,5209919,1264640,3099686,65280,8388479,52224,6736998,38912,5019724,32512,4161343,19456,2509862,65343,8388511,52275,6737023,38950,5019743,32543,4161359,19475,2509871,65407,8388543,52326,6737049,38988,5019762,32575,4161375,19494,2509881,65471,8388575,52377,6737074,39026,5019781,32607,4161391,19513,2509890,65535,8388607,52428,6737100,39064,5019800,32639,4161407,19532,2509900,49151,8380415,39372,6730444,29336,5014936,24447,4157311,14668,2507340,32767,8372223,26316,6724044,19608,5010072,16255,4153215,9804,2505036,16383,8364031,13260,6717388,9880,5005208,8063,4149119,4940,2502476,255,8355839,204,6710988,152,5000344,127,4145023,76,2500172,4129023,10452991,3342540,8349388,2490520,6245528,2031743,5193599,1245260,3089996,8323327,12550143,6684876,10053324,4980888,7490712,4128895,6242175,2490444,3745356,12517631,14647295,10027212,11691724,7471256,8735896,6226047,7290751,3735628,4335180,16711935,16744447,13369548,13395660,9961624,9981080,8323199,8339327,4980812,4990540,16711871,16744415,13369497,13395634,9961586,9981061,8323167,8339311,4980793,4990530,16711807,16744383,13369446,13395609,9961548,9981042,8323135,8339295,4980774,4990521,16711743,16744351,13369395,13395583,9961510,9981023,8323103,8339279,4980755,4990511,3355443,5987163,8684676,11382189,14079702,16777215];function Ed(i){return Td[i]}function Ld(i){i.rewind();let t=i.next();if(t.code!==101)throw Error("Bad call for skipEmbeddedObject()");do t=i.next();while(t.code!==0);i.rewind()}function Md(i,t,e){if(O(t,102))return Gt(t,e,i),!0;switch(t.code){case 0:i.type=t.value;break;case 5:i.handle=t.value;break;case 330:i.ownerBlockRecordSoftId=t.value;break;case 67:i.isInPaperSpace=!!t.value;break;case 8:i.layer=t.value;break;case 6:i.lineType=t.value;break;case 347:i.materialObjectHardId=t.value;break;case 62:i.colorIndex=t.value,i.color=Ed(Math.abs(t.value));break;case 370:i.lineweight=t.value;break;case 48:i.lineTypeScale=t.value;break;case 60:i.isVisible=!!t.value;break;case 92:i.proxyByte=t.value;break;case 310:i.proxyEntity=t.value;break;case 100:break;case 420:i.color=t.value;break;case 430:i.transparency=t.value;break;case 390:i.plotStyleHardId=t.value;break;case 284:i.shadowMode=t.value;break;case 1001:(i.xdata??(i.xdata=[])).push(Cl(t,e));break;default:return!1}return!0}function Wl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let kd={textStyle:"STANDARD",extrusionDirection:{x:0,y:0,z:1},rotation:0},Mi=[{code:46,name:"annotationHeight",parser:l},{code:101,parser(i,t){Ld(t)}},{code:50,name:"columnHeight",parser:l},{code:49,name:"columnGutter",parser:l},{code:48,name:"columnWidth",parser:l},{code:79,name:"columnAutoHeight",parser:l},{code:78,name:"columnFlowReversed",parser:l},{code:76,name:"columnCount",parser:l},{code:75,name:"columnType",parser:l},{code:441,name:"backgroundFillTransparency",parser:l},{code:63,name:"backgroundFillColor",parser:l},{code:45,name:"fillBoxScale",parser:l},{code:[...hn(430,440)],name:"backgroundColor",parser:l},{code:[...hn(420,430)],name:"backgroundColor",parser:l},{code:90,name:"backgroundFill",parser:l},{code:44,name:"lineSpacing",parser:l},{code:73,name:"lineSpacingStyle",parser:l},{code:50,name:"rotation",parser:l},{code:43},{code:42},{code:11,name:"direction",parser:f},{code:210,name:"extrusionDirection",parser:f},{code:7,name:"styleName",parser:l},..._n("text"),{code:72,name:"drawingDirection",parser:l},{code:71,name:"attachmentPoint",parser:l},{code:41,name:"width",parser:l},{code:40,name:"height",parser:l},{code:10,name:"insertionPoint",parser:f},{code:100,name:"subclassMarker",parser:l},...V];class Hl{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Wl(this,"parser",E(Mi,kd))}}function Gl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Wl(Hl,"ForEntityName","MTEXT");let vd={thickness:0,rotation:0,scale:1,obliqueAngle:0,textStyle:"STANDARD",textGenerationFlag:0,horizontalJustification:0,verticalJustification:0,extrusionDirection:{x:0,y:0,z:1}},Cd=[...Mi.slice(Mi.findIndex(({name:i})=>i==="columnType"),Mi.findIndex(({name:i})=>i==="subclassMarker")+1),{code:100},{code:0,parser(i){if(!O(i,0,"MTEXT"))return ri}},{code:2,name:"definitionTag",parser:l},{code:40,name:"annotationScale",parser:l},{code:10,name:"alignmentPoint",parser:f},{code:340,name:"secondaryAttributesHardId",parser:l},{code:70,name:"numberOfSecondaryAttributes",parser:l},{code:70,name:"isReallyLocked",parser:T},{code:70,name:"mtextFlag",parser:l},{code:280,name:"isDuplicatedEntriesKeep",parser:T},{code:100},{code:280,name:"lockPositionFlag",parser:T},{code:210,name:"extrusionDirection",parser:f},{code:11,name:"alignmentPoint",parser:f},{code:74,name:"verticalJustification",parser:l},{code:72,name:"horizontalJustification",parser:l},{code:71,name:"textGenerationFlag",parser:l},{code:7,name:"textStyle",parser:l},{code:51,name:"obliqueAngle",parser:l},{code:41,name:"scale",parser:l},{code:50,name:"rotation",parser:l},{code:73},{code:70,name:"attributeFlag",parser:l},{code:2,name:"tag",parser:l},{code:280},{code:100,name:"subclassMarker",parser:l},{code:1,name:"text",parser:l},{code:40,name:"textHeight",parser:l},{code:10,name:"startPoint",parser:f},{code:39,name:"thickness",parser:l},{code:100},...V];class Ul{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Gl(this,"parser",E(Cd,vd))}}function Yl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Gl(Ul,"ForEntityName","ATTRIB");let Od=[..._n("data"),{code:70,name:"version",parser:l},{code:100,name:"subclassMarker",parser:l},...V];class Xl{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Yl(this,"parser",E(Od))}}function $l(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Yl(Xl,"ForEntityName","BODY");let Nd={thickness:0,extrusionDirection:{x:0,y:0,z:1}},Bd=[{code:210,name:"extrusionDirection",parser:f},{code:40,name:"radius",parser:l},{code:10,name:"center",parser:f},{code:39,name:"thickness",parser:l},{code:100,name:"subclassMarker",parser:l},...V];class ql{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){$l(this,"parser",E(Bd,Nd))}}function Zl(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}$l(ql,"ForEntityName","CIRCLE");let Rd={extrusionDirection:{x:0,y:0,z:1}},Fd=[{code:42,name:"endAngle",parser:l},{code:41,name:"startAngle",parser:l},{code:40,name:"axisRatio",parser:l},{code:210,name:"extrusionDirection",parser:f},{code:11,name:"majorAxisEndPoint",parser:f},{code:10,name:"center",parser:f},{code:100,name:"subclassMarker",parser:l},...V];class Kl{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Zl(this,"parser",E(Fd,Rd))}}function Ql(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Zl(Kl,"ForEntityName","ELLIPSE");let zd=[{code:13,name:"vertices.3",parser:f},{code:12,name:"vertices.2",parser:f},{code:11,name:"vertices.1",parser:f},{code:10,name:"vertices.0",parser:f},{code:100,name:"subclassMarker",parser:l},...V];class Jl{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Ql(this,"parser",E(zd))}}Ql(Jl,"ForEntityName","3DFACE");(Jt={})[Jt.First=1]="First",Jt[Jt.Second=2]="Second",Jt[Jt.Third=4]="Third",Jt[Jt.Fourth=8]="Fourth";let th=[{code:330,name:"sourceBoundaryObjects",parser:l,isMultiple:!0},{code:97,name:"numberOfSourceBoundaryObjects",parser:l}],Vd=[{code:11,name:"end",parser:f},{code:10,name:"start",parser:f}],Dd=[{code:73,name:"isCCW",parser:T},{code:51,name:"endAngle",parser:l},{code:50,name:"startAngle",parser:l},{code:40,name:"radius",parser:l},{code:10,name:"center",parser:f}],jd=[{code:73,name:"isCCW",parser:T},{code:51,name:"endAngle",parser:l},{code:50,name:"startAngle",parser:l},{code:40,name:"lengthOfMinorAxis",parser:l},{code:11,name:"end",parser:f},{code:10,name:"center",parser:f}],Wd=[{code:13,name:"endTangent",parser:f},{code:12,name:"startTangent",parser:f},{code:11,name:"fitDatum",isMultiple:!0,parser:f},{code:97,name:"numberOfFitData",parser:l},{code:10,name:"controlPoints",isMultiple:!0,parser(i,t){let e={...Le(t),weight:1};return(i=t.next()).code===42?e.weight=i.value:t.rewind(),e}},{code:40,name:"knots",isMultiple:!0,parser:l},{code:96,name:"numberOfControlPoints",parser:l},{code:95,name:"numberOfKnots",parser:l},{code:74,name:"isPeriodic",parser:T},{code:73,name:"splineFlag",parser:l},{code:94,name:"degree",parser:l}],Hd={[wi.Line]:Vd,[wi.Circular]:Dd,[wi.Elliptic]:jd,[wi.Spline]:Wd},Gd=[...th,{code:72,name:"edges",parser(i,t){let e={type:i.value},s=E(Hd[e.type]);if(!s)throw Error(`Invalid edge type ${e.type}`);return s(i=t.next(),t,e),e},isMultiple:!0},{code:93,name:"numberOfEdges",parser:l}],Ud=[...th,{code:10,name:"vertices",parser(i,t){let e={...Le(t),bulge:0};return(i=t.next()).code===42?e.bulge=i.value:t.rewind(),e},isMultiple:!0},{code:93,name:"numberOfVertices",parser:l},{code:73,name:"isClosed",parser:T},{code:72,name:"hasBulge",parser:T}];function Yd(i,t){let e={boundaryPathTypeFlag:i.value},s=e.boundaryPathTypeFlag&id.Polyline;return i=t.next(),s?E(Ud)(i,t,e):E(Gd)(i,t,e),e}let Xd=[{code:49,name:"dashLengths",parser:l,isMultiple:!0},{code:79,name:"numberOfDashLengths",parser:l},{code:45,name:"offset",parser:zo},{code:43,name:"base",parser:zo},{code:53,name:"angle",parser:l}];function zo(i,t){let e=i.code+1,s={x:i.value,y:1};return(i=t.next()).code===e?s.y=i.value:t.rewind(),s}function $d(i,t){let e={};return E(Xd)(i,t,e),e}function qd(i,t){let e=[];for(;i.code===463;){let s={reservedField:i.value};if((i=t.next()).code===63&&(s.colorIndex=i.value,i=t.next()),i.code===421)s.rgb=i.value,e.push(s),i=t.next();else{t.rewind();break}}return i.code!==463&&e.length>0&&t.rewind(),e}function eh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let Zd={extrusionDirection:{x:0,y:0,z:1},gradientRotation:0,colorTint:0},Kd=[{code:470,name:"gradientName",parser:l},{code:463,name:"gradientColors",parser:qd},{code:462,name:"colorTint",parser:l},{code:461,name:"gradientDefinition",parser:l},{code:460,name:"gradientRotation",parser:l},{code:453,name:"numberOfColors",parser:l},{code:452,name:"gradientColorFlag",parser:l},{code:451},{code:450,name:"gradientFlag",parser:l},{code:10,name:"seedPoints",parser:f,isMultiple:!0},{code:99},{code:11,name:"offsetVector",parser:f},{code:98,name:"numberOfSeedPoints",parser:l},{code:47,name:"pixelSize",parser:l},{code:53,name:"definitionLines",parser:$d,isMultiple:!0},{code:78,name:"numberOfDefinitionLines",parser:l},{code:77,name:"isDouble",parser:T},{code:73,name:"isAnnotated",parser:T},{code:41,name:"patternScale",parser:l},{code:52,name:"patternAngle",parser:l},{code:76,name:"patternType",parser:l},{code:75,name:"hatchStyle",parser:l},{code:92,name:"boundaryPaths",parser:Yd,isMultiple:!0},{code:91,name:"numberOfBoundaryPaths",parser:l},{code:71,name:"associativity",parser:l},{code:63,name:"patternFillColor",parser:l},{code:70,name:"solidFill",parser:l},{code:2,name:"patternName",parser:l},{code:210,name:"extrusionDirection",parser:f},{code:10,name:"elevationPoint",parser:f},{code:100,name:"subclassMarker",parser:l,pushContext:!0},...V];class sh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){eh(this,"parser",E(Kd,Zd))}}function ih(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}eh(sh,"ForEntityName","HATCH");let Qd={brightness:50,contrast:50,fade:0,clippingBoundaryPath:[]},Jd=[{code:290,name:"clipMode",parser:l},{code:14,name:"clippingBoundaryPath",isMultiple:!0,parser:f},{code:91,name:"countBoundaryPoints",parser:l},{code:71,name:"clippingBoundaryType",parser:l},{code:360,name:"imageDefReactorHandle",parser:l},{code:283,name:"fade",parser:l},{code:282,name:"contrast",parser:l},{code:281,name:"brightness",parser:l},{code:280,name:"isClipped",parser:T},{code:70,name:"flags",parser:l},{code:340,name:"imageDefHandle",parser:l},{code:13,name:"imageSize",parser:f},{code:12,name:"vPixel",parser:f},{code:11,name:"uPixel",parser:f},{code:10,name:"position",parser:f},{code:90,name:"version",parser:l},{code:100,name:"subclassMarker",parser:l},...V];class nh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){ih(this,"parser",E(Jd,Qd))}}ih(nh,"ForEntityName","IMAGE");(te={})[te.ShowImage=1]="ShowImage",te[te.ShowImageWhenNotAlignedWithScreen=2]="ShowImageWhenNotAlignedWithScreen",te[te.UseClippingBoundary=4]="UseClippingBoundary",te[te.TransparencyIsOn=8]="TransparencyIsOn";(As={})[As.Rectangular=1]="Rectangular",As[As.Polygonal=2]="Polygonal";(Ps={})[Ps.Outside=0]="Outside",Ps[Ps.Inside=1]="Inside";function rh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let tu={xScale:1,yScale:1,zScale:1,rotation:0,columnCount:0,rowCount:0,columnSpacing:0,rowSpacing:0,extrusionDirection:{x:0,y:0,z:1}},eu=[{code:210,name:"extrusionDirection",parser:f},{code:45,name:"rowSpacing",parser:l},{code:44,name:"columnSpacing",parser:l},{code:71,name:"rowCount",parser:l},{code:70,name:"columnCount",parser:l},{code:50,name:"rotation",parser:l},{code:43,name:"zScale",parser:l},{code:42,name:"yScale",parser:l},{code:41,name:"xScale",parser:l},{code:10,name:"insertionPoint",parser:f},{code:2,name:"name",parser:l},{code:66,name:"isVariableAttributes",parser:T},{code:100,name:"subclassMarker",parser:l},...V];class oh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){rh(this,"parser",E(eu,tu))}}function ah(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}rh(oh,"ForEntityName","INSERT");let su={isArrowheadEnabled:!0},iu=[{code:213,name:"offsetFromAnnotation",parser:f},{code:212,name:"offsetFromBlock",parser:f},{code:211,name:"horizontalDirection",parser:f},{code:210,name:"normal",parser:f},{code:340,name:"associatedAnnotation",parser:l},{code:77,name:"byBlockColor",parser:l},{code:10,name:"vertices",parser:f,isMultiple:!0},{code:76,name:"numberOfVertices",parser:l},{code:41,name:"textWidth",parser:l},{code:40,name:"textHeight",parser:l},{code:75,name:"isHooklineExists",parser:T},{code:74,name:"isHooklineSameDirection",parser:T},{code:73,name:"leaderCreationFlag",parser:l},{code:72,name:"isSpline",parser:T},{code:71,name:"isArrowheadEnabled",parser:T},{code:3,name:"styleName",parser:l},{code:100,name:"subclassMarker",parser:l},...V];class lh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){ah(this,"parser",E(iu,su))}}ah(lh,"ForEntityName","LEADER");(ee={})[ee.TextAnnotation=0]="TextAnnotation",ee[ee.ToleranceAnnotation=1]="ToleranceAnnotation",ee[ee.BlockReferenceAnnotation=2]="BlockReferenceAnnotation",ee[ee.NoAnnotation=3]="NoAnnotation";function hh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let nu={thickness:0,extrusionDirection:{x:0,y:0,z:1}},ru=[{code:210,name:"extrusionDirection",parser:f},{code:11,name:"endPoint",parser:f},{code:10,name:"startPoint",parser:f},{code:39,name:"thickness",parser:l},{code:100,name:"subclassMarker",parser:l},...V];class ch{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){hh(this,"parser",E(ru,nu))}}function dh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}hh(ch,"ForEntityName","LINE");let ou=[{code:280,name:"shadowMapSoftness",parser:l},{code:91,name:"shadowMapSize",parser:l},{code:73,name:"shadowType",parser:l},{code:293,name:"isShadowCast",parser:T},{code:51,name:"falloffAngle",parser:l},{code:50,name:"hotspotAngle",parser:l},{code:42,name:"limitEnd",parser:l},{code:41,name:"limitStart",parser:l},{code:292,name:"isAttenuationLimited",parser:T},{code:72,name:"attenuationType",parser:l},{code:11,name:"target",parser:f},{code:10,name:"position",parser:f},{code:40,name:"intensity",parser:l},{code:291,name:"isPlotGlyph",parser:T},{code:290,name:"isOn",parser:T},{code:421,name:"lightColorInstance",parser:l},{code:63,name:"lightColorIndex",parser:l},{code:70,name:"lightType",parser:l},{code:1,name:"name",parser:l},{code:90,name:"version",parser:l},{code:100,name:"subclassMarker",parser:l},...V];class uh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){dh(this,"parser",E(ou))}}dh(uh,"ForEntityName","LIGHT");(We={})[We.Distant=1]="Distant",We[We.Point=2]="Point",We[We.Spot=3]="Spot";(He={})[He.None=0]="None",He[He.InverseLinear=1]="InverseLinear",He[He.InverseSquare=2]="InverseSquare";let au={flag:0,elevation:0,thickness:0,extrusionDirection:{x:0,y:0,z:1},vertices:[]},lu={bulge:0},hu=[{code:42,name:"bulge",parser:l},{code:41,name:"endWidth",parser:l},{code:40,name:"startWidth",parser:l},{code:91,name:"id",parser:l},{code:20,name:"y",parser:l},{code:10,name:"x",parser:l}],cu=[{code:210,name:"extrusionDirection",parser:f},{code:10,name:"vertices",isMultiple:!0,parser(i,t){let e={};return E(hu,lu)(i,t,e),e}},{code:39,name:"thickness",parser:l},{code:38,name:"elevation",parser:l},{code:43,name:"constantWidth",parser:l},{code:70,name:"flag",parser:l},{code:90,name:"numberOfVertices",parser:l},{code:100,name:"subclassMarker",parser:l},...V];class ki{parseEntity(t,e){let s={};return E(cu,au)(e,t,s),s}}(Ln="ForEntityName")in ki?Object.defineProperty(ki,Ln,{value:"LWPOLYLINE",enumerable:!0,configurable:!0,writable:!0}):ki[Ln]="LWPOLYLINE";(Ts={})[Ts.IS_CLOSED=1]="IS_CLOSED",Ts[Ts.PLINE_GEN=128]="PLINE_GEN";function gh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let du=[{code:90,name:"overridenSubEntityCount",parser:l},{code:140,name:"edgeCreaseWeights",parser:l,isMultiple:!0},{code:95,name:"edgeCreaseCount",parser:l},{code:94,parser(i,t,e){e.edgeCount=i.value,e.edgeIndices=[];for(let s=0;s<e.edgeCount;++s){let n=[];i=t.next(),n[0]=i.value,i=t.next(),n[1]=i.value,e.edgeIndices.push(n)}}},{code:93,parser(i,t,e){e.totalFaceIndices=i.value,e.faceIndices=[];let s=[];for(let r=0;r<e.totalFaceIndices&&!O(i,0);++r)i=t.next(),s.push(i.value);let n=0;for(;n<s.length;){let r=s[n++],o=[];for(let a=0;a<r;++a)o.push(s[n++]);e.faceIndices.push(o)}}},{code:10,name:"vertices",parser:f,isMultiple:!0},{code:92,name:"verticesCount",parser:l},{code:91,name:"subdivisionLevel",parser:l},{code:40,name:"blendCrease",parser:l},{code:72,name:"isBlendCreased",parser:T},{code:71,name:"version",parser:l},{code:100,name:"subclassMarker",parser:od,pushContext:!0},...V];class ph{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){gh(this,"parser",E(du))}}function mh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}gh(ph,"ForEntityName","MESH");let uu=[{code:42,name:"fillParameters",parser:l,isMultiple:!0},{code:75,name:"fillCount",parser:l},{code:41,name:"parameters",parser:l,isMultiple:!0},{code:74,name:"parameterCount",parser:l}],gu=[{code:[74,41,75,42],name:"elements",parser(i,t){let e=E(uu),s={};return e(i,t,s),s},isMultiple:!0},{code:13,name:"miterDirection",parser:f},{code:12,name:"direction",parser:f},{code:11,name:"position",parser:f}],pu=[{code:[11,12,13],name:"segments",parser(i,t){let e=E(gu),s={};return e(i,t,s),s},isMultiple:!0},{code:210,name:"extrusionDirection",parser:f},{code:10,name:"startPosition",parser:f},{code:73,name:"styleCount",parser:l},{code:72,name:"vertexCount",parser:l},{code:71,name:"flags",parser:l},{code:70,name:"justification",parser:l},{code:40,name:"scale",parser:l},{code:340,name:"styleObjectHandle",parser:l},{code:2,name:"name",parser:l},{code:100,name:"subclassMarker",parser:l,pushContext:!0},...V];class yh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){mh(this,"parser",E(pu))}}mh(yh,"ForEntityName","MLINE");(Ge={})[Ge.Top=0]="Top",Ge[Ge.Zero=1]="Zero",Ge[Ge.Bottom=2]="Bottom";(se={})[se.HasVertex=1]="HasVertex",se[se.Closed=2]="Closed",se[se.SuppressStartCaps=4]="SuppressStartCaps",se[se.SuppressEndCaps=8]="SuppressEndCaps";(Ue={})[Ue.LEFT_TO_RIGHT=1]="LEFT_TO_RIGHT",Ue[Ue.TOP_TO_BOTTOM=3]="TOP_TO_BOTTOM",Ue[Ue.BY_STYLE=5]="BY_STYLE";function _h(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let mu={},yu=[{code:300,parser:function(i,t,e){var r;let s;if(i.value==="CONTEXT_DATA{")for(;t.hasNext();){var n;if((s=t.next()).code===301)break;switch(s.code){case 10:e.contentBasePosition=rt(s,t);break;case 11:e.normal=rt(s,t);break;case 12:e.textAnchor=rt(s,t);break;case 13:e.textDirection=rt(s,t);break;case 14:ae(e).normal=rt(s,t);break;case 15:ae(e).position=rt(s,t);break;case 16:ae(e).scale=rt(s,t);break;case 40:e.contentScale=s.value;break;case 41:case 44:e.textHeight=s.value;break;case 42:e.textRotation=s.value;break;case 43:e.textWidth=s.value;break;case 45:e.textLineSpacingFactor=s.value;break;case 46:ae(e).rotation=s.value;break;case 47:(n=ae(e)).transformationMatrix??(n.transformationMatrix=[]),(r=ae(e).transformationMatrix)==null||r.push(s.value);break;case 90:e.textColor=s.value;break;case 91:e.textBackgroundColor=s.value;break;case 92:e.textBackgroundTransparency=s.value;break;case 93:ae(e).color=s.value;break;case 110:e.planeOrigin=rt(s,t);break;case 111:e.planeXAxisDirection=rt(s,t);break;case 112:e.planeYAxisDirection=rt(s,t);break;case 140:e.arrowheadSize=s.value;break;case 141:e.textBackgroundScaleFactor=s.value;break;case 142:e.textColumnWidth=s.value;break;case 143:e.textColumnGutterWidth=s.value;break;case 144:e.textColumnHeight=s.value;break;case 145:e.landingGap=s.value;break;case 170:e.textLineSpacingStyle=s.value;break;case 171:e.textAttachment=s.value;break;case 172:e.textFlowDirection=s.value;break;case 173:e.textColumnType=s.value;break;case 290:e.hasMText=s.value;break;case 291:e.textBackgroundColorOn=s.value;break;case 292:e.textFillOn=s.value;break;case 293:e.textUseAutoHeight=s.value;break;case 294:e.textColumnFlowReversed=s.value;break;case 295:e.textUseWordBreak=s.value;break;case 296:e.hasBlock=s.value;break;case 297:e.planeNormalReversed=s.value;break;case 302:s.value==="LEADER{"&&(e.leaderSections??(e.leaderSections=[]),e.leaderSections.push(function(o,a){let h,c;if(o.value!=="LEADER{")return{leaderLines:[]};let d={leaderLines:[]};for(;a.hasNext();){if((c=a.next()).code===303){bi(d,h);break}switch(c.code){case 290:d.lastLeaderLinePointSet=c.value;break;case 291:d.doglegVectorSet=c.value;break;case 10:d.lastLeaderLinePoint=rt(c,a);break;case 11:d.doglegVector=rt(c,a);break;case 12:h??(h={}),h.start=rt(c,a);break;case 13:h??(h={}),h.end=rt(c,a),bi(d,h),h=void 0;break;case 90:d.leaderBranchIndex=c.value;break;case 40:d.doglegLength=c.value;break;case 304:c.value==="LEADER_LINE{"&&d.leaderLines.push(function(u,p){let g,m;if(u.value!=="LEADER_LINE{")return{vertices:[]};let y={vertices:[]};for(;p.hasNext();){if((m=p.next()).code===305){bi(y,g);break}switch(m.code){case 10:y.vertices.push(rt(m,p));break;case 11:g??(g={}),g.start=rt(m,p);break;case 12:g??(g={}),g.end=rt(m,p),bi(y,g),g=void 0;break;case 90:y.breakPointIndexes??(y.breakPointIndexes=[]),y.breakPointIndexes.push(m.value),g??(g={}),g.index=m.value;break;case 91:y.leaderLineIndex=m.value}}return y}(c,a))}}return d}(s,t)));break;case 304:s.value!=="LEADER_LINE{"&&(e.textContent=s.value,e.contentType??(e.contentType=2));break;case 340:e.textStyleId=s.value;break;case 341:e.blockContentId=s.value,ae(e).blockContentId=s.value}}}},{code:270,name:"version",parser:l},{code:340,name:"leaderStyleId",parser:l},{code:90,name:"propertyOverrideFlag",parser:l},{code:170,name:"leaderLineType",parser:l},{code:91,name:"leaderLineColor",parser:l},{code:341,name:"leaderLineTypeId",parser:l},{code:171,name:"leaderLineWeight",parser:l},{code:290,name:"landingEnabled",parser:T},{code:291,name:"doglegEnabled",parser:T},{code:[40,41],name:"doglegLength",parser:l},{code:342,name:"arrowheadId",parser:l},{code:42,name:"arrowheadSize",parser:l},{code:172,name:"contentType",parser:l},{code:343,name:"textStyleId",parser:l},{code:173,name:"textLeftAttachmentType",parser:l},{code:95,name:"textRightAttachmentType",parser:l},{code:174,name:"textAngleType",parser:l},{code:175,name:"textAlignmentType",parser:l},{code:92,name:"textColor",parser:l},{code:292,name:"textFrameEnabled",parser:T},{code:344,parser:function(i,t,e){e.blockContentId=i.value,ae(e).blockContentId=i.value}},{code:93,name:"blockContentColor",parser:l},{code:10,name:"blockContentScale",parser:f},{code:43,name:"blockContentRotation",parser:l},{code:176,name:"blockContentConnectionType",parser:l},{code:293,name:"annotativeScaleEnabled",parser:T},{code:94,parser:function(i,t,e){e.arrowheadOverrides??(e.arrowheadOverrides=[]),e.arrowheadOverrides.push({index:i.value})},isMultiple:!0},{code:345,parser:function(i,t,e){var s;((s=e).arrowheadOverrides??(s.arrowheadOverrides=[]),s.arrowheadOverrides.length||s.arrowheadOverrides.push({}),s.arrowheadOverrides[s.arrowheadOverrides.length-1]).handle=i.value},isMultiple:!0},{code:330,parser:function(i,t,e){e.blockAttributes??(e.blockAttributes=[]),e.blockAttributes.push({id:i.value})},isMultiple:!0},{code:177,parser:function(i,t,e){On(e).index=i.value},isMultiple:!0},{code:44,parser:function(i,t,e){On(e).width=i.value},isMultiple:!0},{code:302,parser:function(i,t,e){On(e).text=i.value},isMultiple:!0},{code:294,name:"textDirectionNegative",parser:T},{code:178,name:"textAlignInIPE",parser:l},{code:179,name:"textAttachmentPoint",parser:l},{code:271,name:"textAttachmentDirection",parser:l},{code:272,name:"bottomTextAttachmentDirection",parser:l},{code:273,name:"topTextAttachmentDirection",parser:l},{code:100,name:"subclassMarker",parser:l},...V];function rt(i,t){return Kn(f(i,t))}function bi(i,t){(t!=null&&t.start||t!=null&&t.end)&&(i.breaks??(i.breaks=[]),i.breaks.push(t))}function ae(i){return i.blockContent??(i.blockContent={})}function On(i){return i.blockAttributes??(i.blockAttributes=[]),i.blockAttributes.length||i.blockAttributes.push({}),i.blockAttributes[i.blockAttributes.length-1]}class xh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){_h(this,"parser",E(yu,mu))}}function wh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}_h(xh,"ForEntityName","MULTILEADER");let _u={thickness:0,extrusionDirection:{x:0,y:0,z:1},angle:0},xu=[{code:50,name:"angle",parser:l},{code:210,name:"extrusionDirection",parser:f},{code:39,name:"thickness",parser:l},{code:10,name:"position",parser:f},{code:100,name:"subclassMarker",parser:l},...V];class bh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){wh(this,"parser",E(xu,_u))}}function fh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}wh(bh,"ForEntityName","POINT");let wu={startWidth:0,endWidth:0,bulge:0},bu=[{code:91,name:"id",parser:l},{code:[...hn(71,75)],name:"faces",isMultiple:!0,parser:l},{code:50,name:"tangentDirection",parser:l},{code:70,name:"flag",parser:l},{code:42,name:"bulge",parser:l},{code:41,name:"endWidth",parser:l},{code:40,name:"startWidth",parser:l},{code:30,name:"z",parser:l},{code:20,name:"y",parser:l},{code:10,name:"x",parser:l},{code:100,name:"subclassMarker",parser:l},{code:100},...V];class vr{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){fh(this,"parser",E(bu,wu))}}function Sh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}fh(vr,"ForEntityName","VERTEX");let fu={thickness:0,flag:0,startWidth:0,endWidth:0,meshMVertexCount:0,meshNVertexCount:0,surfaceMDensity:0,surfaceNDensity:0,smoothType:0,extrusionDirection:{x:0,y:0,z:1},vertices:[]},Su=[{code:0,name:"vertices",isMultiple:!0,parser:(i,t)=>O(i,0,"VERTEX")?(i=t.next(),new vr().parseEntity(t,i)):ri},{code:210,name:"extrusionDirection",parser:f},{code:75,name:"smoothType",parser:l},{code:74,name:"surfaceNDensity",parser:l},{code:73,name:"surfaceMDensity",parser:l},{code:72,name:"meshNVertexCount",parser:l},{code:71,name:"meshMVertexCount",parser:l},{code:41,name:"endWidth",parser:l},{code:40,name:"startWidth",parser:l},{code:70,name:"flag",parser:l},{code:39,name:"thickness",parser:l},{code:30,name:"elevation",parser:l},{code:20},{code:10},{code:66},{code:100,name:"subclassMarker",parser:l},...V];class Ih{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Sh(this,"parser",E(Su,fu))}}Sh(Ih,"ForEntityName","POLYLINE");(it={})[it.CLOSED_POLYLINE=1]="CLOSED_POLYLINE",it[it.CURVE_FIT=2]="CURVE_FIT",it[it.SPLINE_FIT=4]="SPLINE_FIT",it[it.POLYLINE_3D=8]="POLYLINE_3D",it[it.POLYGON_3D=16]="POLYGON_3D",it[it.CLOSED_POLYGON=32]="CLOSED_POLYGON",it[it.POLYFACE=64]="POLYFACE",it[it.CONTINUOUS=128]="CONTINUOUS";var fi=((ie={})[ie.NONE=0]="NONE",ie[ie.QUADRATIC=5]="QUADRATIC",ie[ie.CUBIC=6]="CUBIC",ie[ie.BEZIER=8]="BEZIER",ie);function Ah(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let Iu=[{code:11,name:"direction",parser:f},{code:10,name:"position",parser:f},{code:100,name:"subclassMarker",parser:l},...V];class Ph{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Ah(this,"parser",E(Iu))}}function Th(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Ah(Ph,"ForEntityName","RAY");let Au=[..._n("data"),{code:70,name:"version",parser:l},{code:100,name:"subclassMarker",parser:l},...V];class Eh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Th(this,"parser",E(Au))}}function Lh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Th(Eh,"ForEntityName","REGION");let Pu={vertices:[],backLineVertices:[]},Tu=[{code:360,name:"geometrySettingHardId",parser:l},{code:12,name:"backLineVertices",isMultiple:!0,parser:f},{code:93,name:"numberOfBackLineVertices",parser:l},{code:11,name:"vertices",isMultiple:!0,parser:f},{code:92,name:"verticesCount",parser:l},{code:[63,411],name:"indicatorColor",parser:l},{code:70,name:"indicatorTransparency",parser:l},{code:41,name:"bottomHeight",parser:l},{code:40,name:"topHeight",parser:l},{code:10,name:"verticalDirection",parser:f},{code:1,name:"name",parser:l},{code:91,name:"flag",parser:l},{code:90,name:"state",parser:l},{code:100,name:"subclassMarker",parser:l},...V];class Mh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Lh(this,"parser",E(Tu,Pu))}}function kh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Lh(Mh,"ForEntityName","SECTION");let Eu={points:[],thickness:0,extrusionDirection:{x:0,y:0,z:1}},Lu=[{code:210,name:"extrusionDirection",parser:f},{code:39,name:"thickness",parser:l},{code:[...hn(10,14)],name:"points",isMultiple:!0,parser:f},{code:100,name:"subclassMarker",parser:l},...V];class vh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){kh(this,"parser",E(Lu,Eu))}}function Ch(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}kh(vh,"ForEntityName","SOLID");let Mu=[{code:350,name:"historyObjectSoftId",parser:l},{code:100,name:"subclassMarker",parser:l},..._n("data"),{code:70,name:"version",parser:l},{code:100},...V];class Oh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Ch(this,"parser",E(Mu))}}function Nh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}Ch(Oh,"ForEntityName","3DSOLID");let ku={knotTolerance:1e-6,controlTolerance:1e-6,fitTolerance:1e-9,knotValues:[],controlPoints:[],fitPoints:[]},vu=[{code:11,name:"fitPoints",isMultiple:!0,parser:f},{code:10,name:"controlPoints",isMultiple:!0,parser:f},{code:41,name:"weights",isMultiple:!0,parser:l},{code:40,name:"knots",isMultiple:!0,parser:l},{code:13,name:"endTangent",parser:f},{code:12,name:"startTangent",parser:f},{code:44,name:"fitTolerance",parser:l},{code:43,name:"controlTolerance",parser:l},{code:42,name:"knotTolerance",parser:l},{code:74,name:"numberOfFitPoints",parser:l},{code:73,name:"numberOfControlPoints",parser:l},{code:72,name:"numberOfKnots",parser:l},{code:71,name:"degree",parser:l},{code:70,name:"flag",parser:l},{code:210,name:"normal",parser:f},{code:100,name:"subclassMarker",parser:l},...V];class Bh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Nh(this,"parser",E(vu,ku))}}Nh(Bh,"ForEntityName","SPLINE");(At={})[At.NONE=0]="NONE",At[At.CLOSED=1]="CLOSED",At[At.PERIODIC=2]="PERIODIC",At[At.RATIONAL=4]="RATIONAL",At[At.PLANAR=8]="PLANAR",At[At.LINEAR=16]="LINEAR";function Rh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let Cu=[{code:280,name:"shadowMapSoftness",parser:l},{code:71,name:"shadowMapSize",parser:l},{code:70,name:"shadowType",parser:l},{code:292,name:"isSummerTime",parser:T},{code:92,name:"time",parser:l},{code:91,name:"julianDay",parser:l},{code:291,name:"hasShadow",parser:T},{code:40,name:"intensity",parser:l},{code:421,name:"lightColorInstance",parser:l},{code:63,name:"lightColorIndex",parser:l},{code:290,name:"isOn",parser:T},{code:90,name:"version",parser:l},{code:100,name:"subclassMarker",parser:l,pushContext:!0},...V.filter(i=>i.code!==100)];class Fh{parseEntity(t,e){let s={layer:""};return this.parser(e,t,s),s}constructor(){Rh(this,"parser",E(Cu))}}Rh(Fh,"ForEntityName","SUN");class vi{parseEntity(t,e){let s={};for(;!t.isEOF();){if(e.code===0){t.rewind();break}switch(e.code){case 100:s.subclassMarker=e.value,e=t.next();break;case 2:s.name=e.value,e=t.next();break;case 5:s.handle=e.value,e=t.next();break;case 10:s.startPoint=Kn(Le(t)),e=t.lastReadGroup;break;case 11:s.directionVector=Kn(Le(t)),e=t.lastReadGroup;break;case 90:s.tableValue=e.value,e=t.next();break;case 91:s.rowCount=e.value,e=t.next();break;case 92:s.columnCount=e.value,e=t.next();break;case 93:s.overrideFlag=e.value,e=t.next();break;case 94:s.borderColorOverrideFlag=e.value,e=t.next();break;case 95:s.borderLineWeightOverrideFlag=e.value,e=t.next();break;case 96:s.borderVisibilityOverrideFlag=e.value,e=t.next();break;case 141:s.rowHeightArr??(s.rowHeightArr=[]),s.rowHeightArr.push(e.value),e=t.next();break;case 142:s.columnWidthArr??(s.columnWidthArr=[]),s.columnWidthArr.push(e.value),e=t.next();break;case 280:s.version=e.value,e=t.next();break;case 310:s.bmpPreview??(s.bmpPreview=""),s.bmpPreview+=e.value,e=t.next();break;case 330:s.ownerBlockRecordSoftId=e.value,e=t.next();break;case 342:s.tableStyleId=e.value,e=t.next();break;case 343:s.blockRecordHandle=e.value,e=t.next();break;case 170:s.attachmentPoint=e.value,e=t.next();break;case 171:s.cells??(s.cells=[]),s.cells.push(function(n,r){let o=!1,a=!1,h={};for(;!n.isEOF()&&r.code!==0&&!a;)switch(r.code){case 171:if(o){a=!0;continue}h.cellType=r.value,o=!0,r=n.next();break;case 172:h.flagValue=r.value,r=n.next();break;case 173:h.mergedValue=r.value,r=n.next();break;case 174:h.autoFit=r.value,r=n.next();break;case 175:h.borderWidth=r.value,r=n.next();break;case 176:h.borderHeight=r.value,r=n.next();break;case 91:h.overrideFlag=r.value,r=n.next();break;case 178:h.virtualEdgeFlag=r.value,r=n.next();break;case 145:h.rotation=r.value,r=n.next();break;case 345:h.fieldObjetId=r.value,r=n.next();break;case 340:h.blockTableRecordId=r.value,r=n.next();break;case 146:h.blockScale=r.value,r=n.next();break;case 177:h.blockAttrNum=r.value,r=n.next();break;case 7:h.textStyle=r.value,r=n.next();break;case 140:h.textHeight=r.value,r=n.next();break;case 170:h.attachmentPoint=r.value,r=n.next();break;case 92:h.extendedCellFlags=r.value,r=n.next();break;case 285:h.rightBorderVisibility=!!(r.value??!0),r=n.next();break;case 286:h.bottomBorderVisibility=!!(r.value??!0),r=n.next();break;case 288:h.leftBorderVisibility=!!(r.value??!0),r=n.next();break;case 289:h.topBorderVisibility=!!(r.value??!0),r=n.next();break;case 301:(function(c,d,u){for(;u.code!==304;)switch(u.code){case 301:case 93:case 90:case 94:u=d.next();break;case 1:c.text=u.value,u=d.next();break;case 300:c.attrText=u.value,u=d.next();break;case 302:c.text=u.value?u.value:c.text,u=d.next();break;default:u=d.next()}})(h,n,r),r=n.next();break;default:return h}return o=!1,a=!1,h}(t,e)),e=t.lastReadGroup;break;default:Md(s,e,t),e=t.next()}}return s}}function zh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}(Mn="ForEntityName")in vi?Object.defineProperty(vi,Mn,{value:"ACAD_TABLE",enumerable:!0,configurable:!0,writable:!0}):vi[Mn]="ACAD_TABLE";let Ou=[{code:11,name:"xAxisDirection",parser:f},{code:210,name:"extrusionDirection",parser:f},{code:1,name:"text",parser:l},{code:10,name:"position",parser:f},{code:3,name:"styleName",parser:l},{code:100,name:"subclassMarker",parser:l},...V];class Vh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){zh(this,"parser",E(Ou))}}zh(Vh,"ForEntityName","TOLERANCE");var Nu=((nt={})[nt.CREATED_BY_CURVE_FIT=1]="CREATED_BY_CURVE_FIT",nt[nt.TANGENT_DEFINED=2]="TANGENT_DEFINED",nt[nt.NOT_USED=4]="NOT_USED",nt[nt.CREATED_BY_SPLINE_FIT=8]="CREATED_BY_SPLINE_FIT",nt[nt.SPLINE_CONTROL_POINT=16]="SPLINE_CONTROL_POINT",nt[nt.FOR_POLYLINE=32]="FOR_POLYLINE",nt[nt.FOR_POLYGON=64]="FOR_POLYGON",nt[nt.POLYFACE=128]="POLYFACE",nt);let Bu=[{code:[335,343,344,91],name:"softPointers",isMultiple:!0,parser:l},{code:361,name:"sunId",parser:l},{code:431,name:"ambientLightColorName",parser:l},{code:421,name:"ambientLightColorInstance",parser:l},{code:63,name:"ambientLightColorIndex",parser:l},{code:142,name:"contrast",parser:l},{code:141,name:"brightness",parser:l},{code:282,name:"defaultLightingType",parser:l},{code:292,name:"isDefaultLighting",parser:T},{code:348,name:"visualStyleId",parser:l},{code:333,name:"shadePlotId",parser:l},{code:332,name:"backgroundId",parser:l},{code:61,name:"majorGridFrequency",parser:l},{code:170,name:"shadePlotMode",parser:l},{code:146,name:"elevation",parser:l},{code:79,name:"orthographicType",parser:l},{code:346,name:"ucsBaseId",parser:l},{code:345,name:"ucsId",parser:l},{code:112,name:"ucsYAxis",parser:f},{code:111,name:"ucsXAxis",parser:f},{code:110,name:"ucsOrigin",parser:f},{code:74,name:"iconFlag",parser:l},{code:71,name:"ucsPerViewport",parser:l},{code:281,name:"renderMode",parser:l},{code:1,name:"sheetName",parser:l},{code:340,name:"clippingBoundaryId",parser:l},{code:90,name:"statusBitFlags",parser:l},{code:331,name:"frozenLayerIds",isMultiple:!0,parser:l},{code:72,name:"circleZoomPercent",parser:l},{code:51,name:"viewTwistAngle",parser:l},{code:50,name:"snapAngle",parser:l},{code:45,name:"viewHeight",parser:l},{code:44,name:"backClipZ",parser:l},{code:43,name:"frontClipZ",parser:l},{code:42,name:"perspectiveLensLength",parser:l},{code:17,name:"targetPoint",parser:f},{code:16,name:"viewDirection",parser:f},{code:15,name:"gridSpacing",parser:f},{code:14,name:"snapSpacing",parser:f},{code:13,name:"snapBase",parser:f},{code:12,name:"displayCenter",parser:f},{code:69,name:"viewportId",parser:l},{code:68,name:"status",parser:l},{code:41,name:"height",parser:l},{code:40,name:"width",parser:l},{code:10,name:"viewportCenter",parser:f},{code:100,name:"subclassMarker",parser:l,pushContext:!0},...V];class Ci{parseEntity(t,e){let s={};return E(Bu)(e,t,s),s}}function Dh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}(kn="ForEntityName")in Ci?Object.defineProperty(Ci,kn,{value:"VIEWPORT",enumerable:!0,configurable:!0,writable:!0}):Ci[kn]="VIEWPORT";let Ru={brightness:50,constrast:50,fade:0},Fu=[{code:14,name:"boundary",isMultiple:!0,parser:f},{code:91,name:"numberOfVertices",parser:l},{code:71,name:"boundaryType",parser:l},{code:360,name:"imageDefReactorHardId",parser:l},{code:283,name:"fade",parser:l},{code:282,name:"contrast",parser:l},{code:281,name:"brightness",parser:l},{code:280,name:"isClipping",parser:T},{code:70,name:"displayFlag",parser:l},{code:340,name:"imageDefHardId",parser:l},{code:13,name:"imageSize",parser:f},{code:12,name:"vDirection",parser:f},{code:11,name:"uDirection",parser:f},{code:10,name:"position",parser:f},{code:90,name:"classVersion",parser:l},{code:100,name:"subclassMarker",parser:l},...V];class jh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Dh(this,"parser",E(Fu,Ru))}}Dh(jh,"ForEntityName","WIPEOUT");(ne={})[ne.ShowImage=1]="ShowImage",ne[ne.ShowImageWhenNotAligned=2]="ShowImageWhenNotAligned",ne[ne.UseClippingBoundary=4]="UseClippingBoundary",ne[ne.Transparency=8]="Transparency";function Wh(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}let zu=[{code:11,name:"direction",parser:f},{code:10,name:"position",parser:f},{code:100,name:"subclassMarker",parser:l},...V];class Hh{parseEntity(t,e){let s={};return this.parser(e,t,s),s}constructor(){Wh(this,"parser",E(zu))}}Wh(Hh,"ForEntityName","XLINE");let Vu=0;function Gh(i){if(!i)throw TypeError("entity cannot be undefined or null");i.handle||(i.handle=Vu++)}let Du=Object.fromEntries([Nl,Li,jl,Ul,Xl,ql,Ei,Kl,Jl,nh,oh,lh,ch,uh,ki,ph,yh,Hl,xh,bh,Ih,Ph,Eh,Mh,vh,Oh,Bh,Fh,vi,Vl,Vh,sh,vr,Ci,jh,Hh].map(i=>[i.ForEntityName,new i]));function Uh(i,t){let e=[];for(;!O(i,0,"EOF");){if(i.code===0){if(i.value==="ENDBLK"||i.value==="ENDSEC"){t.rewind();break}let s=Du[i.value];if(s){let n=i.value;i=t.next();let r=s.parseEntity(t,i);r.type=n,Gh(r),e.push(r)}else t.debug}i=t.next()}return e}function Ls(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}class Vo{next(){if(!this.hasNext())return this._eof?this.debug:this.debug,{code:0,value:"EOF"};let t=parseInt(this._data[this._pointer++],10),e=Do(t,this._data[this._pointer++],this.debug),s={code:t,value:e};return O(s,0,"EOF")&&(this._eof=!0),this.lastReadGroup=s,s}peek(){if(!this.hasNext())throw this._eof?Error("Cannot call 'next' after EOF group has been read"):Error("Unexpected end of input: EOF group not read before end of file. Ended on code "+this._data[this._pointer]);let t={code:parseInt(this._data[this._pointer]),value:0};return t.value=Do(t.code,this._data[this._pointer+1],this.debug),t}rewind(t){t=t||1,this._pointer=this._pointer-2*t}hasNext(){return!this._eof&&!(this._pointer>this._data.length-2)}isEOF(){return this._eof}constructor(t,e=!1){Ls(this,"_data",void 0),Ls(this,"debug",void 0),Ls(this,"_pointer",void 0),Ls(this,"_eof",void 0),Ls(this,"lastReadGroup",void 0),this._data=t,this.debug=e,this.lastReadGroup={code:0,value:0},this._pointer=0,this._eof=!1}}function Do(i,t,e=!1){var s;let n=(s=t).endsWith("\r")?s.slice(0,-1):s;return i<=9?n:i>=10&&i<=59?parseFloat(t.trim()):i>=60&&i<=99?parseInt(t.trim()):i>=100&&i<=109?n:i>=110&&i<=149?parseFloat(t.trim()):i>=160&&i<=179?parseInt(t.trim()):i>=210&&i<=239?parseFloat(t.trim()):i>=270&&i<=289?parseInt(t.trim()):i>=290&&i<=299?function(r){if(r==="0")return!1;if(r==="1")return!0;throw TypeError("String '"+r+"' cannot be cast to Boolean type")}(t.trim()):i>=300&&i<=369?n:i>=370&&i<=389?parseInt(t.trim()):i>=390&&i<=399?n:i>=400&&i<=409?parseInt(t.trim()):i>=410&&i<=419?n:i>=420&&i<=429?parseInt(t.trim()):i>=430&&i<=439?n:i>=440&&i<=459?parseInt(t.trim()):i>=460&&i<=469?parseFloat(t.trim()):i>=470&&i<=481||i===999||i>=1e3&&i<=1009?n:i>=1010&&i<=1059?parseFloat(t.trim()):i>=1060&&i<=1071?parseInt(t.trim()):n}function ju(i,t){let e=null,s={};for(;!O(i,0,"EOF")&&!O(i,0,"ENDSEC");)i.code===9?e=typeof i.value=="string"?i.value:null:e!=null&&(i.code===10?s[e]=Le(t):s[e]=i.value),i=t.next();return s}let me=[{code:100,name:"subclassMarker",parser:l},{code:330,name:"ownerObjectId",parser:l},{code:102,isMultiple:!0,parser(i,t){for(;!O(i,0,"EOF")&&!O(i,102,"}");)i=t.next()}},{code:5,name:"handle",parser:l}],Wu=[{code:70,name:"flag",parser:l},{code:2,name:"appName",parser:l},{code:100,name:"subclassMarker",parser:l},...me],Hu=E(Wu),Gu=E([{code:310,name:"bmpPreview",parser:l},{code:281,name:"scalability",parser:l},{code:280,name:"explodability",parser:l},{code:70,name:"insertionUnits",parser:l},{code:340,name:"layoutObjects",parser:l},{code:2,name:"name",parser:l},{code:100,name:"subclassMarker",parser:l},...me]),Uu=E([...kr.map(i=>({...i,parser:l})),{code:70,name:"standardFlag",parser:l},{code:2,name:"name",parser:l},{code:100,name:"subclassMarker",parser:l},{code:105,name:"handle",parser:l},...me.filter(i=>i.code!==5)]),Yu=E([{code:347,name:"materialObjectId",parser:l},{code:390,name:"plotStyleNameObjectId",parser:l},{code:370,name:"lineweight",parser:l},{code:290,name:"isPlotting",parser:T},{code:6,name:"lineType",parser:l},{code:62,name:"colorIndex",parser:l},{code:70,name:"standardFlag",parser:l},{code:2,name:"name",parser:l},{code:100,name:"subclassMarker",parser:l},...me]),Xu=E([{code:9,name:"text",parser:l},{code:45,name:"offsetY",parser:l},{code:44,name:"offsetX",parser:l},{code:50,name:"rotation",parser:l},{code:46,name:"scale",parser:l},{code:340,name:"styleObjectId",parser:l},{code:75,name:"shapeNumber",parser:l},{code:74,name:"elementTypeFlag",parser:l},{code:49,name:"elementLength",parser:l}],{elementTypeFlag:0,elementLength:0}),$u=E([{code:49,name:"pattern",parser(i,t){let e={};return Xu(i,t,e),e},isMultiple:!0},{code:40,name:"totalPatternLength",parser:l},{code:73,name:"numberOfLineTypes",parser:l},{code:72,parser:l},{code:3,name:"description",parser:l},{code:70,name:"standardFlag",parser:l},{code:2,name:"name",parser:l},{code:100,name:"subclassMarker",parser:l},...me]),qu=E([{code:1e3,name:"extendedFont",parser:l},{code:1001},{code:4,name:"bigFont",parser:l},{code:3,name:"font",parser:l},{code:42,name:"lastHeight",parser:l},{code:71,name:"textGenerationFlag",parser:l},{code:50,name:"obliqueAngle",parser:l},{code:41,name:"widthFactor",parser:l},{code:40,name:"fixedTextHeight",parser:l},{code:70,name:"standardFlag",parser:l},{code:2,name:"name",parser:l},{code:100,name:"subclassMarker",parser:l},...me]),Zu=[{code:13,name:"orthographicOrigin",parser:f},{code:71,name:"orthographicType",parser:l},{code:346,name:"baseUcsHandle",parser:l},{code:146,name:"elevation",parser:l},{code:79,name:"isOrthographic",parser:T},{code:12,name:"yAxis",parser:f},{code:11,name:"xAxis",parser:f},{code:10,name:"origin",parser:f},{code:70,name:"flag",parser:l},{code:2,name:"name",parser:l},{code:100,name:"subclassMarker",parser:l},...me],Ku=E(Zu),Qu=[{code:346,name:"baseUcsId",parser:l},{code:345,name:"ucsId",parser:l},{code:146,name:"elevation",parser:l},{code:79,name:"orthographicType",parser:l},{code:112,name:"ucsYAxis",parser:f},{code:111,name:"ucsXAxis",parser:f},{code:110,name:"ucsOrigin",parser:f},{code:361,name:"sunHardId",parser:l},{code:348,name:"styleHardId",parser:l},{code:334,name:"liveSectionSoftId",parser:l},{code:332,name:"backgroundSoftId",parser:l},{code:73,name:"isPlottable",parser:T},{code:72,name:"isUcsAssociated",parser:T},{code:281,name:"renderMode",parser:l},{code:71,name:"viewMode",parser:l},{code:50,name:"twistAngle",parser:l},{code:44,name:"backClippingPlane",parser:l},{code:43,name:"frontClippingPlane",parser:l},{code:42,name:"lensLength",parser:l},{code:12,name:"target",parser:f},{code:11,name:"direction",parser:f},{code:10,name:"center",parser:f},{code:41,name:"width",parser:l},{code:40,name:"height",parser:l},{code:70,name:"flag",parser:l},{code:2,name:"name",parser:l},{code:100,name:"subclassMarker",parser:l},...me],Ju=E(Qu),tg=E([{code:[63,421,431],name:"ambientColor",parser:l},{code:142,name:"contrast",parser:l},{code:141,name:"brightness",parser:l},{code:282,name:"defaultLightingType",parser:l},{code:292,name:"isDefaultLightingOn",parser:T},{code:348,name:"visualStyleObjectId",parser:l},{code:333,name:"shadePlotObjectId",parser:l},{code:332,name:"backgroundObjectId",parser:l},{code:61,name:"majorGridLines",parser:l},{code:170,name:"shadePlotSetting",parser:l},{code:146,name:"elevation",parser:l},{code:79,name:"orthographicType",parser:l},{code:112,name:"ucsYAxis",parser:f},{code:111,name:"ucsXAxis",parser:f},{code:110,name:"ucsOrigin",parser:f},{code:74,name:"ucsIconSetting",parser:l},{code:71,name:"viewMode",parser:l},{code:281,name:"renderMode",parser:l},{code:1,name:"styleSheet",parser:l},{code:[331,441],name:"frozenLayers",parser:l,isMultiple:!0},{code:72,name:"circleSides",parser:l},{code:51,name:"viewTwistAngle",parser:l},{code:50,name:"snapRotationAngle",parser:l},{code:45,name:"viewHeight",parser:l},{code:44,name:"backClippingPlane",parser:l},{code:43,name:"frontClippingPlane",parser:l},{code:42,name:"lensLength",parser:l},{code:17,name:"viewTarget",parser:f},{code:16,name:"viewDirectionFromTarget",parser:f},{code:15,name:"gridSpacing",parser:f},{code:14,name:"snapSpacing",parser:f},{code:13,name:"snapBasePoint",parser:f},{code:12,name:"center",parser:f},{code:11,name:"upperRightCorner",parser:f},{code:10,name:"lowerLeftCorner",parser:f},{code:70,name:"standardFlag",parser:l},{code:2,name:"name",parser:l},{code:100,name:"subclassMarker",parser:l},...me]),eg={APPID:Hu,BLOCK_RECORD:Gu,DIMSTYLE:Uu,LAYER:Yu,LTYPE:$u,STYLE:qu,UCS:Ku,VIEW:Ju,VPORT:tg},sg=E([{code:70,name:"maxNumberOfEntries",parser:l},{code:100,name:"subclassMarker",parser:l},{code:330,name:"ownerObjectId",parser:l},{code:102,parser:Gt},{code:102,parser:Gt},{code:102,parser:Gt},{code:360,isMultiple:!0},{code:5,name:"handle",parser:l},{code:2,name:"name",parser:l}]);function ig(i,t){var s;let e={};for(;!O(i,0,"EOF")&&!O(i,0,"ENDSEC");){if(O(i,0,"TABLE")){i=t.next();let n={entries:[]};sg(i,t,n),e[n.name]=n}if(O(i,0)&&!O(i,0,"ENDTAB")){let n=i.value;i=t.next();let r=eg[n];if(!r){t.debug,i=t.next();continue}let o={};r(i,t,o),(s=e[n])==null||s.entries.push(o)}i=t.next()}return e}function ng(i,t){let e={};for(;!O(i,0,"EOF")&&!O(i,0,"ENDSEC");){if(O(i,0,"BLOCK")){let s=rg(i=t.next(),t);Gh(s),s.name&&(e[s.name]=s)}i=t.next()}return e}function rg(i,t){let e={};for(;!O(i,0,"EOF");){if(O(i,0,"ENDBLK")){for(i=t.next();!O(i,0,"EOF");){if(O(i,100,"AcDbBlockEnd"))return e;i=t.next()}break}switch(i.code){case 1:e.xrefPath=i.value;break;case 2:e.name=i.value;break;case 3:e.name2=i.value;break;case 5:e.handle=i.value;break;case 8:e.layer=i.value;break;case 10:e.position=Le(t);break;case 67:e.paperSpace=!!i.value&&i.value==1;break;case 70:i.value!==0&&(e.type=i.value);break;case 100:break;case 330:e.ownerHandle=i.value;break;case 0:e.entities=Uh(i,t)}i=t.next()}return e}let ye=[{code:330,name:"ownerObjectId",parser:l},{code:102,parser:Gt},{code:102,parser:Gt},{code:102,parser:Gt},{code:5,name:"handle",parser:l}],Yh=[{code:333,name:"shadePlotId",parser:l},{code:149,name:"imageOriginY",parser:l},{code:148,name:"imageOriginX",parser:l},{code:147,name:"scaleFactor",parser:l},{code:78,name:"shadePlotCustomDPI",parser:l},{code:77,name:"shadePlotResolution",parser:l},{code:76,name:"shadePlotMode",parser:l},{code:75,name:"standardScaleType",parser:l},{code:7,name:"currentStyleSheet",parser:l},{code:74,name:"plotType",parser:l},{code:73,name:"plotRotation",parser:l},{code:72,name:"plotPaperUnit",parser:l},{code:70,name:"layoutFlag",parser:l},{code:143,name:"printScaleDenominator",parser:l},{code:142,name:"printScaleNumerator",parser:l},{code:141,name:"windowAreaYMax",parser:l},{code:140,name:"windowAreaXMax",parser:l},{code:49,name:"windowAreaYMin",parser:l},{code:48,name:"windowAreaXMin",parser:l},{code:47,name:"plotOriginY",parser:l},{code:46,name:"plotOriginX",parser:l},{code:45,name:"paperHeight",parser:l},{code:44,name:"paperWidth",parser:l},{code:43,name:"marginTop",parser:l},{code:42,name:"marginRight",parser:l},{code:41,name:"marginBottom",parser:l},{code:40,name:"marginLeft",parser:l},{code:6,name:"plotViewName",parser:l},{code:4,name:"paperSize",parser:l},{code:2,name:"configName",parser:l},{code:1,name:"pageSetupName",parser:l},{code:100,name:"subclassMarker",parser:l},...ye],og=[{code:346,name:"orthographicUcsId",parser:l},{code:345,name:"namedUcsId",parser:l},{code:331,name:"viewportId",parser:l},{code:330,name:"paperSpaceTableId",parser:l},{code:76,name:"orthographicType",parser:l},{code:17,name:"ucsYAxis",parser:f},{code:16,name:"ucsXAxis",parser:f},{code:13,name:"ucsOrigin",parser:f},{code:146,name:"elevation",parser:l},{code:15,name:"maxExtent",parser:f},{code:14,name:"minExtent",parser:f},{code:12,name:"insertionPoint",parser:f},{code:11,name:"maxLimit",parser:f},{code:10,name:"minLimit",parser:f},{code:71,name:"tabOrder",parser:l},{code:70,name:"controlFlag",parser:l},{code:1,name:"layoutName",parser:l},{code:100,name:"subclassMarker",parser:l},...Yh],ag=[{code:3,name:"entries",parser:(i,t)=>{let e={name:i.value};return(i=t.next()).code===350?e.objectSoftId=i.value:i.code===360?e.objectHardId=i.value:t.rewind(),e},isMultiple:!0},{code:281,name:"recordCloneFlag",parser:l},{code:280,name:"isHardOwned",parser:T},{code:100,name:"subclassMarker",parser:l},...ye],lg=[{code:40,name:"wcsToOCSTransform",parser:jo},{code:40,name:"ocsToWCSTransform",parser:jo},{code:41,name:"backClippingDistance",parser:l},{code:73,name:"isBackClipping",parser:T,pushContext:!0},{code:40,name:"frontClippingDistance",parser:l},{code:72,name:"isFrontClipping",parser:T,pushContext:!0},{code:71,name:"isClipBoundaryDisplayed",parser:T},{code:11,name:"position",parser:f},{code:210,name:"normal",parser:f},{code:10,name:"boundaryVertices",parser:f,isMultiple:!0},{code:70,name:"boundaryCount",parser:l},{code:100,name:"subclassMarker",parser:l},{code:100},...ye];function jo(i,t){let e=[];for(let s=0;s<3&&O(i,40);++s){let n=[];for(let r=0;r<4&&O(i,40);++r)n.push(i.value),i=t.next();e.push(n)}return t.rewind(),e}let hg=[{code:330,name:"imageDefReactorIdSoft",isMultiple:!0,parser:l},{code:90,name:"version",parser:l},{code:1,name:"fileName",parser:l},{code:10,name:"size",parser:f},{code:11,name:"sizeOfOnePixel",parser:f},{code:280,name:"isLoaded",parser:l},{code:281,name:"resolutionUnits",parser:l},{code:100,name:"subclassMarker",parser:l}],cg=[{code:179,name:"unknown1",parser:l},{code:170,name:"contentType",parser:l},{code:171,name:"drawMLeaderOrderType",parser:l},{code:172,name:"drawLeaderOrderType",parser:l},{code:90,name:"maxLeaderSegmentPoints",parser:l},{code:40,name:"firstSegmentAngleConstraint",parser:l},{code:41,name:"secondSegmentAngleConstraint",parser:l},{code:173,name:"leaderLineType",parser:l},{code:91,name:"leaderLineColor",parser:l},{code:340,name:"leaderLineTypeId",parser:l},{code:92,name:"leaderLineWeight",parser:l},{code:290,name:"landingEnabled",parser:T},{code:42,name:"landingGap",parser:l},{code:291,name:"doglegEnabled",parser:T},{code:43,name:"doglegLength",parser:l},{code:3,name:"description",parser:l},{code:341,name:"arrowheadId",parser:l},{code:44,name:"arrowheadSize",parser:l},{code:300,name:"defaultMTextContents",parser:l},{code:342,name:"textStyleId",parser:l},{code:174,name:"textLeftAttachmentType",parser:l},{code:175,name:"textAngleType",parser:l},{code:176,name:"textAlignmentType",parser:l},{code:178,name:"textRightAttachmentType",parser:l},{code:93,name:"textColor",parser:l},{code:45,name:"textHeight",parser:l},{code:292,name:"textFrameEnabled",parser:T},{code:297,name:"textAlignAlwaysLeft",parser:T},{code:46,name:"alignSpace",parser:l},{code:343,name:"blockContentId",parser:l},{code:94,name:"blockContentColor",parser:l},{code:47,name:"blockContentScale.x",parser:l},{code:49,name:"blockContentScale.y",parser:l},{code:140,name:"blockContentScale.z",parser:l},{code:293,name:"blockContentScaleEnabled",parser:T},{code:141,name:"blockContentRotation",parser:l},{code:294,name:"blockContentRotationEnabled",parser:T},{code:177,name:"blockContentConnectionType",parser:l},{code:142,name:"scale",parser:l},{code:295,name:"overwritePropertyValue",parser:T},{code:296,name:"annotative",parser:T},{code:143,name:"breakGapSize",parser:l},{code:271,name:"textAttachmentDirection",parser:l},{code:272,name:"bottomTextAttachmentDirection",parser:l},{code:273,name:"topTextAttachmentDirection",parser:l},{code:298,name:"unknown2",parser:l},{code:100,name:"subclassMarker",parser:l},...ye];function Si(i,t,e){i.elements||(i.elements=[]);let s=i.elements.find(n=>n[t]===void 0);if(s){s[t]=e;return}i.elements.push({[t]:e})}let dg=[{code:6,parser:function({value:i},t,e){Si(e,"lineType",i)},isMultiple:!0},{code:62,parser:function({value:i},t,e){var s;if(e.fillColorIndex===void 0&&!((s=e.elements)!=null&&s.length)){e.fillColorIndex=i;return}Si(e,"colorIndex",i)},isMultiple:!0},{code:420,parser:function({value:i},t,e){var s;if(e.fillColor===void 0&&!((s=e.elements)!=null&&s.length)){e.fillColor=i;return}Si(e,"color",i)},isMultiple:!0},{code:49,parser:function({value:i},t,e){Si(e,"offset",i)},isMultiple:!0},{code:71,name:"elementCount",parser:l},{code:52,name:"endAngle",parser:l},{code:51,name:"startAngle",parser:l},{code:3,name:"description",parser:l},{code:70,name:"flags",parser:l},{code:2,name:"styleName",parser:l},{code:100,name:"subclassMarker",parser:l},...ye],ug=[{code:340,name:"entityIds",parser:l,isMultiple:!0},{code:71,name:"isSelectable",parser:T},{code:70,name:"isUnnamed",parser:T},{code:300,name:"description",parser:l},{code:100,name:"subclassMarker",parser:l},...ye],gg=[{code:8,name:"layerNames",parser:l,isMultiple:!0},{code:100,name:"subclassMarker",parser:l},{code:100,name:"filterSubclassMarker",parser:l},...ye],pg=[{code:90,name:"idBufferEntryCounts",parser:l,isMultiple:!0},{code:360,name:"idBufferIds",parser:l,isMultiple:!0},{code:8,name:"layerNames",parser:l,isMultiple:!0},{code:100,name:"subclassMarker",parser:l},{code:40,name:"timeStamp",parser:l},{code:100,name:"indexSubclassMarker",parser:l},...ye],mg=[{code:75,name:"hasLastPointRef",parser:T},{code:1,name:"pointRefs",parser:function(i,t){let e={className:i.value};for(;;)switch((i=t.next()).code){case 72:e.objectOsnapType=i.value;continue;case 331:e.mainObjectId=i.value;continue;case 73:e.mainObjectSubentityType=i.value;continue;case 91:e.mainObjectGsMarker=i.value;continue;case 301:e.mainObjectXrefHandle=i.value;continue;case 40:e.nearOsnapGeometryParameter=i.value;continue;case 10:{let s=f(i,t);e.osnapPoint="z"in s?s:{...s,z:0}}continue;case 332:e.intersectionObjectId=i.value;continue;case 74:e.intersectionObjectSubentityType=i.value;continue;case 92:e.intersectionObjectGsMarker=i.value;continue;case 302:e.intersectionObjectXrefHandle=i.value;continue;default:return t.rewind(),e}},isMultiple:!0},{code:71,name:"rotatedDimensionType",parser:l},{code:70,name:"transSpaceFlag",parser:T},{code:90,name:"associativityFlag",parser:l},{code:330,name:"dimensionObjectId",parser:l},{code:100,name:"subclassMarker",parser:l},...ye],yg={LAYOUT:og,PLOTSETTINGS:Yh,DICTIONARY:ag,SPATIAL_FILTER:lg,IMAGEDEF:hg,MLEADERSTYLE:cg,MLINESTYLE:dg,GROUP:ug,LAYER_FILTER:gg,LAYER_INDEX:pg,DIMASSOC:mg};function _g(i,t){let e=[];for(;i.code!==0||!["EOF","ENDSEC"].includes(i.value);){let s=i.value,n=yg[s];if(i.code===0&&(n!=null&&n.length)){let r=E(n),o={name:s};r(i=t.next(),t,o)?(e.push(o),i=t.peek()):i=t.next()}else i=t.next()}return{byName:Pd(e,({name:s})=>s)}}function Vs(i,t,e){return t in i?Object.defineProperty(i,t,{value:e,enumerable:!0,configurable:!0,writable:!0}):i[t]=e,i}class xg{constructor(){Vs(this,"encoding","utf-8"),Vs(this,"encodingFailureFatal",!1),Vs(this,"thumbnailImageFormat","base64")}}class wg extends EventTarget{parseSync(t,e=!1){let s=new Vo(t.split(/\r\n|\r|\n/g),e);if(!s.hasNext())throw Error("Empty file");return this.parseAll(s)}parseStream(t){let e="",s=this;return new Promise((n,r)=>{t.on("data",o=>{e+=o}),t.on("end",()=>{try{let o=e.split(/\r\n|\r|\n/g),a=new Vo(o);if(!a.hasNext())throw Error("Empty file");n(s.parseAll(a))}catch(o){r(o)}}),t.on("error",o=>{r(o)})})}async parseFromUrl(t,e){let s=await fetch(t,e);if(!s.body)return null;let n=s.body.getReader(),r="";for(;;){let{done:o,value:a}=await n.read();if(o){r+=this._decoder.decode(new ArrayBuffer(0),{stream:!1});break}r+=this._decoder.decode(a,{stream:!0})}return this.parseSync(r)}parseAll(t){let e={header:{},blocks:{},entities:[],tables:{},objects:{byName:{},byTree:void 0}},s=t.next();for(;!O(s,0,"EOF");)O(s,0,"SECTION")&&(O(s=t.next(),2,"HEADER")?e.header=ju(s=t.next(),t):O(s,2,"CLASSES")?cd(s=t.next(),t,e):O(s,2,"BLOCKS")?e.blocks=ng(s=t.next(),t):O(s,2,"ENTITIES")?e.entities=Uh(s=t.next(),t):O(s,2,"TABLES")?e.tables=ig(s=t.next(),t):O(s,2,"OBJECTS")?e.objects=_g(s=t.next(),t):O(s,2,"THUMBNAILIMAGE")&&(e.thumbnailImage=function(n,r,o="base64"){let a,h="",c=0;for(;!O(n,0,"EOF")&&!O(n,0,"ENDSEC");)n.code===90?c=n.value:n.code===310&&(h+=n.value),n=r.next();if(o==="hex")a=h;else{let d=function(u){let p=u.length/2,g=new Uint8Array(p);for(let m=0;m<p;m++)g[m]=parseInt(u.substr(2*m,2),16);return g}(h);a=o==="buffer"?d:function(u){let p="";for(let g=0;g<u.length;g++)p+=String.fromCharCode(u[g]);return btoa(p)}(d)}return{size:c,data:a}}(s=t.next(),t,this._options.thumbnailImageFormat))),s=t.next();return e}constructor(t={}){super(),Vs(this,"_decoder",void 0),Vs(this,"_options",void 0);let e=new xg;this._options=Object.assign(e,t),this._decoder=new TextDecoder(this._options.encoding,{fatal:this._options.encodingFailureFatal})}}(Pt={})[Pt.NOT_APPLICABLE=0]="NOT_APPLICABLE",Pt[Pt.KEEP_EXISTING=1]="KEEP_EXISTING",Pt[Pt.USE_CLONE=2]="USE_CLONE",Pt[Pt.XREF_VALUE_NAME=3]="XREF_VALUE_NAME",Pt[Pt.VALUE_NAME=4]="VALUE_NAME",Pt[Pt.UNMANGLE_NAME=5]="UNMANGLE_NAME";(Ye={})[Ye.NOUNIT=0]="NOUNIT",Ye[Ye.CENTIMETERS=2]="CENTIMETERS",Ye[Ye.INCH=5]="INCH";(Es={})[Es.PSLTSCALE=1]="PSLTSCALE",Es[Es.LIMCHECK=2]="LIMCHECK";(Xe={})[Xe.INCHES=0]="INCHES",Xe[Xe.MILLIMETERS=1]="MILLIMETERS",Xe[Xe.PIXELS=2]="PIXELS";(Tt={})[Tt.LAST_SCREEN_DISPLAY=0]="LAST_SCREEN_DISPLAY",Tt[Tt.DRAWING_EXTENTS=1]="DRAWING_EXTENTS",Tt[Tt.DRAWING_LIMITS=2]="DRAWING_LIMITS",Tt[Tt.VIEW_SPECIFIED=3]="VIEW_SPECIFIED",Tt[Tt.WINDOW_SPECIFIED=4]="WINDOW_SPECIFIED",Tt[Tt.LAYOUT_INFORMATION=5]="LAYOUT_INFORMATION";(re={})[re.AS_DISPLAYED=0]="AS_DISPLAYED",re[re.WIREFRAME=1]="WIREFRAME",re[re.HIDDEN=2]="HIDDEN",re[re.RENDERED=3]="RENDERED";(Et={})[Et.DRAFT=0]="DRAFT",Et[Et.PREVIEW=1]="PREVIEW",Et[Et.NORMAL=2]="NORMAL",Et[Et.PRESENTATION=3]="PRESENTATION",Et[Et.MAXIMUM=4]="MAXIMUM",Et[Et.CUSTOM=5]="CUSTOM";(oe={})[oe.NONE=0]="NONE",oe[oe.AbsoluteRotation=1]="AbsoluteRotation",oe[oe.TextEmbedded=2]="TextEmbedded",oe[oe.ShapeEmbedded=4]="ShapeEmbedded";(vn={})[vn.PaperSpace=1]="PaperSpace";($e={})[$e.XrefDependent=16]="XrefDependent",$e[$e.XrefResolved=32]="XrefResolved",$e[$e.Referenced=64]="Referenced";(Lt={})[Lt.Off=0]="Off",Lt[Lt.Perspective=1]="Perspective",Lt[Lt.ClipFront=2]="ClipFront",Lt[Lt.ClipBack=4]="ClipBack",Lt[Lt.UcsFollow=8]="UcsFollow",Lt[Lt.ClipFrontByFrontZ=16]="ClipFrontByFrontZ";class bg{parse(t){const e=new wg,s=this.getDxfInfoFromBuffer(t);let n="";return s.version&&s.version.value<=23&&s.encoding?n=new TextDecoder(s.encoding).decode(t):n=new TextDecoder().decode(t),e.parseSync(n)}getDxfInfoFromBuffer(t){var c,d,u;const s=new TextDecoder("utf-8");let n=0,r="",o=null,a=null,h=!1;for(;n<t.byteLength;){const p=Math.min(n+65536,t.byteLength),g=t.slice(n,p);n=p;const y=(r+s.decode(g,{stream:!0})).split(/\r?\n/);r=y.pop()??"";for(let b=0;b<y.length;b++){const x=y[b].trim();if(x==="SECTION"&&((c=y[b+2])==null?void 0:c.trim())==="HEADER")h=!0;else if(x==="ENDSEC"&&h)return{version:o,encoding:a};if(h&&x==="$ACADVER"){const I=(d=y[b+2])==null?void 0:d.trim();I&&(o=new kt(I))}else if(h&&x==="$DWGCODEPAGE"){const I=(u=y[b+2])==null?void 0:u.trim();if(I){const S=nr[I];a=na(S)}}if(o&&a)return{version:o,encoding:a}}}return{version:o,encoding:a}}}class Wo{convert(t){const e=this.createEntity(t);return e&&this.processCommonAttrs(t,e),e}createEntity(t){return t.type=="3DFACE"?this.convertFace(t):t.type=="ARC"?this.convertArc(t):t.type=="ATTDEF"?this.convertAttributeDefinition(t):t.type=="ATTRIB"?this.convertAttribute(t):t.type=="CIRCLE"?this.convertCirle(t):t.type=="DIMENSION"?this.convertDimension(t):t.type=="ELLIPSE"?this.convertEllipse(t):t.type=="HATCH"?this.convertHatch(t):t.type=="IMAGE"?this.convertImage(t):t.type=="LEADER"?this.convertLeader(t):t.type=="LINE"?this.convertLine(t):t.type=="LWPOLYLINE"?this.convertLWPolyline(t):t.type=="MTEXT"?this.convertMText(t):t.type=="MLINE"?this.convertMLine(t):t.type=="MULTILEADER"||t.type=="MLEADER"?this.convertMLeader(t):t.type=="POLYLINE"?this.convertPolyline(t):t.type=="POINT"?this.convertPoint(t):t.type=="RAY"?this.convertRay(t):t.type=="SPLINE"?this.convertSpline(t):t.type=="ACAD_TABLE"?this.convertTable(t):t.type=="TEXT"?this.convertText(t):t.type=="SOLID"?this.convertSolid(t):t.type=="VIEWPORT"?this.convertViewport(t):t.type=="WIPEOUT"?this.convertWipeout(t):t.type=="XLINE"?this.convertXline(t):t.type=="INSERT"?this.convertBlockReference(t):null}convertFace(t){const e=new ji;return t.vertices.forEach((s,n)=>e.setVertexAt(n,s)),e}convertArc(t){const e=t.extrusionDirection??_.Z_AXIS;return new Ri(Hn(t.center,e),t.radius,k.degToRad(t.startAngle),k.degToRad(t.endAngle),e)}convertAttributeCommon(t,e){e.textString=t.text,e.height=t.textHeight,e.position.copy(t.startPoint),e.rotation=t.rotation,e.oblique=t.obliqueAngle??0,e.thickness=t.thickness,e.tag=t.tag,e.fieldLength=0,e.isInvisible=(t.attributeFlag&tt.Invisible)!==0,e.isConst=(t.attributeFlag&tt.Const)!==0,e.isVerifiable=(t.attributeFlag&tt.Verifiable)!==0,e.isPreset=(t.attributeFlag&tt.Preset)!==0,e.isReallyLocked=!!t.isReallyLocked,e.isMTextAttribute=(t.mtextFlag&jt.MultiLine)!==0,e.isConstMTextAttribute=(t.mtextFlag&jt.ConstMultiLine)!==0}convertAttribute(t){const e=new zi;return this.convertAttributeCommon(t,e),e.styleName=t.textStyle,e.horizontalMode=t.horizontalJustification,e.verticalMode=t.verticalJustification,e.widthFactor=t.scale??1,e.lockPositionInBlock=t.lockPositionFlag,e}convertAttributeDefinition(t){const e=new Fi;return this.convertAttributeCommon(t,e),e.styleName=t.styleName,e.horizontalMode=t.halign,e.verticalMode=t.valign,e.widthFactor=t.xScale??1,e.prompt=t.prompt,e}convertCirle(t){const e=t.extrusionDirection??_.Z_AXIS;return new Vi(Hn(t.center,e),t.radius,e)}convertEllipse(t){const e=new _(t.majorAxisEndPoint),s=e.length();return new Di(t.center,t.extrusionDirection??_.Z_AXIS,e,s,s*t.axisRatio,t.startAngle,t.endAngle)}convertLine(t){const e=t.startPoint,s=t.endPoint;return new Ys(new w(e.x,e.y,e.z||0),new w(s.x,s.y,s.z||0))}convertSpline(t){try{if(t.numberOfControlPoints>0&&t.numberOfKnots>0)return new $s(t.controlPoints,t.knots,t.weights,t.degree,!!(t.flag&1));if(t.numberOfFitPoints>0)return new $s(t.fitPoints,"Uniform",t.degree,!!(t.flag&1))}catch{}return null}convertPoint(t){const e=new $i;return e.position=t.position,e}convertSolid(t){const e=new Yi;return t.points.forEach((s,n)=>e.setPointAt(n,s)),e.thickness=t.thickness,e}convertPolyline(t){var d;const e=!!(t.flag&1),s=!!(t.flag&8),n=!!(t.flag&16),r=!!(t.flag&64),o=!!(t.flag&32),a=[],h=[],c=[];if((d=t.vertices)==null||d.map(u=>{u.flag&Nu.SPLINE_CONTROL_POINT||(r&&u.flag&128?u.flag&64?(a.push({x:u.x,y:u.y,z:u.z}),h.push(u.bulge??0)):u.faces&&u.faces.length>=3&&c.push([...u.faces]):(a.push({x:u.x,y:u.y,z:u.z}),h.push(u.bulge??0)))}),n){const u=t.meshMVertexCount,p=t.meshNVertexCount;return new Ji(u,p,a,e,o)}else{if(r)return new tn(a,c);if(s){let u=Rs.SimplePoly;return t.flag&4&&(t.smoothType==fi.CUBIC?u=Rs.CubicSplinePoly:t.smoothType==fi.QUADRATIC&&(u=Rs.QuadSplinePoly)),new Bi(u,a,e)}else{let u=rs.SimplePoly;return t.flag&2?u=rs.FitCurvePoly:t.flag&4&&(t.smoothType==fi.CUBIC?u=rs.CubicSplinePoly:t.smoothType==fi.QUADRATIC&&(u=rs.QuadSplinePoly)),new Ni(u,a,0,e,t.startWidth,t.endWidth,h)}}}convertLWPolyline(t){var n;const e=new Xi;e.closed=!!(t.flag&1);const s=t.constantWidth??-1;return(n=t.vertices)==null||n.forEach((r,o)=>{e.addVertexAt(o,new v(r.x,r.y),r.bulge,r.startWidth??s,r.endWidth??s)}),e}convertHatch(t){var n;const e=new Us;if((n=t.definitionLines)==null||n.forEach(r=>{e.definitionLines.push({angle:k.degToRad(r.angle||0),base:r.base,offset:r.offset,dashLengths:r.numberOfDashLengths>0?r.dashLengths:[]})}),e.isSolidFill=t.solidFill==sd.SolidFill,e.hatchStyle=t.hatchStyle,e.patternName=t.patternName,e.patternType=t.patternType,e.patternAngle=t.patternAngle==null?0:k.degToRad(t.patternAngle),e.patternScale=t.patternScale==null?0:t.patternScale,t.boundaryPaths.forEach(r=>{if(r.boundaryPathTypeFlag&2){const a=r,h=new at;h.closed=a.isClosed,a.vertices.forEach((c,d)=>{h.addVertexAt(d,{x:c.x,y:c.y,bulge:c.bulge})}),e.add(h)}else{const a=r,h=[];a.edges.forEach(d=>{if(d.type==1){const u=d;h.push(new Wt(u.start,u.end))}else if(d.type==2){const u=d;h.push(new Te(u.center,u.radius,k.degToRad(u.startAngle||0),k.degToRad(u.endAngle||0),!u.isCCW))}else if(d.type==3){const u=d;new $().subVectors(u.end,u.center);const g=Math.sqrt(Math.pow(u.end.x,2)+Math.pow(u.end.y,2)),m=g*u.lengthOfMinorAxis;let y=k.degToRad(u.startAngle||0),b=k.degToRad(u.endAngle||0);const x=Math.atan2(u.end.y,u.end.x);u.isCCW||(y=Math.PI*2-y,b=Math.PI*2-b),h.push(new Hs({...u.center,z:0},g,m,y,b,!u.isCCW,x))}else if(d.type==4){const u=d;if(u.numberOfControlPoints>0&&u.numberOfKnots>0){const p=u.controlPoints.map(y=>({x:y.x,y:y.y,z:0}));let g=!0;const m=u.controlPoints.map(y=>(y.weight==null&&(g=!1),y.weight||1));h.push(new Ht(p,u.knots,g?m:void 0))}else if(u.numberOfFitData>0){const p=u.fitDatum.map(g=>({x:g.x,y:g.y,z:0}));h.push(new Ht(p,"Uniform"))}}});const c=Gs.buildFromEdges(h);c.length==0&&h.length>0?e.add(new Gs(h)):c.forEach(d=>e.add(d))}}),t.gradientFlag){const r=t;if(e.hatchObjectType=br.GradientObject,e.gradientName=r.gradientName,e.gradientAngle=r.gradientRotation??0,e.gradientShift=r.gradientDefinition??0,e.gradientOneColorMode=r.gradientColorFlag==1,e.shadeTintValue=r.colorTint??0,r.gradientColors){const o=r.gradientColors.length;o>1?(e.gradientStartColor=r.gradientColors[0].rgb,e.gradientEndColor=r.gradientColors[1].rgb):o>0&&(e.gradientStartColor=r.gradientColors[0].rgb)}}return e}convertTable(t){const e=new Ui(t.name,t.rowCount,t.columnCount);return e.tableDataVersion=t.version,e.tableStyleId=t.tableStyleId,e.owningBlockRecordId=t.blockRecordHandle,t.directionVector&&(e.horizontalDirection=new _(t.directionVector)),e.attachmentPoint=t.attachmentPoint,e.position.copy(t.startPoint),e.tableValueFlag=t.tableValue,e.tableOverrideFlag=t.overrideFlag,e.borderColorOverrideFlag=t.borderColorOverrideFlag,e.borderLineweightOverrideFlag=t.borderLineWeightOverrideFlag,e.borderVisibilityOverrideFlag=t.borderVisibilityOverrideFlag,t.columnWidthArr.forEach((s,n)=>e.setColumnWidth(n,s)),t.rowHeightArr.forEach((s,n)=>e.setRowHeight(n,s)),t.cells.forEach((s,n)=>{e.setCell(n,s)}),e}convertText(t){const e=new cs;return e.textString=t.text,e.styleName=t.styleName,e.height=t.textHeight,e.position.copy(t.startPoint),e.rotation=k.degToRad(t.rotation||0),e.oblique=t.obliqueAngle??0,e.thickness=t.thickness,e.horizontalMode=t.halign,e.verticalMode=t.valign,e.widthFactor=t.xScale??1,e}convertMText(t){const e=new Xs;return e.contents=t.text,t.styleName!=null&&(e.styleName=t.styleName),e.height=t.height,e.width=t.width,e.rotation=k.degToRad(t.rotation||0),e.location=t.insertionPoint,e.attachmentPoint=t.attachmentPoint,t.direction&&(e.direction=new _(t.direction)),e.drawingDirection=t.drawingDirection,e}convertLeader(t){var s;const e=new Wi;return(s=t.vertices)==null||s.forEach(n=>{e.appendVertex(n)}),e.hasArrowHead=t.isArrowheadEnabled,e.hasHookLine=t.isHooklineExists,e.isHookLineSameDirection=t.isHooklineSameDirection,e.isSplined=t.isSpline,e.dimensionStyle=t.styleName??"",e.annoType=t.leaderCreationFlag,e.textHeight=t.textHeight??0,e.textWidth=t.textWidth??0,e.byBlockColor=t.byBlockColor,e.associatedAnnotation=t.associatedAnnotation??"",t.normal&&(e.normal=t.normal),t.horizontalDirection&&(e.horizontalDirection=t.horizontalDirection),t.offsetFromBlock&&(e.offsetFromBlock=t.offsetFromBlock),t.offsetFromAnnotation&&(e.offsetFromAnnotation=t.offsetFromAnnotation),e}convertMLine(t){const e=new Hi;return e.styleName=t.name||"STANDARD",e.styleObjectHandle=t.styleObjectHandle,e.scale=t.scale,e.justification=t.justification,e.flags=t.flags,e.styleCount=t.styleCount,e.startPosition=t.startPosition,e.normal=t.extrusionDirection??_.Z_AXIS,e.segments=(t.segments??[]).map(s=>{var n;return{position:s.position,direction:s.direction,miterDirection:s.miterDirection,elements:((n=s.elements)==null?void 0:n.map(r=>({parameterCount:r.parameterCount,parameters:r.parameters??[],fillCount:r.fillCount,fillParameters:r.fillParameters??[]})))??[]}}),e}convertMLeader(t){var S,L;const e=new Gi,s=t;e.version=t.version,e.leaderStyleId=t.leaderStyleId,t.leaderStyleId&&(e.mleaderStyleId=t.leaderStyleId),e.propertyOverrideFlag=t.propertyOverrideFlag,e.leaderLineType=t.leaderLineType??hs.StraightLeader,e.leaderLineColor=t.leaderLineColor,e.leaderLineTypeId=t.leaderLineTypeId,e.leaderLineWeight=t.leaderLineWeight,e.landingEnabled=t.landingEnabled,e.doglegEnabled=t.doglegEnabled??!1,e.doglegLength=t.doglegLength??0,e.arrowheadId=t.arrowheadId,e.arrowheadSize=t.arrowheadSize,e.textStyleId=t.textStyleId,e.textLeftAttachmentType=t.textLeftAttachmentType,e.textRightAttachmentType=t.textRightAttachmentType,e.textAngleType=t.textAngleType,e.textAlignmentType=t.textAlignmentType,e.textColor=t.textColor,e.textFrameEnabled=t.textFrameEnabled,e.landingGap=t.landingGap,e.textAttachment=t.textAttachment,e.textFlowDirection=t.textFlowDirection,e.blockContentId=t.blockContentId,e.blockContentColor=t.blockContentColor,e.blockContentRotation=t.blockContentRotation,e.blockContentConnectionType=t.blockContentConnectionType,e.annotativeScaleEnabled=t.annotativeScaleEnabled,e.arrowheadOverrides=t.arrowheadOverrides?t.arrowheadOverrides.map(A=>({...A})):[],e.blockAttributes=t.blockAttributes?t.blockAttributes.map(A=>({...A})):[],e.textDirectionNegative=t.textDirectionNegative,e.textAlignInIPE=t.textAlignInIPE,e.bottomTextAttachmentDirection=t.bottomTextAttachmentDirection,e.topTextAttachmentDirection=t.topTextAttachmentDirection,e.contentScale=t.contentScale,e.textLineSpacingStyle=t.textLineSpacingStyle,e.textBackgroundColor=t.textBackgroundColor,e.textBackgroundScaleFactor=t.textBackgroundScaleFactor,e.textBackgroundTransparency=t.textBackgroundTransparency,e.textBackgroundColorOn=t.textBackgroundColorOn,e.textFillOn=t.textFillOn,e.textColumnType=t.textColumnType,e.textUseAutoHeight=t.textUseAutoHeight,e.textColumnWidth=t.textColumnWidth,e.textColumnGutterWidth=t.textColumnGutterWidth,e.textColumnFlowReversed=t.textColumnFlowReversed,e.textColumnHeight=t.textColumnHeight,e.textUseWordBreak=t.textUseWordBreak,e.hasMText=t.hasMText,e.hasBlock=t.hasBlock,e.planeNormalReversed=t.planeNormalReversed,t.blockContentScale&&(e.blockContentScale=new _(t.blockContentScale)),t.contentBasePosition&&(e.contentBasePosition=new w().copy(t.contentBasePosition)),t.textAnchor&&(e.textAnchor=new w().copy(t.textAnchor)),t.planeOrigin&&(e.planeOrigin=new w().copy(t.planeOrigin)),t.planeXAxisDirection&&(e.planeXAxisDirection=new _(t.planeXAxisDirection)),t.planeYAxisDirection&&(e.planeYAxisDirection=new _(t.planeYAxisDirection));const n=s.textContent,r=n&&typeof n=="object"?n:void 0,o=typeof n=="string"&&n.length>0||this.readString(r??{},["text","contents"])!=null||this.readString(s,["text","contents","mtext"])!=null,a=t.contentType??(o?ue.MTextContent:t.blockContent?ue.BlockContent:ue.NoneContent);e.contentType=a;const h=this.readPoint(s,["normal","extrusionDirection"]);h&&(e.normal=h);const c=this.readString(r??{},["styleName","textStyleName","textStyle"])??this.readString(s,["textStyleName","textStyle","styleName","textStyleId"]);c&&(e.textStyleName=c);const d=this.readPositiveNumber(r??{},["textHeight","height"])??this.readPositiveNumber(s,["textHeight","mtextHeight","textContentHeight"])??this.readPositiveNumber(s,["arrowheadSize","contentScale"]);d!=null&&(e.textHeight=d);const u=this.readPositiveNumber(r??{},["textWidth","width"])??this.readPositiveNumber(s,["textWidth","mtextWidth","textContentWidth"]);u!=null&&(e.textWidth=u),e.textLineSpacingFactor=this.readNumber(r??{},["lineSpacingFactor","textLineSpacingFactor"])??this.readNumber(s,["textLineSpacingFactor"])??e.textLineSpacingFactor;const p=this.readNumber(r??{},["textRotation","rotation"])??this.readNumber(s,["textRotation","mtextRotation","textContentRotation"]);p!=null&&(e.textRotation=k.degToRad(p));const g=this.readPoint(s,["textDirection","mtextDirection","textDirectionVector"]);g&&(e.textDirection=g);const m=this.readNumber(s,["textAttachmentPoint","attachmentPoint"]);m!=null&&(e.textAttachmentPoint=m);const y=t.textAttachmentDirection;y!=null&&(e.textAttachmentDirection=y);const b=this.readNumber(s,["textDrawingDirection","drawingDirection"]);b!=null&&(e.textDrawingDirection=b);const x=typeof n=="string"?n:this.readString(r??{},["text","contents"])??this.readString(s,["text","contents","mtext"]),I=this.readPoint(r??{},["anchorPoint","textAnchor","textLocation","textPosition","textAnchorPoint"])??this.readPoint(s,["textAnchor","textLocation","textPosition","textAnchorPoint","contentBasePosition"]);if(x!=null&&I&&(e.mtextContent={text:x,anchorPoint:I}),t.blockContent){const A=t.blockContent;e.blockContent={blockContentId:t.blockContent.blockContentId,normal:this.readPoint(A,["normal"]),position:t.blockContent.position,scale:this.readPoint(A,["scale"]),rotation:this.readNumber(A,["rotation"]),color:this.readNumber(A,["color"]),transformationMatrix:Array.isArray(t.blockContent.transformationMatrix)?t.blockContent.transformationMatrix:[]}}else t.blockContentId&&(e.blockContent={blockContentId:t.blockContentId,scale:t.blockContentScale,rotation:t.blockContentRotation,color:t.blockContentColor,transformationMatrix:[]});return(S=this.readMLeaderLeaders(s))==null||S.forEach(A=>{e.addLeader({lastLeaderLinePoint:A.lastLeaderLinePoint,lastLeaderLinePointSet:A.lastLeaderLinePointSet,doglegVector:A.doglegVector,doglegVectorSet:A.doglegVectorSet,doglegLength:A.doglegLength??t.doglegLength,breaks:A.breaks,leaderBranchIndex:A.leaderBranchIndex,leaderLines:A.leaderLines})}),e.numberOfLeaders===0&&((L=this.readLeaderLineArray(s))==null||L.forEach(A=>{e.addLeader({doglegLength:t.doglegLength}),e.addLeaderLine(e.numberOfLeaders-1,A)})),e.numberOfLeaders===0&&t.contentBasePosition&&e.addLeader({lastLeaderLinePoint:t.contentBasePosition,lastLeaderLinePointSet:!0,doglegLength:t.doglegLength}),e}convertDimension(t){if(t.subclassMarker=="AcDbAlignedDimension"){const e=t,s=new Zs(e.subDefinitionPoint1,e.subDefinitionPoint2,e.definitionPoint);return e.insertionPoint&&(s.dimBlockPosition={...e.insertionPoint,z:0}),s.rotation=k.degToRad(e.rotationAngle||0),this.processDimensionCommonAttrs(t,s),s}else if(t.subclassMarker=="AcDbRotatedDimension"){const e=t,s=new an(e.subDefinitionPoint1,e.subDefinitionPoint2,e.definitionPoint);return e.insertionPoint&&(s.dimBlockPosition={...e.insertionPoint,z:0}),s.rotation=k.degToRad(e.rotationAngle||0),this.processDimensionCommonAttrs(t,s),s}else if(t.subclassMarker=="AcDb3PointAngularDimension"){const e=t,s=new sn(e.centerPoint,e.subDefinitionPoint1,e.subDefinitionPoint2,e.definitionPoint);return this.processDimensionCommonAttrs(t,s),s}else if(t.subclassMarker=="AcDbOrdinateDimension"){const e=t,s=new rn(e.subDefinitionPoint1,e.subDefinitionPoint2);return this.processDimensionCommonAttrs(t,s),s}else if(t.subclassMarker=="AcDbRadialDimension"){const e=t,s=new on(e.definitionPoint,e.subDefinitionPoint,e.leaderLength);return this.processDimensionCommonAttrs(t,s),s}else if(t.subclassMarker=="AcDbDiametricDimension"){const e=t,s=new nn(e.definitionPoint,e.subDefinitionPoint,e.leaderLength);return this.processDimensionCommonAttrs(t,s),s}return null}processImage(t,e){e.position.copy(t.position),e.brightness=t.brightness,e.contrast=t.contrast,e.fade=t.fade,e.imageSize.copy(t.imageSize),e.isShownClipped=(t.flags|4)>0,e.isImageShown=(t.flags|3)>0,e.isImageTransparent=(t.flags|8)>0,e.imageDefId=t.imageDefHandle,e.isClipped=t.isClipped,t.clippingBoundaryPath.forEach(s=>{e.clipBoundary.push(new v(s))}),e.width=Math.sqrt(t.uPixel.x**2+t.uPixel.y**2+t.uPixel.z**2)*t.imageSize.x,e.height=Math.sqrt(t.vPixel.x**2+t.vPixel.y**2+t.vPixel.z**2)*t.imageSize.y,e.rotation=Math.atan2(t.uPixel.y,t.uPixel.x)}convertImage(t){const e=new qs;return this.processImage(t,e),e.clipBoundaryType=t.clippingBoundaryType,e}processWipeout(t,e){e.position.copy(t.position),e.brightness=t.brightness,e.contrast=t.contrast,e.fade=t.fade,e.imageSize.copy(t.imageSize),e.isShownClipped=(t.displayFlag|4)>0,e.isImageShown=(t.displayFlag|3)>0,e.isImageTransparent=(t.displayFlag|8)>0,e.imageDefId=t.imageDefHardId,e.isClipped=t.isClipping,t.boundary.forEach(s=>{e.clipBoundary.push(new v(s))}),e.clipBoundaryType=t.boundaryType,e.width=Math.sqrt(t.uDirection.x**2+t.uDirection.y**2+t.uDirection.z**2)*t.imageSize.x,e.height=Math.sqrt(t.vDirection.x**2+t.vDirection.y**2+t.vDirection.z**2)*t.imageSize.y,e.rotation=Math.atan2(t.uDirection.y,t.uDirection.x)}convertWipeout(t){const e=new Ki;return this.processWipeout(t,e),e}convertViewport(t){const e=new Zi;return e.number=t.viewportId,e.centerPoint.copy(t.viewportCenter),e.height=t.height,e.width=t.width,e.viewCenter.copy(t.displayCenter),e.viewHeight=t.viewHeight,e}convertRay(t){const e=new qi;return e.basePoint.copy(t.position),e.unitDir.copy(t.direction),e}convertXline(t){const e=new Qi;return e.basePoint.copy(t.position),e.unitDir.copy(t.direction),e}convertBlockReference(t){const e=new Je(t.name);return t.insertionPoint&&e.position.copy(t.insertionPoint),e.scaleFactors.x=t.xScale||1,e.scaleFactors.y=t.yScale||1,e.scaleFactors.z=t.zScale||1,e.rotation=t.rotation!=null?k.degToRad(t.rotation):0,e.normal.copy(t.extrusionDirection??{x:0,y:0,z:1}),e}processDimensionCommonAttrs(t,e){e.dimBlockId=t.name,e.textPosition.copy(t.textPoint),e.textRotation=t.textRotation||0,t.textLineSpacingFactor&&(e.textLineSpacingFactor=t.textLineSpacingFactor),t.textLineSpacingStyle&&(e.textLineSpacingStyle=t.textLineSpacingStyle),e.dimensionStyleName=t.styleName,e.dimensionText=t.text||"",e.measurement=t.measurement,e.normal.copy(t.extrusionDirection??{x:0,y:0,z:1})}processCommonAttrs(t,e){e.layer=t.layer||"0",t.handle&&(e.objectId=t.handle.toString()),e.ownerId=t.ownerBlockRecordSoftId||"",t.lineType!=null&&(e.lineType=t.lineType),t.lineweight!=null&&(e.lineWeight=t.lineweight),t.lineTypeScale!=null&&(e.linetypeScale=t.lineTypeScale),t.color!=null&&e.color.setRGBValue(t.color),t.colorIndex!=null&&(e.color.colorIndex=t.colorIndex),t.colorName&&(e.color.colorName=t.colorName),t.isVisible!=null&&(e.visibility=!t.isVisible),t.transparency!=null&&(e.transparency=gn.deserialize(t.transparency))}readNumber(t,e){for(const s of e){const n=t[s];if(typeof n=="number"&&Number.isFinite(n))return n}}readPositiveNumber(t,e){const s=this.readNumber(t,e);return s!=null&&s>0?s:void 0}readString(t,e){for(const s of e){const n=t[s];if(typeof n=="string")return n}}readBoolean(t,e){for(const s of e){const n=t[s];if(typeof n=="boolean")return n;if(typeof n=="number")return n!==0}}readPoint(t,e){for(const s of e){const n=t[s];if(this.isPointLike(n))return n;if(Array.isArray(n)&&typeof n[0]=="number"&&typeof n[1]=="number")return{x:n[0],y:n[1],z:n[2]??0}}}readLeaderLineArray(t){const e=t.leaderLines;if(Array.isArray(e))return e.map(n=>{if(!n||typeof n!="object")return;const r=n.vertices;return Array.isArray(r)?r.filter(o=>this.isPointLike(o)):void 0}).filter(n=>!!n&&n.length>0);const s=t.vertices;if(Array.isArray(s)){const n=s.filter(r=>this.isPointLike(r));return n.length>0?[n]:void 0}}readMLeaderLeaders(t){const e=t.leaderSections;if(!Array.isArray(e))return;const s=[];return e.forEach(n=>{if(!n||typeof n!="object")return;const r=n,o=r.leaderLines,a=Array.isArray(o)?o.reduce((m,y)=>{const b=this.readMLeaderLine(y);return b&&m.push(b),m},[]):void 0,h={},c=this.readPoint(r,["lastLeaderLinePoint"]),d=this.readPoint(r,["doglegVector"]),u=this.readNumber(r,["doglegLength"]),p=this.readMLeaderBreaks(r.breaks),g=this.readNumber(r,["leaderBranchIndex"]);c&&(h.lastLeaderLinePoint=c),r.lastLeaderLinePointSet!=null&&(h.lastLeaderLinePointSet=this.readBoolean(r,["lastLeaderLinePointSet"])),d&&(h.doglegVector=d),r.doglegVectorSet!=null&&(h.doglegVectorSet=this.readBoolean(r,["doglegVectorSet"])),u!=null&&(h.doglegLength=u),p&&(h.breaks=p),g!=null&&(h.leaderBranchIndex=g),a&&(h.leaderLines=a),s.push(h)}),s}readMLeaderLine(t){if(!t||typeof t!="object")return;const e=t,s=e.vertices,n=Array.isArray(s)?s.filter(h=>this.isPointLike(h)):[],r=this.readMLeaderBreaks(e.breaks),o=Array.isArray(e.breakPointIndexes)?e.breakPointIndexes.filter(h=>typeof h=="number"):void 0,a=this.readNumber(e,["leaderLineIndex"]);return n.length>0||r&&r.length>0?{vertices:n,breakPointIndexes:o,leaderLineIndex:a,breaks:r}:void 0}readMLeaderBreaks(t){if(!Array.isArray(t))return;const e=t.map(s=>{if(!s||typeof s!="object")return;const n=s,r=this.readPoint(n,["start"]),o=this.readPoint(n,["end"]),a=this.readNumber(n,["index"]);if(!r||!o)return;const h={start:r,end:o};return a!=null&&(h.index=a),h}).filter(s=>!!s);return e.length>0?e:void 0}isPointLike(t){return!!t&&typeof t=="object"&&typeof t.x=="number"&&typeof t.y=="number"}}class fg{convertLayout(t,e){var r,o;const s=new ii;s.layoutName=t.layoutName,s.tabOrder=t.tabOrder,s.plotSettingsName=t.pageSetupName,s.plotCfgName=t.configName,s.canonicalMediaName=t.paperSize,s.plotViewName=t.plotViewName,s.currentStyleSheet=t.currentStyleSheet,s.plotPaperMargins={left:t.marginLeft,right:t.marginRight,top:t.marginTop,bottom:t.marginBottom},s.plotPaperSize.copy({x:t.paperWidth,y:t.paperHeight}),s.plotOrigin.copy({x:t.plotOriginX,y:t.plotOriginY}),s.plotWindowArea.min.copy({x:t.windowAreaXMin,y:t.windowAreaYMin}),s.plotWindowArea.max.copy({x:t.windowAreaXMax,y:t.windowAreaYMax}),s.customPrintScale={numerator:t.printScaleNumerator,denominator:t.printScaleDenominator},s.plotPaperUnits=t.plotPaperUnit,s.plotRotation=t.plotRotation,s.plotType=t.plotType,s.stdScaleType=t.standardScaleType,s.shadePlot=(()=>{switch(t.shadePlotMode){case 1:return os.kWireframe;case 2:return os.kHidden;case 3:return os.kRendered;default:return os.kAsDisplayed}})(),s.shadePlotResLevel=(()=>{switch(t.shadePlotResolution){case 1:return we.kPreview;case 2:return we.kNormal;case 3:return we.kPresentation;case 4:return we.kMaximum;case 5:return we.kCustom;default:return we.kDraft}})(),t.shadePlotCustomDPI!=null&&(s.shadePlotCustomDPI=t.shadePlotCustomDPI),t.shadePlotId&&(s.shadePlotId=t.shadePlotId);const n=t.layoutFlag??0;if(s.plotViewportBorders=(n&1)!==0,s.showPlotStyles=(n&2)!==0,s.plotCentered=(n&4)!==0,s.plotHidden=(n&8)!==0,s.useStandardScale=(n&16)!==0,s.plotPlotStyles=(n&32)!==0,s.scaleLineweights=(n&64)!==0,s.printLineweights=(n&128)!==0,s.drawViewportsFirst=(n&512)!==0,s.modelType=(n&1024)!==0,t.viewportId&&s.viewportArray.push(t.viewportId),t.layoutName==="Model"){const a=J.MODEL_SPACE_NAME.toUpperCase();(r=e.tables.BLOCK_RECORD)==null||r.entries.some(h=>h.name.toUpperCase()===a?(s.blockTableRecordId=h.handle,!0):!1)}else(o=e.tables.BLOCK_RECORD)==null||o.entries.some(a=>a.layoutObjects===t.handle?(s.blockTableRecordId=a.handle,!0):!1),s.blockTableRecordId||(s.blockTableRecordId=t.paperSpaceTableId);return t.minLimit&&s.limits.min.copy(t.minLimit),t.maxLimit&&s.limits.max.copy(t.maxLimit),t.minExtent&&s.extents.min.copy(t.minExtent),t.maxExtent&&s.extents.max.copy(t.maxExtent),this.processCommonAttrs(t,s),s}convertImageDef(t){const e=new gl;return e.sourceFileName=t.fileName,this.processCommonAttrs(t,e),e}convertMLeaderStyle(t){const e=new fr;return e.unknown1=t.unknown1,t.contentType!=null&&(e.contentType=t.contentType),t.drawMLeaderOrderType!=null&&(e.drawMLeaderOrderType=t.drawMLeaderOrderType),t.drawLeaderOrderType!=null&&(e.drawLeaderOrderType=t.drawLeaderOrderType),t.maxLeaderSegmentPoints!=null&&(e.maxLeaderSegmentPoints=t.maxLeaderSegmentPoints),t.firstSegmentAngleConstraint!=null&&(e.firstSegmentAngleConstraint=t.firstSegmentAngleConstraint),t.secondSegmentAngleConstraint!=null&&(e.secondSegmentAngleConstraint=t.secondSegmentAngleConstraint),t.leaderLineType!=null&&(e.leaderLineType=t.leaderLineType),t.leaderLineColor!=null&&(e.leaderLineColor=zs(t.leaderLineColor)),e.leaderLineTypeId=t.leaderLineTypeId,t.leaderLineWeight!=null&&(e.leaderLineWeight=t.leaderLineWeight),t.landingEnabled!=null&&(e.landingEnabled=t.landingEnabled),t.landingGap!=null&&(e.landingGap=t.landingGap),t.doglegEnabled!=null&&(e.doglegEnabled=t.doglegEnabled),t.doglegLength!=null&&(e.doglegLength=t.doglegLength),t.description!=null&&(e.description=t.description),e.arrowheadId=t.arrowheadId,t.arrowheadSize!=null&&(e.arrowheadSize=t.arrowheadSize),t.defaultMTextContents!=null&&(e.defaultMTextContents=t.defaultMTextContents),e.textStyleId=t.textStyleId,t.textLeftAttachmentType!=null&&(e.textLeftAttachmentType=t.textLeftAttachmentType),t.textAngleType!=null&&(e.textAngleType=t.textAngleType),t.textAlignmentType!=null&&(e.textAlignmentType=t.textAlignmentType),t.textRightAttachmentType!=null&&(e.textRightAttachmentType=t.textRightAttachmentType),t.textColor!=null&&(e.textColor=zs(t.textColor)),t.textHeight!=null&&(e.textHeight=t.textHeight),t.textFrameEnabled!=null&&(e.textFrameEnabled=t.textFrameEnabled),t.textAlignAlwaysLeft!=null&&(e.textAlignAlwaysLeft=t.textAlignAlwaysLeft),t.alignSpace!=null&&(e.alignSpace=t.alignSpace),e.blockContentId=t.blockContentId,t.blockContentColor!=null&&(e.blockContentColor=zs(t.blockContentColor)),t.blockContentScale&&(e.blockContentScale={x:t.blockContentScale.x,y:t.blockContentScale.y,z:t.blockContentScale.z??1}),t.blockContentScaleEnabled!=null&&(e.blockContentScaleEnabled=t.blockContentScaleEnabled),t.blockContentRotation!=null&&(e.blockContentRotation=t.blockContentRotation),t.blockContentRotationEnabled!=null&&(e.blockContentRotationEnabled=t.blockContentRotationEnabled),t.blockContentConnectionType!=null&&(e.blockContentConnectionType=t.blockContentConnectionType),t.scale!=null&&(e.scale=t.scale),t.overwritePropertyValue!=null&&(e.overwritePropertyValue=t.overwritePropertyValue),t.annotative!=null&&(e.annotative=t.annotative),t.breakGapSize!=null&&(e.breakGapSize=t.breakGapSize),t.textAttachmentDirection!=null&&(e.textAttachmentDirection=t.textAttachmentDirection),t.bottomTextAttachmentDirection!=null&&(e.bottomTextAttachmentDirection=t.bottomTextAttachmentDirection),t.topTextAttachmentDirection!=null&&(e.topTextAttachmentDirection=t.topTextAttachmentDirection),e.unknown2=t.unknown2,this.processCommonAttrs(t,e),e}convertMLineStyle(t){var n;const e=new Sr;if(t.styleName!=null&&(e.styleName=t.styleName),t.flags!=null&&(e.flags=t.flags),t.description!=null&&(e.description=t.description),t.fillColor!=null)e.fillColor=new j().setRGBValue(t.fillColor);else if(t.fillColorIndex!=null){const r=new j;r.colorIndex=t.fillColorIndex,e.fillColor=r}t.startAngle!=null&&(e.startAngle=t.startAngle),t.endAngle!=null&&(e.endAngle=t.endAngle);const s=Math.max(t.elementCount??0,((n=t.elements)==null?void 0:n.length)??0);return s>0&&(e.elements=Array.from({length:s},(r,o)=>{var a,h,c,d;return{offset:((h=(a=t.elements)==null?void 0:a[o])==null?void 0:h.offset)??0,color:(()=>{var p,g,m,y;const u=new j;return((g=(p=t.elements)==null?void 0:p[o])==null?void 0:g.color)!=null?u.setRGBValue(t.elements[o].color):u.colorIndex=((y=(m=t.elements)==null?void 0:m[o])==null?void 0:y.colorIndex)??256,u})(),lineType:((d=(c=t.elements)==null?void 0:c[o])==null?void 0:d.lineType)??"BYLAYER"}})),this.processCommonAttrs(t,e),e}processCommonAttrs(t,e){e.objectId=t.handle,t.ownerObjectId!=null&&(e.ownerId=t.ownerObjectId)}}class Xh{constructor(t){this.taskId=0,this.workers=new Map,this.pendingTasks=new Map,this.config={workerUrl:t.workerUrl,timeout:t.timeout??3e4,maxConcurrentWorkers:t.maxConcurrentWorkers??4}}async execute(t,e){const s=Date.now(),n=this.generateTaskId();try{return await this.executeInWorker(n,t,e||this.config.workerUrl)}catch(r){const o=Date.now()-s;return{success:!1,error:r instanceof Error?r.message:String(r),duration:o}}}async executeInWorker(t,e,s){const n=Date.now();return new Promise((r,o)=>{const a=this.getAvailableWorker(s),h=setTimeout(()=>{this.cleanupTask(t),this.releaseWorker(a),o(new Error(`Worker operation timed out after ${this.config.timeout}ms`))},this.config.timeout);this.pendingTasks.set(t,{resolve:u=>{clearTimeout(h),this.releaseWorker(a),r(u)},reject:u=>{clearTimeout(h),this.releaseWorker(a),o(u)},timeout:h});const c=u=>{const{id:p,success:g,data:m,error:y}=u.data;if(p!==t)return;this.cleanupTask(t);const b=Date.now()-n;r(g?{success:!0,data:m,duration:b}:{success:!1,error:y,duration:b})},d=u=>{this.cleanupTask(t),o(new Error(`Worker error: ${u.message}`))};a.addEventListener("message",c),a.addEventListener("error",d),a.postMessage({id:t,input:e})})}cleanupTask(t){const e=this.pendingTasks.get(t);e&&(clearTimeout(e.timeout),this.pendingTasks.delete(t))}generateTaskId(){return`task_${++this.taskId}_${Date.now()}`}detectWorkerSupport(){return typeof Worker<"u"}getAvailableWorker(t){for(const[s,n]of this.workers)if(!n.isBusy)return n.isBusy=!0,n.worker;if(this.workers.size<this.config.maxConcurrentWorkers){const s=new Worker(t,{type:"module"}),n=this.generateWorkerId(),r={worker:s,isBusy:!0,id:n,createdAt:new Date};return this.workers.set(n,r),s}const e=Array.from(this.workers.values()).sort((s,n)=>s.createdAt.getTime()-n.createdAt.getTime())[0];return e.isBusy=!0,e.worker}releaseWorker(t){for(const[e,s]of this.workers)if(s.worker===t){s.isBusy=!1;break}}generateWorkerId(){return`worker_${Date.now()}_${Math.random().toString(36).substr(2,9)}`}getStats(){return{totalWorkers:this.workers.size,busyWorkers:Array.from(this.workers.values()).filter(t=>t.isBusy).length,pendingTasks:this.pendingTasks.size,config:this.config}}destroy(){for(const[t,e]of this.pendingTasks)clearTimeout(e.timeout),e.reject(new Error("Framework destroyed"));this.pendingTasks.clear();for(const[t,e]of this.workers)e.worker.terminate();this.workers.clear()}}class $h{constructor(t){this.framework=new Xh(t)}async execute(t,e){return this.framework.execute(t,e)}getStats(){return this.framework.getStats()}destroy(){this.framework.destroy()}}function qh(i){return new $h(i)}class Sg{constructor(){this.setupMessageHandler()}setupMessageHandler(){self.onmessage=async t=>{const{id:e,input:s}=t.data;try{const n=await this.executeTask(s);this.sendResponse(e,!0,n)}catch(n){this.sendResponse(e,!1,void 0,n instanceof Error?n.message:String(n))}}}sendResponse(t,e,s,n){const r={id:t,success:e,data:s,error:n};self.postMessage(r)}}class Zh extends Mr{constructor(t={}){super(t),t.parserWorkerUrl||(t.parserWorkerUrl="/assets/dxf-parser-worker.js")}async parse(t,e){const s=this.config,n=this.getParserWorkerTimeout(t,e);if(s.useWorker&&s.parserWorkerUrl){const r=qh({workerUrl:s.parserWorkerUrl,timeout:n,maxConcurrentWorkers:1}),o=await r.execute(t);if(r.destroy(),o.success)return{model:o.data,data:{unknownEntityCount:0}};throw new Error(`Failed to parse drawing due to error: '${o.error}'`)}else return{model:new bg().parse(t),data:{unknownEntityCount:0}}}getFonts(t){var r;const e=new Map,s=o=>{if(o){const a=o.lastIndexOf(".");return a>=0?o.substring(0,a).toLowerCase():o.toLowerCase()}};(r=t.tables.STYLE)==null||r.entries.forEach(o=>{const a=[];if(o.font){const h=s(o.font);h&&a.push(h)}if(o.bigFont){const h=s(o.bigFont);h&&a.push(h)}if(o.extendedFont){const h=s(o.extendedFont);h&&a.push(h)}e.set(o.name,a)});const n=new Set;return this.getFontsInBlock(t.entities,t.blocks,e,n),Array.from(n)}getFontsInBlock(t,e,s,n){const r=/\\f(.*?)\|/g;t.forEach(o=>{if(o.type=="MTEXT"){const a=o;[...a.text.matchAll(r)].forEach(d=>{n.add(d[1].toLowerCase())});const c=s.get(a.styleName);c==null||c.forEach(d=>n.add(d))}else if(o.type=="TEXT"){const a=o,h=s.get(a.styleName);h==null||h.forEach(c=>n.add(c))}else if(o.type=="MULTILEADER"||o.type=="MLEADER"){const a=o;[...(typeof a.textContent=="string"?a.textContent:"").matchAll(r)].forEach(u=>{n.add(u[1].toLowerCase())});const c=typeof a.textStyleName=="string"?a.textStyleName:typeof a.styleName=="string"?a.styleName:void 0,d=c?s.get(c):void 0;d==null||d.forEach(u=>n.add(u))}else if(o.type=="INSERT"){const h=e[o.name];h&&h.entities&&this.getFontsInBlock(h.entities,e,s,n)}})}async processEntities(t,e,s,n,r){const o=new Wo;let a=t.entities;const h=a.length,c=new sr(h,100-n.value,s);this.config.convertByEntityType&&(a=this.groupAndFlattenByType(a));const d=new Map;for(let p=0;p<h;p++){const g=a[p];if(g.type==="ATTRIB"){const m=o.convert(g);if(m&&m.ownerId&&m.ownerId!=="0"){let y=d.get(m==null?void 0:m.ownerId);y==null&&(y=[],d.set(m.ownerId,y)),y.push(m)}}}const u=e.tables.blockTable.modelSpace;await c.processChunk(async(p,g)=>{let m=[],y=p<g?a[p].type:"";for(let x=p;x<g;x++){const I=a[x];if(!(I.ownerBlockRecordSoftId&&I.ownerBlockRecordSoftId!==u.objectId)&&I.type!=="ATTRIB"){const S=o.convert(I);if(S){if(this.config.convertByEntityType&&I.type!==y&&(u.appendEntity(m),m=[],y=I.type),I.type==="INSERT"){const L=d.get(S.objectId);L&&L.length>0&&L.forEach(A=>{S.appendAttributes(A)})}m.push(S)}}}u.appendEntity(m);let b=n.value+g/h*(100-n.value);b>100&&(b=100),r&&await r(b,"ENTITY","IN-PROGRESS")})}async processEntitiesInBlock(t,e,s=!1){const n=new Wo,r=t.length,o=[],a=e.objectId,h=[];for(let c=0;c<r;c++){const d=t[c],u=n.convert(d);u&&(d.type==="ATTRIB"?h.push(u):(!s||d.ownerBlockRecordSoftId===a)&&o.push(u))}e.appendEntity(o),h.forEach(c=>{const d=e.getIdAt(c.ownerId);d&&d.appendAttributes(c)})}processBlocks(t,e){const s=t.blocks;for(const[n,r]of Object.entries(s)){let o=e.tables.blockTable.getAt(r.name);o||(o=new J,o.objectId=r.handle,o.name=n,o.origin.copy(r.position),e.tables.blockTable.add(o)),r.entities?this.processEntitiesInBlock(r.entities,o):o.isPaperSapce&&this.processEntitiesInBlock(t.entities,o,!0)}}processHeader(t,e){const s=t.header;s.$ACADVER&&(e.version=s.$ACADVER),e.cecolor.colorIndex=s.$CECOLOR||256,e.angBase=s.$ANGBASE||0,e.angDir=s.$ANGDIR||0,s.$AUNITS!=null&&(e.aunits=s.$AUNITS),e.celtype=s.$CELTYPE||dt,e.celtscale=s.$CELTSCALE||1;const n=this.normalizeHeaderStringValue(s.$CMLSTYLE)||this.normalizeHeaderStringValue(s.CMLSTYLE)||ce;e.cmlstyle=n;const r=s.$CMLSCALE??s.CMLSCALE;typeof r=="number"&&Number.isFinite(r)&&(e.cmlscale=r);const o=this.normalizeHeaderStringValue(s.$CMLEADERSTYLE)||this.normalizeHeaderStringValue(s.CMLEADERSTYLE)||de;e.cmleaderstyle=o,e.ltscale=s.$LTSCALE||1,s.$EXTMAX&&(e.extmax=s.$EXTMAX),s.$EXTMIN&&(e.extmin=s.$EXTMIN),s.$INSUNITS!=null&&(e.insunits=s.$INSUNITS),e.osmode=s.$OSMODE||0,e.pdmode=s.$PDMODE||0,e.pdsize=s.$PDSIZE||0,e.textstyle=s.$TEXTSTYLE||Z}processBlockTables(t,e){var n;const s=(n=t.tables.BLOCK_RECORD)==null?void 0:n.entries;s&&s.length>0&&(e.tables.blockTable.removeAll(),s.forEach(r=>{const o=new J;o.objectId=r.handle,o.name=r.name,o.layoutId=r.layoutObjects,o.blockInsertUnits=r.insertionUnits,o.explodability=r.explodability,o.blockScaling=r.scalability,r.bmpPreview&&(o.bmpPreview=r.bmpPreview),e.tables.blockTable.add(o)}))}processObjects(t,e){const s=t.objects.byName,n=new fg;if("LAYOUT"in s){const r=e.objects.layout;s.LAYOUT.forEach(o=>{const a=n.convertLayout(o,t);r.setAt(a.layoutName,a)})}if("IMAGEDEF"in s){const r=e.objects.imageDefinition;s.IMAGEDEF.forEach(o=>{const a=n.convertImageDef(o);r.setAt(a.objectId,a)})}if("MLEADERSTYLE"in s){const r=e.objects.mleaderStyle;s.MLEADERSTYLE.forEach(o=>{const a=n.convertMLeaderStyle(o);r.setAt(a.objectId,a)})}if("MLINESTYLE"in s){const r=e.objects.mlineStyle;s.MLINESTYLE.forEach(o=>{const a=n.convertMLineStyle(o);r.setAt(a.styleName||a.objectId,a)})}}processViewports(t,e){var n;const s=(n=t.tables)==null?void 0:n.VPORT;if(s){this.processCommonTableAttrs(s,e.tables.viewportTable);const r=s.entries;r&&r.length>0&&r.forEach(o=>{const a=new Lr;this.processCommonTableEntryAttrs(o,a),o.circleSides&&(a.circleSides=o.circleSides),a.standardFlag=o.standardFlag,a.center.copy(o.center),a.lowerLeftCorner.copy(o.lowerLeftCorner),a.upperRightCorner.copy(o.upperRightCorner),o.snapBasePoint&&a.snapBase.copy(o.snapBasePoint),o.snapRotationAngle&&(a.snapAngle=o.snapRotationAngle),o.snapSpacing&&a.snapIncrements.copy(o.snapSpacing),o.majorGridLines&&(a.gridMajor=o.majorGridLines),o.gridSpacing&&a.gridIncrements.copy(o.gridSpacing),o.backgroundObjectId&&(a.backgroundObjectId=o.backgroundObjectId),a.gsView.center.copy(o.center),a.gsView.viewDirectionFromTarget.copy(o.viewDirectionFromTarget),a.gsView.viewTarget.copy(o.viewTarget),o.lensLength&&(a.gsView.lensLength=o.lensLength),o.frontClippingPlane&&(a.gsView.frontClippingPlane=o.frontClippingPlane),o.backClippingPlane&&(a.gsView.backClippingPlane=o.backClippingPlane),o.viewHeight&&(a.gsView.viewHeight=o.viewHeight),o.viewTwistAngle&&(a.gsView.viewTwistAngle=o.viewTwistAngle),o.frozenLayers&&(a.gsView.frozenLayers=o.frozenLayers),o.styleSheet&&(a.gsView.styleSheet=o.styleSheet),o.renderMode&&(a.gsView.renderMode=o.renderMode),o.viewMode&&(a.gsView.viewMode=o.viewMode),o.ucsIconSetting&&(a.gsView.ucsIconSetting=o.ucsIconSetting),o.ucsOrigin&&a.gsView.ucsOrigin.copy(o.ucsOrigin),o.ucsXAxis&&a.gsView.ucsXAxis.copy(o.ucsXAxis),o.ucsYAxis&&a.gsView.ucsYAxis.copy(o.ucsYAxis),o.orthographicType&&(a.gsView.orthographicType=o.orthographicType),o.shadePlotSetting&&(a.gsView.shadePlotSetting=o.shadePlotSetting),o.shadePlotObjectId&&(a.gsView.shadePlotObjectId=o.shadePlotObjectId),o.visualStyleObjectId&&(a.gsView.visualStyleObjectId=o.visualStyleObjectId),o.isDefaultLightingOn&&(a.gsView.isDefaultLightingOn=o.isDefaultLightingOn),o.defaultLightingType&&(a.gsView.defaultLightingType=o.defaultLightingType),o.brightness&&(a.gsView.brightness=o.brightness),o.contrast&&(a.gsView.contrast=o.contrast),o.ambientColor&&(a.gsView.ambientColor=o.ambientColor),e.tables.viewportTable.add(a)})}}processLayers(t,e){var n;const s=(n=t.tables)==null?void 0:n.LAYER;if(s){this.processCommonTableAttrs(s,e.tables.layerTable);const r=s.entries;r&&r.length>0&&r.forEach(o=>{const a=new j;a.colorIndex=o.colorIndex;const h=new mn({name:o.name,standardFlags:o.standardFlag,linetype:o.lineType,lineWeight:o.lineweight,isOff:o.colorIndex<0,color:a,isPlottable:o.isPlotting});this.processCommonTableEntryAttrs(o,h),e.tables.layerTable.add(h)})}}processLineTypes(t,e){var n;const s=(n=t.tables)==null?void 0:n.LTYPE;if(s){this.processCommonTableAttrs(s,e.tables.linetypeTable);const r=s.entries;r&&r.length>0&&r.forEach(o=>{const a=new Ae(o);this.processCommonTableEntryAttrs(o,a),a.name=o.name,e.tables.linetypeTable.add(a)})}}processTextStyles(t,e){var n;const s=(n=t.tables)==null?void 0:n.STYLE;if(s){this.processCommonTableAttrs(s,e.tables.textStyleTable);const r=s.entries;r&&r.length>0&&r.forEach(o=>{const a=new yn(o);this.processCommonTableEntryAttrs(o,a),e.tables.textStyleTable.add(a)})}}processDimStyles(t,e){var n;const s=(n=t.tables)==null?void 0:n.DIMSTYLE;if(s){this.processCommonTableAttrs(s,e.tables.dimStyleTable);const r=s.entries;r&&r.length>0&&r.forEach(o=>{const a={name:o.name,ownerId:o.ownerObjectId,dimpost:o.DIMPOST||"",dimapost:o.DIMAPOST||"",dimscale:o.DIMSCALE,dimasz:o.DIMASZ,dimexo:o.DIMEXO,dimdli:o.DIMDLI,dimexe:o.DIMEXE,dimrnd:o.DIMRND,dimdle:o.DIMDLE,dimtp:o.DIMTP,dimtm:o.DIMTM,dimtxt:o.DIMTXT,dimcen:o.DIMCEN,dimtsz:o.DIMTSZ,dimaltf:o.DIMALTF,dimlfac:o.DIMLFAC,dimtvp:o.DIMTVP,dimtfac:o.DIMTFAC,dimgap:o.DIMGAP,dimaltrnd:o.DIMALTRND,dimtol:o.DIMTOL==null||o.DIMTOL==0?0:1,dimlim:o.DIMLIM==null||o.DIMLIM==0?0:1,dimtih:o.DIMTIH==null||o.DIMTIH==0?0:1,dimtoh:o.DIMTOH==null||o.DIMTOH==0?0:1,dimse1:o.DIMSE1==null||o.DIMSE1==0?0:1,dimse2:o.DIMSE2==null||o.DIMSE2==0?0:1,dimtad:o.DIMTAD,dimzin:o.DIMZIN,dimazin:o.DIMAZIN,dimalt:o.DIMALT,dimaltd:o.DIMALTD,dimtofl:o.DIMTOFL,dimsah:o.DIMSAH,dimtix:o.DIMTIX,dimsoxd:o.DIMSOXD,dimclrd:o.DIMCLRD,dimclre:o.DIMCLRE,dimclrt:o.DIMCLRT,dimadec:o.DIMADEC||0,dimunit:o.DIMUNIT||2,dimdec:o.DIMDEC,dimtdec:o.DIMTDEC,dimaltu:o.DIMALTU,dimalttd:o.DIMALTTD,dimaunit:o.DIMAUNIT,dimfrac:o.DIMFRAC,dimlunit:o.DIMLUNIT,dimdsep:o.DIMDSEP?o.DIMDSEP.toString():".",dimtmove:o.DIMTMOVE||0,dimjust:o.DIMJUST,dimsd1:o.DIMSD1,dimsd2:o.DIMSD2,dimtolj:o.DIMTOLJ,dimtzin:o.DIMTZIN,dimaltz:o.DIMALTZ,dimalttz:o.DIMALTTZ,dimfit:o.DIMFIT||0,dimupt:o.DIMUPT,dimatfit:o.DIMATFIT,dimtxsty:o.DIMTXSTY||Z,dimldrblk:o.DIMLDRBLK||"",dimblk:o.DIMBLK||"",dimblk1:o.DIMBLK1||"",dimblk2:o.DIMBLK2||"",dimlwd:o.DIMLWD,dimlwe:o.DIMLWE},h=new ts(a);this.processCommonTableEntryAttrs(o,h),e.tables.dimStyleTable.add(h)})}}processCommonTableAttrs(t,e){t.handle!=null&&(e.objectId=t.handle),t.ownerObjectId!=null&&(e.ownerId=t.ownerObjectId)}processCommonTableEntryAttrs(t,e){e.name="name"in t?t.name:"",t.handle!=null&&(e.objectId=t.handle),t.ownerObjectId!=null&&(e.ownerId=t.ownerObjectId)}groupAndFlattenByType(t){const e={},s=[];for(const n of t)e[n.type]||(e[n.type]=[],s.push(n.type)),e[n.type].push(n);return s.flatMap(n=>e[n])}normalizeHeaderStringValue(t){if(typeof t!="string")return;const e=t.trim();return e.length>0?e:void 0}}class Kh extends Mr{constructor(t){super({}),this._database=t}async parse(){return{model:this._database,data:{unknownEntityCount:0}}}getFonts(){return[]}async processEntities(t,e,s,n,r){let o=t.tables.blockTable.modelSpace.newIterator().toArray();const a=o.length,h=new sr(a,100-n.value,s);this.config.convertByEntityType&&(o=this.groupAndFlattenByType(o));const c=e.tables.blockTable.modelSpace;await h.processChunk(async(d,u)=>{let p=[],g=d<u?o[d].type:"";for(let m=d;m<u;m++){const y=o[m];this.config.convertByEntityType&&y.type!==g&&(this.triggerEvents(c,p),p=[],g=y.type),p.push(y)}if(this.triggerEvents(c,p),r){let m=n.value+u/a*(100-n.value);m>100&&(m=100),await r(m,"ENTITY","IN-PROGRESS")}})}processBlocks(){const t=this._database.tables.blockTable.newIterator();for(const e of t){const s=e.newIterator().toArray();this.triggerEvents(e,s)}}processHeader(){}processBlockTables(){}processObjects(){const t=this._database.objects.layout.newIterator();for(const n of t)this._database.events.dictObjetSet.dispatch({database:this._database,object:n,key:n.layoutName});const e=this._database.objects.imageDefinition.newIterator();for(const n of e)this._database.events.dictObjetSet.dispatch({database:this._database,object:n,key:n.objectId});const s=this._database.objects.mleaderStyle.newIterator();for(const n of s)this._database.events.dictObjetSet.dispatch({database:this._database,object:n,key:n.objectId})}processViewports(){}processLayers(){this._database.tables.layerTable.newIterator().toArray().forEach(e=>{this._database.events.layerAppended.dispatch({database:this._database,layer:e})})}processLineTypes(){}processTextStyles(){}processDimStyles(){}groupAndFlattenByType(t){const e={},s=[];for(const n of t)e[n.type]||(e[n.type]=[],s.push(n.type)),e[n.type].push(n);return s.flatMap(n=>e[n])}triggerEvents(t,e){(t.isModelSapce||t.isPaperSapce)&&t.database.events.entityAppended.dispatch({database:t.database,entity:e})}}exports.ACAD_APPID=zn;exports.AC_DB_SYSTEM_VARIABLE_NAMES=$c;exports.AcCmColor=j;exports.AcCmColorMethod=P;exports.AcCmColorUtil=xe;exports.AcCmEntityColor=Jh;exports.AcCmErrors=wt;exports.AcCmEventDispatcher=tc;exports.AcCmEventManager=Q;exports.AcCmLoader=lc;exports.AcCmLoadingManager=Qo;exports.AcCmObject=$o;exports.AcCmPerformanceCollector=Jn;exports.AcCmTask=Zo;exports.AcCmTaskScheduler=Ko;exports.AcCmTransparency=gn;exports.AcCmTransparencyMethod=yt;exports.AcDb2dPolyline=Ni;exports.AcDb2dVertex=Yn;exports.AcDb2dVertexType=Ha;exports.AcDb3PointAngularDimension=sn;exports.AcDb3dPolyline=Bi;exports.AcDb3dVertex=Xn;exports.AcDb3dVertexType=Ga;exports.AcDbAbstractViewTableRecord=Er;exports.AcDbAlignedDimension=Zs;exports.AcDbAngleUnits=ir;exports.AcDbArc=Ri;exports.AcDbArcDimension=qn;exports.AcDbAttribute=zi;exports.AcDbAttributeDefinition=Fi;exports.AcDbAttributeFlags=tt;exports.AcDbAttributeMTextFlag=jt;exports.AcDbBaseWorker=Sg;exports.AcDbBatchProcessing=sr;exports.AcDbBlockReference=Je;exports.AcDbBlockScaling=dl;exports.AcDbBlockTable=xl;exports.AcDbBlockTableRecord=J;exports.AcDbCircle=Vi;exports.AcDbCodePage=nr;exports.AcDbCurve=ht;exports.AcDbDataGenerator=ml;exports.AcDbDatabase=qc;exports.AcDbDatabaseConverter=Mr;exports.AcDbDatabaseConverterManager=Vt;exports.AcDbDiametricDimension=nn;exports.AcDbDictionary=Ze;exports.AcDbDimArrowType=yl;exports.AcDbDimStyleTable=wl;exports.AcDbDimStyleTableRecord=ts;exports.AcDbDimTextHorizontal=bl;exports.AcDbDimTextVertical=fl;exports.AcDbDimVerticalJustification=Al;exports.AcDbDimZeroSuppression=Sl;exports.AcDbDimZeroSuppressionAngular=Il;exports.AcDbDimension=ge;exports.AcDbDuplicateRecordCloning=pl;exports.AcDbDwgVersion=kt;exports.AcDbDxfCode=Qn;exports.AcDbDxfConverter=Zh;exports.AcDbDxfFiler=Ho;exports.AcDbEllipse=Di;exports.AcDbEntity=lt;exports.AcDbFace=ji;exports.AcDbFileType=Os;exports.AcDbGradientPatternType=$a;exports.AcDbHatch=Us;exports.AcDbHatchObjectType=br;exports.AcDbHatchPatternType=Fs;exports.AcDbHatchStyle=Xa;exports.AcDbHostApplicationServices=Oi;exports.AcDbLayerTable=Pl;exports.AcDbLayerTableRecord=mn;exports.AcDbLayout=ii;exports.AcDbLayoutDictionary=cl;exports.AcDbLayoutManager=ul;exports.AcDbLeader=Wi;exports.AcDbLeaderAnnotationType=qa;exports.AcDbLine=Ys;exports.AcDbLineSpacingStyle=en;exports.AcDbLinetypeTable=Tl;exports.AcDbLinetypeTableRecord=Ae;exports.AcDbMLeader=Gi;exports.AcDbMLeaderContentType=ue;exports.AcDbMLeaderDirectionType=Ja;exports.AcDbMLeaderLineType=hs;exports.AcDbMLeaderStyle=fr;exports.AcDbMLeaderTextAttachmentDirection=Qa;exports.AcDbMLine=Hi;exports.AcDbMLineFlags=Ka;exports.AcDbMLineJustification=Za;exports.AcDbMText=Xs;exports.AcDbMlineStyle=Sr;exports.AcDbObject=Ft;exports.AcDbObjectIterator=ni;exports.AcDbOpenMode=ia;exports.AcDbOrdinateDimension=rn;exports.AcDbOsnapMode=z;exports.AcDbPlotPaperUnits=rl;exports.AcDbPlotRotation=ol;exports.AcDbPlotSettings=hl;exports.AcDbPlotShadePlotResLevel=we;exports.AcDbPlotShadePlotType=os;exports.AcDbPlotStdScaleType=ll;exports.AcDbPlotType=al;exports.AcDbPoint=$i;exports.AcDbPoly2dType=rs;exports.AcDbPoly3dType=Rs;exports.AcDbPolyFaceMesh=tn;exports.AcDbPolyFaceMeshFace=nl;exports.AcDbPolyFaceMeshVertex=il;exports.AcDbPolygonMesh=Ji;exports.AcDbPolygonMeshVertex=sl;exports.AcDbPolyline=Xi;exports.AcDbRadialDimension=on;exports.AcDbRasterImage=qs;exports.AcDbRasterImageClipBoundaryType=tl;exports.AcDbRasterImageDef=gl;exports.AcDbRasterImageImageDisplayOpt=el;exports.AcDbRay=qi;exports.AcDbRegAppTable=kl;exports.AcDbRegAppTableRecord=Zn;exports.AcDbRegenerator=Kh;exports.AcDbRenderingCache=es;exports.AcDbResultBuffer=er;exports.AcDbRotatedDimension=an;exports.AcDbSpline=$s;exports.AcDbSymbolTable=pe;exports.AcDbSymbolTableRecord=Me;exports.AcDbSysVarManager=Ks;exports.AcDbSystemVariables=B;exports.AcDbTable=Ui;exports.AcDbText=cs;exports.AcDbTextHorizontalMode=Ua;exports.AcDbTextStyleTable=El;exports.AcDbTextStyleTableRecord=yn;exports.AcDbTextVerticalMode=Ya;exports.AcDbTrace=Yi;exports.AcDbUnitsValue=Tr;exports.AcDbViewTable=Ll;exports.AcDbViewTableRecord=Qc;exports.AcDbViewport=Zi;exports.AcDbViewportTable=Ml;exports.AcDbViewportTableRecord=Lr;exports.AcDbWipeout=Ki;exports.AcDbWorkerApi=$h;exports.AcDbWorkerManager=Xh;exports.AcDbXline=Qi;exports.AcDbXrecord=Gc;exports.AcGeArea2d=Pe;exports.AcGeBox2d=_t;exports.AcGeBox3d=N;exports.AcGeCatmullRomCurve3d=pn;exports.AcGeCircArc2d=Te;exports.AcGeCircArc3d=Ie;exports.AcGeCurve2d=ds;exports.AcGeEllipseArc2d=Hs;exports.AcGeEllipseArc3d=ls;exports.AcGeEuler=yc;exports.AcGeGeometryUtil=Na;exports.AcGeLine2d=Wt;exports.AcGeLine3d=Ee;exports.AcGeLoop2d=Gs;exports.AcGeMathUtil=k;exports.AcGeMatrix2d=Js;exports.AcGeMatrix3d=D;exports.AcGeNurbsCurve=Rt;exports.AcGePlane=ei;exports.AcGePoint2d=v;exports.AcGePoint3d=w;exports.AcGePolyline2d=at;exports.AcGeQuaternion=ss;exports.AcGeShape2d=mr;exports.AcGeSpline3d=Ht;exports.AcGeTol=ti;exports.AcGeVector2d=$;exports.AcGeVector3d=_;exports.AcGiArrowType=yr;exports.AcGiDefaultLightingType=wr;exports.AcGiLineWeight=Qe;exports.AcGiMTextAttachmentPoint=ot;exports.AcGiMTextFlowDirection=Dt;exports.AcGiOrthographicType=xr;exports.AcGiRenderMode=_r;exports.AcGiViewport=ja;exports.AcTrStringUtil=ac;exports.ByBlock=fe;exports.ByLayer=dt;exports.DEBUG_MODE=rc;exports.DEFAULT_LINE_TYPE=Se;exports.DEFAULT_MLEADER_STYLE=de;exports.DEFAULT_MLINE_STYLE=ce;exports.DEFAULT_TEXT_STYLE=Z;exports.DEFAULT_TOL=dr;exports.DEG2RAD=rr;exports.DefaultLoadingManager=Jo;exports.FLOAT_TOL=qe;exports.MLIGHTCAD_APPID=Fn;exports.ORIGIN_POINT_2D=dc;exports.ORIGIN_POINT_3D=cr;exports.RAD2DEG=or;exports.RAW_COLOR_TYPE_ACI=Pr;exports.RAW_COLOR_TYPE_BY_BLOCK=ln;exports.RAW_COLOR_TYPE_BY_LAYER=Ir;exports.RAW_COLOR_TYPE_RGB=Ar;exports.RAW_COLOR_TYPE_WINDOW_BG=_l;exports.TAU=G;exports.TEMP_OBJECT_ID_PREFIX=Ii;exports.acdbDisableOsnapMode=Mc;exports.acdbEnableOsnapMode=Lc;exports.acdbHasOsnapMode=Ec;exports.acdbHostApplicationServices=tr;exports.acdbMaskToOsnapModes=Pc;exports.acdbOsnapModesToMask=Ac;exports.acdbToggleOsnapMode=Tc;exports.basisFunction=js;exports.calculateCurveLength=Fa;exports.ceilPowerOfTwo=wa;exports.clamp=he;exports.clone=Ms;exports.computeParameterValues=Ba;exports.createWorkerApi=qh;exports.damp=la;exports.decodeMLeaderStyleRawColor=zs;exports.deepClone=Nn;exports.defaults=Qs;exports.degToRad=ya;exports.dwgCodePageToEncoding=na;exports.encodeMLeaderStyleRawColor=Ti;exports.euclideanModulo=ar;exports.evaluateNurbsPoint=Bs;exports.floorPowerOfTwo=ba;exports.generateAveragedKnots=Ra;exports.generateChordKnots=xc;exports.generateSqrtChordKnots=wc;exports.generateUUID=ra;exports.generateUniformKnots=_c;exports.getOcsAngle=Gn;exports.getOcsReferenceVector=pr;exports.has=Go;exports.intPartLength=hr;exports.interpolateControlPoints=bc;exports.interpolateNurbsCurve=gr;exports.inverseLerp=aa;exports.isBetween=fa;exports.isBetweenAngle=Sa;exports.isEmpty=Uo;exports.isEqual=as;exports.isImperialUnits=Yc;exports.isMetricUnits=Uc;exports.isPointInPolygon=ur;exports.isPolygonIntersect=Oa;exports.isPowerOfTwo=xa;exports.lerp=lr;exports.log=Cs;exports.mapLinear=oa;exports.normalizeAngle=Ns;exports.pingpong=ha;exports.radToDeg=_a;exports.randFloat=ga;exports.randFloatSpread=pa;exports.randInt=ua;exports.relativeEps=Ia;exports.seededRandom=ma;exports.setAcDbHostApplicationServicesProvider=ea;exports.setAcDbLayoutManagerFactory=sa;exports.setLogLevel=oc;exports.smootherstep=da;exports.smoothstep=ca;exports.transformOcsPointToWcs=Hn;exports.transformWcsPointToOcs=Ws;