@linkiez/dxf-renew 7.1.0 → 7.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (169) hide show
  1. package/.eslintrc.json +1 -16
  2. package/.yarn/install-state.gz +0 -0
  3. package/ARCHITECTURE.md +163 -0
  4. package/CHANGELOG.md +16 -0
  5. package/README.md +72 -10
  6. package/{PLAN.md → ROADMAP.md} +227 -35
  7. package/dist/dxf.js +1090 -344
  8. package/docs/FIXTURE_VALIDATION_EZDXF.md +1 -1
  9. package/lib/Helper.cjs +4 -0
  10. package/lib/Helper.cjs.map +3 -3
  11. package/lib/Helper.js +4 -0
  12. package/lib/Helper.js.map +2 -2
  13. package/lib/entityToPolyline.cjs +95 -0
  14. package/lib/entityToPolyline.cjs.map +3 -3
  15. package/lib/entityToPolyline.js +95 -0
  16. package/lib/entityToPolyline.js.map +2 -2
  17. package/lib/handlers/entities.cjs +22 -2
  18. package/lib/handlers/entities.cjs.map +3 -3
  19. package/lib/handlers/entities.js +22 -2
  20. package/lib/handlers/entities.js.map +2 -2
  21. package/lib/handlers/entity/mleader.cjs +69 -0
  22. package/lib/handlers/entity/mleader.cjs.map +7 -0
  23. package/lib/handlers/entity/mleader.js +34 -0
  24. package/lib/handlers/entity/mleader.js.map +7 -0
  25. package/lib/handlers/entity/mline.cjs +91 -0
  26. package/lib/handlers/entity/mline.cjs.map +7 -0
  27. package/lib/handlers/entity/mline.js +56 -0
  28. package/lib/handlers/entity/mline.js.map +7 -0
  29. package/lib/handlers/entity/oleframe.cjs +98 -0
  30. package/lib/handlers/entity/oleframe.cjs.map +7 -0
  31. package/lib/handlers/entity/oleframe.js +63 -0
  32. package/lib/handlers/entity/oleframe.js.map +7 -0
  33. package/lib/handlers/entity/ray.cjs +81 -0
  34. package/lib/handlers/entity/ray.cjs.map +7 -0
  35. package/lib/handlers/entity/ray.js +46 -0
  36. package/lib/handlers/entity/ray.js.map +7 -0
  37. package/lib/handlers/entity/region.cjs +67 -0
  38. package/lib/handlers/entity/region.cjs.map +7 -0
  39. package/lib/handlers/entity/region.js +32 -0
  40. package/lib/handlers/entity/region.js.map +7 -0
  41. package/lib/handlers/entity/shape.cjs +95 -0
  42. package/lib/handlers/entity/shape.cjs.map +7 -0
  43. package/lib/handlers/entity/shape.js +60 -0
  44. package/lib/handlers/entity/shape.js.map +7 -0
  45. package/lib/handlers/entity/table.cjs +71 -0
  46. package/lib/handlers/entity/table.cjs.map +7 -0
  47. package/lib/handlers/entity/table.js +36 -0
  48. package/lib/handlers/entity/table.js.map +7 -0
  49. package/lib/handlers/entity/trace.cjs +101 -0
  50. package/lib/handlers/entity/trace.cjs.map +7 -0
  51. package/lib/handlers/entity/trace.js +66 -0
  52. package/lib/handlers/entity/trace.js.map +7 -0
  53. package/lib/handlers/entity/wipeout.cjs +122 -0
  54. package/lib/handlers/entity/wipeout.cjs.map +7 -0
  55. package/lib/handlers/entity/wipeout.js +87 -0
  56. package/lib/handlers/entity/wipeout.js.map +7 -0
  57. package/lib/handlers/entity/xline.cjs +81 -0
  58. package/lib/handlers/entity/xline.cjs.map +7 -0
  59. package/lib/handlers/entity/xline.js +46 -0
  60. package/lib/handlers/entity/xline.js.map +7 -0
  61. package/lib/handlers/objects.cjs +43 -1
  62. package/lib/handlers/objects.cjs.map +2 -2
  63. package/lib/handlers/objects.js +43 -1
  64. package/lib/handlers/objects.js.map +2 -2
  65. package/lib/handlers/tables.cjs +96 -17
  66. package/lib/handlers/tables.cjs.map +2 -2
  67. package/lib/handlers/tables.js +96 -17
  68. package/lib/handlers/tables.js.map +2 -2
  69. package/lib/index.cjs +5 -2
  70. package/lib/index.cjs.map +3 -3
  71. package/lib/index.js +18 -16
  72. package/lib/index.js.map +3 -3
  73. package/lib/toJson.cjs +29 -0
  74. package/lib/toJson.cjs.map +7 -0
  75. package/lib/toJson.js +9 -0
  76. package/lib/toJson.js.map +7 -0
  77. package/lib/toSVG.cjs +34 -3
  78. package/lib/toSVG.cjs.map +2 -2
  79. package/lib/toSVG.js +34 -3
  80. package/lib/toSVG.js.map +2 -2
  81. package/lib/types/entity.cjs.map +1 -1
  82. package/lib/types/helper.cjs.map +1 -1
  83. package/lib/types/index.cjs +20 -0
  84. package/lib/types/index.cjs.map +2 -2
  85. package/lib/types/index.js +10 -0
  86. package/lib/types/index.js.map +2 -2
  87. package/lib/types/mleader-entity.cjs +17 -0
  88. package/lib/types/mleader-entity.cjs.map +7 -0
  89. package/lib/types/mleader-entity.js +1 -0
  90. package/lib/types/mleader-entity.js.map +7 -0
  91. package/lib/types/mline-entity.cjs +17 -0
  92. package/lib/types/mline-entity.cjs.map +7 -0
  93. package/lib/types/mline-entity.js +1 -0
  94. package/lib/types/mline-entity.js.map +7 -0
  95. package/lib/types/oleframe-entity.cjs +17 -0
  96. package/lib/types/oleframe-entity.cjs.map +7 -0
  97. package/lib/types/oleframe-entity.js +1 -0
  98. package/lib/types/oleframe-entity.js.map +7 -0
  99. package/lib/types/options.cjs.map +1 -1
  100. package/lib/types/ray-entity.cjs +17 -0
  101. package/lib/types/ray-entity.cjs.map +7 -0
  102. package/lib/types/ray-entity.js +1 -0
  103. package/lib/types/ray-entity.js.map +7 -0
  104. package/lib/types/region-entity.cjs +17 -0
  105. package/lib/types/region-entity.cjs.map +7 -0
  106. package/lib/types/region-entity.js +1 -0
  107. package/lib/types/region-entity.js.map +7 -0
  108. package/lib/types/shape-entity.cjs +17 -0
  109. package/lib/types/shape-entity.cjs.map +7 -0
  110. package/lib/types/shape-entity.js +1 -0
  111. package/lib/types/shape-entity.js.map +7 -0
  112. package/lib/types/table-entity.cjs +17 -0
  113. package/lib/types/table-entity.cjs.map +7 -0
  114. package/lib/types/table-entity.js +1 -0
  115. package/lib/types/table-entity.js.map +7 -0
  116. package/lib/types/tables.cjs.map +1 -1
  117. package/lib/types/trace-entity.cjs +17 -0
  118. package/lib/types/trace-entity.cjs.map +7 -0
  119. package/lib/types/trace-entity.js +1 -0
  120. package/lib/types/trace-entity.js.map +7 -0
  121. package/lib/types/wipeout-entity.cjs +17 -0
  122. package/lib/types/wipeout-entity.cjs.map +7 -0
  123. package/lib/types/wipeout-entity.js +1 -0
  124. package/lib/types/wipeout-entity.js.map +7 -0
  125. package/lib/types/xline-entity.cjs +17 -0
  126. package/lib/types/xline-entity.cjs.map +7 -0
  127. package/lib/types/xline-entity.js +1 -0
  128. package/lib/types/xline-entity.js.map +7 -0
  129. package/package.json +5 -19
  130. package/src/Helper.ts +6 -1
  131. package/src/entityToPolyline.ts +124 -2
  132. package/src/handlers/entities.ts +21 -1
  133. package/src/handlers/entity/mleader.ts +46 -0
  134. package/src/handlers/entity/mline.ts +74 -0
  135. package/src/handlers/entity/oleframe.ts +62 -0
  136. package/src/handlers/entity/ray.ts +52 -0
  137. package/src/handlers/entity/region.ts +42 -0
  138. package/src/handlers/entity/shape.ts +73 -0
  139. package/src/handlers/entity/table.ts +49 -0
  140. package/src/handlers/entity/trace.ts +72 -0
  141. package/src/handlers/entity/wipeout.ts +114 -0
  142. package/src/handlers/entity/xline.ts +52 -0
  143. package/src/handlers/objects.ts +64 -8
  144. package/src/handlers/tables.ts +134 -21
  145. package/src/index.ts +9 -18
  146. package/src/toJson.ts +8 -0
  147. package/src/toSVG.ts +45 -3
  148. package/src/types/entity.ts +20 -0
  149. package/src/types/helper.ts +2 -1
  150. package/src/types/index.ts +10 -0
  151. package/src/types/mleader-entity.ts +8 -0
  152. package/src/types/mline-entity.ts +12 -0
  153. package/src/types/oleframe-entity.ts +40 -0
  154. package/src/types/options.ts +7 -0
  155. package/src/types/ray-entity.ts +12 -0
  156. package/src/types/region-entity.ts +11 -0
  157. package/src/types/shape-entity.ts +19 -0
  158. package/src/types/table-entity.ts +14 -0
  159. package/src/types/tables.ts +76 -0
  160. package/src/types/trace-entity.ts +14 -0
  161. package/src/types/wipeout-entity.ts +20 -0
  162. package/src/types/xline-entity.ts +12 -0
  163. package/docs/DIMENSION_SUMMARY.md +0 -254
  164. package/docs/DXF_VERSION_SUPPORT.md +0 -45
  165. package/docs/ENTITY_SVG_ROADMAP.md +0 -96
  166. package/docs/IMPLEMENTED-2D-ENTITIES.md +0 -54
  167. package/docs/README.md +0 -22
  168. package/docs/SVG_RENDERING_INTEGRATION_TESTS.md +0 -119
  169. package/docs/TEXT-MTEXT-DIMENSION-SUPPORT.md +0 -241
@@ -59,4 +59,4 @@ When adding a new fixture:
59
59
  2. Run `yarn validate:fixtures`.
60
60
  3. Add unit tests (parsing) and integration tests (final SVG).
61
61
 
62
- See also: `docs/ENTITY_SVG_ROADMAP.md` (fixtureezdxf tests checklist)
62
+ See also: the entity workflow checklist in `ROADMAP.md` under “Documentation (Consolidated)Entity SVG Roadmap”.
package/lib/Helper.cjs CHANGED
@@ -34,6 +34,7 @@ module.exports = __toCommonJS(Helper_exports);
34
34
  var import_denormalise = __toESM(require("./denormalise"), 1);
35
35
  var import_groupEntitiesByLayer = __toESM(require("./groupEntitiesByLayer"), 1);
36
36
  var import_parseString = __toESM(require("./parseString"), 1);
37
+ var import_toJson = __toESM(require("./toJson"), 1);
37
38
  var import_toPolylines = __toESM(require("./toPolylines"), 1);
38
39
  var import_toSVG = __toESM(require("./toSVG"), 1);
39
40
  var import_logger = __toESM(require("./util/logger"), 1);
@@ -82,6 +83,9 @@ class Helper {
82
83
  toSVG(options) {
83
84
  return (0, import_toSVG.default)(this.parsed, options);
84
85
  }
86
+ toJson(options) {
87
+ return (0, import_toJson.default)(this.parsed, options);
88
+ }
85
89
  toPolylines() {
86
90
  return (0, import_toPolylines.default)(this.parsed);
87
91
  }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/Helper.ts"],
4
- "sourcesContent": ["import denormalise from './denormalise'\nimport groupEntitiesByLayer from './groupEntitiesByLayer'\nimport parseString from './parseString'\nimport toPolylines from './toPolylines'\nimport toSVG from './toSVG'\nimport logger from './util/logger'\n\nimport type { Entity, LayerGroups, ParsedDXF, ToSVGOptions } from './types'\n\nexport default class Helper {\n private readonly _contents: string\n private _parsed: ParsedDXF | null\n private _denormalised: Entity[] | null\n private _groups: LayerGroups | null\n\n constructor(contents: string) {\n if (typeof contents !== 'string') {\n throw new TypeError('Helper constructor expects a DXF string')\n }\n this._contents = contents\n this._parsed = null\n this._denormalised = null\n this._groups = null\n }\n\n parse(): ParsedDXF {\n this._parsed = parseString(this._contents)\n logger.info('parsed:', this.parsed)\n return this._parsed\n }\n\n get parsed(): ParsedDXF {\n if (this._parsed === null) {\n this.parse()\n }\n return this._parsed as ParsedDXF\n }\n\n denormalise(): Entity[] {\n this._denormalised = denormalise(this.parsed)\n logger.info('denormalised:', this._denormalised)\n return this._denormalised\n }\n\n get denormalised(): Entity[] {\n if (!this._denormalised) {\n this.denormalise()\n }\n return this._denormalised as Entity[]\n }\n\n group(): LayerGroups {\n this._groups = groupEntitiesByLayer(this.denormalised)\n return this._groups\n }\n\n get groups(): LayerGroups {\n if (!this._groups) {\n this.group()\n }\n return this._groups as LayerGroups\n }\n\n toSVG(options?: ToSVGOptions): string {\n return toSVG(this.parsed, options)\n }\n\n toPolylines(): ReturnType<typeof toPolylines> {\n return toPolylines(this.parsed)\n }\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,yBAAwB;AACxB,kCAAiC;AACjC,yBAAwB;AACxB,yBAAwB;AACxB,mBAAkB;AAClB,oBAAmB;AAInB,MAAO,OAAqB;AAAA,EAM1B,YAAY,UAAkB;AAC5B,QAAI,OAAO,aAAa,UAAU;AAChC,YAAM,IAAI,UAAU,yCAAyC;AAAA,IAC/D;AACA,SAAK,YAAY;AACjB,SAAK,UAAU;AACf,SAAK,gBAAgB;AACrB,SAAK,UAAU;AAAA,EACjB;AAAA,EAEA,QAAmB;AACjB,SAAK,cAAU,mBAAAA,SAAY,KAAK,SAAS;AACzC,kBAAAC,QAAO,KAAK,WAAW,KAAK,MAAM;AAClC,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,SAAoB;AACtB,QAAI,KAAK,YAAY,MAAM;AACzB,WAAK,MAAM;AAAA,IACb;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,cAAwB;AACtB,SAAK,oBAAgB,mBAAAC,SAAY,KAAK,MAAM;AAC5C,kBAAAD,QAAO,KAAK,iBAAiB,KAAK,aAAa;AAC/C,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,eAAyB;AAC3B,QAAI,CAAC,KAAK,eAAe;AACvB,WAAK,YAAY;AAAA,IACnB;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,QAAqB;AACnB,SAAK,cAAU,4BAAAE,SAAqB,KAAK,YAAY;AACrD,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,SAAsB;AACxB,QAAI,CAAC,KAAK,SAAS;AACjB,WAAK,MAAM;AAAA,IACb;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAM,SAAgC;AACpC,eAAO,aAAAC,SAAM,KAAK,QAAQ,OAAO;AAAA,EACnC;AAAA,EAEA,cAA8C;AAC5C,eAAO,mBAAAC,SAAY,KAAK,MAAM;AAAA,EAChC;AACF;",
6
- "names": ["parseString", "logger", "denormalise", "groupEntitiesByLayer", "toSVG", "toPolylines"]
4
+ "sourcesContent": ["import denormalise from './denormalise'\nimport groupEntitiesByLayer from './groupEntitiesByLayer'\nimport parseString from './parseString'\nimport toJson from './toJson'\nimport toPolylines from './toPolylines'\nimport toSVG from './toSVG'\nimport logger from './util/logger'\n\nimport type { Entity, LayerGroups, ParsedDXF, ToJsonOptions, ToSVGOptions } from './types'\n\nexport default class Helper {\n private readonly _contents: string\n private _parsed: ParsedDXF | null\n private _denormalised: Entity[] | null\n private _groups: LayerGroups | null\n\n constructor(contents: string) {\n if (typeof contents !== 'string') {\n throw new TypeError('Helper constructor expects a DXF string')\n }\n this._contents = contents\n this._parsed = null\n this._denormalised = null\n this._groups = null\n }\n\n parse(): ParsedDXF {\n this._parsed = parseString(this._contents)\n logger.info('parsed:', this.parsed)\n return this._parsed\n }\n\n get parsed(): ParsedDXF {\n if (this._parsed === null) {\n this.parse()\n }\n return this._parsed as ParsedDXF\n }\n\n denormalise(): Entity[] {\n this._denormalised = denormalise(this.parsed)\n logger.info('denormalised:', this._denormalised)\n return this._denormalised\n }\n\n get denormalised(): Entity[] {\n if (!this._denormalised) {\n this.denormalise()\n }\n return this._denormalised as Entity[]\n }\n\n group(): LayerGroups {\n this._groups = groupEntitiesByLayer(this.denormalised)\n return this._groups\n }\n\n get groups(): LayerGroups {\n if (!this._groups) {\n this.group()\n }\n return this._groups as LayerGroups\n }\n\n toSVG(options?: ToSVGOptions): string {\n return toSVG(this.parsed, options)\n }\n\n toJson(options?: ToJsonOptions): string {\n return toJson(this.parsed, options)\n }\n\n toPolylines(): ReturnType<typeof toPolylines> {\n return toPolylines(this.parsed)\n }\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,yBAAwB;AACxB,kCAAiC;AACjC,yBAAwB;AACxB,oBAAmB;AACnB,yBAAwB;AACxB,mBAAkB;AAClB,oBAAmB;AAInB,MAAO,OAAqB;AAAA,EAM1B,YAAY,UAAkB;AAC5B,QAAI,OAAO,aAAa,UAAU;AAChC,YAAM,IAAI,UAAU,yCAAyC;AAAA,IAC/D;AACA,SAAK,YAAY;AACjB,SAAK,UAAU;AACf,SAAK,gBAAgB;AACrB,SAAK,UAAU;AAAA,EACjB;AAAA,EAEA,QAAmB;AACjB,SAAK,cAAU,mBAAAA,SAAY,KAAK,SAAS;AACzC,kBAAAC,QAAO,KAAK,WAAW,KAAK,MAAM;AAClC,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,SAAoB;AACtB,QAAI,KAAK,YAAY,MAAM;AACzB,WAAK,MAAM;AAAA,IACb;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,cAAwB;AACtB,SAAK,oBAAgB,mBAAAC,SAAY,KAAK,MAAM;AAC5C,kBAAAD,QAAO,KAAK,iBAAiB,KAAK,aAAa;AAC/C,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,eAAyB;AAC3B,QAAI,CAAC,KAAK,eAAe;AACvB,WAAK,YAAY;AAAA,IACnB;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,QAAqB;AACnB,SAAK,cAAU,4BAAAE,SAAqB,KAAK,YAAY;AACrD,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,SAAsB;AACxB,QAAI,CAAC,KAAK,SAAS;AACjB,WAAK,MAAM;AAAA,IACb;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAM,SAAgC;AACpC,eAAO,aAAAC,SAAM,KAAK,QAAQ,OAAO;AAAA,EACnC;AAAA,EAEA,OAAO,SAAiC;AACtC,eAAO,cAAAC,SAAO,KAAK,QAAQ,OAAO;AAAA,EACpC;AAAA,EAEA,cAA8C;AAC5C,eAAO,mBAAAC,SAAY,KAAK,MAAM;AAAA,EAChC;AACF;",
6
+ "names": ["parseString", "logger", "denormalise", "groupEntitiesByLayer", "toSVG", "toJson", "toPolylines"]
7
7
  }
package/lib/Helper.js CHANGED
@@ -1,6 +1,7 @@
1
1
  import denormalise from "./denormalise";
2
2
  import groupEntitiesByLayer from "./groupEntitiesByLayer";
3
3
  import parseString from "./parseString";
4
+ import toJson from "./toJson";
4
5
  import toPolylines from "./toPolylines";
5
6
  import toSVG from "./toSVG";
6
7
  import logger from "./util/logger";
@@ -49,6 +50,9 @@ class Helper {
49
50
  toSVG(options) {
50
51
  return toSVG(this.parsed, options);
51
52
  }
53
+ toJson(options) {
54
+ return toJson(this.parsed, options);
55
+ }
52
56
  toPolylines() {
53
57
  return toPolylines(this.parsed);
54
58
  }
package/lib/Helper.js.map CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/Helper.ts"],
4
- "sourcesContent": ["import denormalise from './denormalise'\nimport groupEntitiesByLayer from './groupEntitiesByLayer'\nimport parseString from './parseString'\nimport toPolylines from './toPolylines'\nimport toSVG from './toSVG'\nimport logger from './util/logger'\n\nimport type { Entity, LayerGroups, ParsedDXF, ToSVGOptions } from './types'\n\nexport default class Helper {\n private readonly _contents: string\n private _parsed: ParsedDXF | null\n private _denormalised: Entity[] | null\n private _groups: LayerGroups | null\n\n constructor(contents: string) {\n if (typeof contents !== 'string') {\n throw new TypeError('Helper constructor expects a DXF string')\n }\n this._contents = contents\n this._parsed = null\n this._denormalised = null\n this._groups = null\n }\n\n parse(): ParsedDXF {\n this._parsed = parseString(this._contents)\n logger.info('parsed:', this.parsed)\n return this._parsed\n }\n\n get parsed(): ParsedDXF {\n if (this._parsed === null) {\n this.parse()\n }\n return this._parsed as ParsedDXF\n }\n\n denormalise(): Entity[] {\n this._denormalised = denormalise(this.parsed)\n logger.info('denormalised:', this._denormalised)\n return this._denormalised\n }\n\n get denormalised(): Entity[] {\n if (!this._denormalised) {\n this.denormalise()\n }\n return this._denormalised as Entity[]\n }\n\n group(): LayerGroups {\n this._groups = groupEntitiesByLayer(this.denormalised)\n return this._groups\n }\n\n get groups(): LayerGroups {\n if (!this._groups) {\n this.group()\n }\n return this._groups as LayerGroups\n }\n\n toSVG(options?: ToSVGOptions): string {\n return toSVG(this.parsed, options)\n }\n\n toPolylines(): ReturnType<typeof toPolylines> {\n return toPolylines(this.parsed)\n }\n}\n"],
5
- "mappings": "AAAA,OAAO,iBAAiB;AACxB,OAAO,0BAA0B;AACjC,OAAO,iBAAiB;AACxB,OAAO,iBAAiB;AACxB,OAAO,WAAW;AAClB,OAAO,YAAY;AAInB,MAAO,OAAqB;AAAA,EAM1B,YAAY,UAAkB;AAC5B,QAAI,OAAO,aAAa,UAAU;AAChC,YAAM,IAAI,UAAU,yCAAyC;AAAA,IAC/D;AACA,SAAK,YAAY;AACjB,SAAK,UAAU;AACf,SAAK,gBAAgB;AACrB,SAAK,UAAU;AAAA,EACjB;AAAA,EAEA,QAAmB;AACjB,SAAK,UAAU,YAAY,KAAK,SAAS;AACzC,WAAO,KAAK,WAAW,KAAK,MAAM;AAClC,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,SAAoB;AACtB,QAAI,KAAK,YAAY,MAAM;AACzB,WAAK,MAAM;AAAA,IACb;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,cAAwB;AACtB,SAAK,gBAAgB,YAAY,KAAK,MAAM;AAC5C,WAAO,KAAK,iBAAiB,KAAK,aAAa;AAC/C,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,eAAyB;AAC3B,QAAI,CAAC,KAAK,eAAe;AACvB,WAAK,YAAY;AAAA,IACnB;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,QAAqB;AACnB,SAAK,UAAU,qBAAqB,KAAK,YAAY;AACrD,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,SAAsB;AACxB,QAAI,CAAC,KAAK,SAAS;AACjB,WAAK,MAAM;AAAA,IACb;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAM,SAAgC;AACpC,WAAO,MAAM,KAAK,QAAQ,OAAO;AAAA,EACnC;AAAA,EAEA,cAA8C;AAC5C,WAAO,YAAY,KAAK,MAAM;AAAA,EAChC;AACF;",
4
+ "sourcesContent": ["import denormalise from './denormalise'\nimport groupEntitiesByLayer from './groupEntitiesByLayer'\nimport parseString from './parseString'\nimport toJson from './toJson'\nimport toPolylines from './toPolylines'\nimport toSVG from './toSVG'\nimport logger from './util/logger'\n\nimport type { Entity, LayerGroups, ParsedDXF, ToJsonOptions, ToSVGOptions } from './types'\n\nexport default class Helper {\n private readonly _contents: string\n private _parsed: ParsedDXF | null\n private _denormalised: Entity[] | null\n private _groups: LayerGroups | null\n\n constructor(contents: string) {\n if (typeof contents !== 'string') {\n throw new TypeError('Helper constructor expects a DXF string')\n }\n this._contents = contents\n this._parsed = null\n this._denormalised = null\n this._groups = null\n }\n\n parse(): ParsedDXF {\n this._parsed = parseString(this._contents)\n logger.info('parsed:', this.parsed)\n return this._parsed\n }\n\n get parsed(): ParsedDXF {\n if (this._parsed === null) {\n this.parse()\n }\n return this._parsed as ParsedDXF\n }\n\n denormalise(): Entity[] {\n this._denormalised = denormalise(this.parsed)\n logger.info('denormalised:', this._denormalised)\n return this._denormalised\n }\n\n get denormalised(): Entity[] {\n if (!this._denormalised) {\n this.denormalise()\n }\n return this._denormalised as Entity[]\n }\n\n group(): LayerGroups {\n this._groups = groupEntitiesByLayer(this.denormalised)\n return this._groups\n }\n\n get groups(): LayerGroups {\n if (!this._groups) {\n this.group()\n }\n return this._groups as LayerGroups\n }\n\n toSVG(options?: ToSVGOptions): string {\n return toSVG(this.parsed, options)\n }\n\n toJson(options?: ToJsonOptions): string {\n return toJson(this.parsed, options)\n }\n\n toPolylines(): ReturnType<typeof toPolylines> {\n return toPolylines(this.parsed)\n }\n}\n"],
5
+ "mappings": "AAAA,OAAO,iBAAiB;AACxB,OAAO,0BAA0B;AACjC,OAAO,iBAAiB;AACxB,OAAO,YAAY;AACnB,OAAO,iBAAiB;AACxB,OAAO,WAAW;AAClB,OAAO,YAAY;AAInB,MAAO,OAAqB;AAAA,EAM1B,YAAY,UAAkB;AAC5B,QAAI,OAAO,aAAa,UAAU;AAChC,YAAM,IAAI,UAAU,yCAAyC;AAAA,IAC/D;AACA,SAAK,YAAY;AACjB,SAAK,UAAU;AACf,SAAK,gBAAgB;AACrB,SAAK,UAAU;AAAA,EACjB;AAAA,EAEA,QAAmB;AACjB,SAAK,UAAU,YAAY,KAAK,SAAS;AACzC,WAAO,KAAK,WAAW,KAAK,MAAM;AAClC,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,SAAoB;AACtB,QAAI,KAAK,YAAY,MAAM;AACzB,WAAK,MAAM;AAAA,IACb;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,cAAwB;AACtB,SAAK,gBAAgB,YAAY,KAAK,MAAM;AAC5C,WAAO,KAAK,iBAAiB,KAAK,aAAa;AAC/C,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,eAAyB;AAC3B,QAAI,CAAC,KAAK,eAAe;AACvB,WAAK,YAAY;AAAA,IACnB;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,QAAqB;AACnB,SAAK,UAAU,qBAAqB,KAAK,YAAY;AACrD,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,SAAsB;AACxB,QAAI,CAAC,KAAK,SAAS;AACjB,WAAK,MAAM;AAAA,IACb;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAM,SAAgC;AACpC,WAAO,MAAM,KAAK,QAAQ,OAAO;AAAA,EACnC;AAAA,EAEA,OAAO,SAAiC;AACtC,WAAO,OAAO,KAAK,QAAQ,OAAO;AAAA,EACpC;AAAA,EAEA,cAA8C;AAC5C,WAAO,YAAY,KAAK,MAAM;AAAA,EAChC;AACF;",
6
6
  "names": []
7
7
  }
@@ -144,12 +144,95 @@ const polyfaceOutline = (entity) => {
144
144
  function entityToPolyline(entity, options) {
145
145
  options = options || {};
146
146
  let polyline;
147
+ const INFINITE_LINE_LENGTH = 1e3;
148
+ const normalize2 = (x, y) => {
149
+ const len = Math.hypot(x, y);
150
+ if (len === 0) return null;
151
+ return { x: x / len, y: y / len };
152
+ };
147
153
  if (entity.type === "LINE") {
148
154
  polyline = [
149
155
  [entity.start.x, entity.start.y],
150
156
  [entity.end.x, entity.end.y]
151
157
  ];
152
158
  }
159
+ if (entity.type === "LEADER") {
160
+ if (entity.vertices.length >= 2) {
161
+ polyline = entity.vertices.map((v) => [v.x, v.y]);
162
+ } else {
163
+ import_logger.default.warn("LEADER entity with insufficient vertices");
164
+ polyline = [];
165
+ }
166
+ }
167
+ if (entity.type === "RAY") {
168
+ const dir = normalize2(entity.direction.x, entity.direction.y);
169
+ if (dir === null) {
170
+ import_logger.default.warn("RAY entity with zero direction vector");
171
+ polyline = [];
172
+ } else {
173
+ polyline = [
174
+ [entity.start.x, entity.start.y],
175
+ [
176
+ entity.start.x + dir.x * INFINITE_LINE_LENGTH,
177
+ entity.start.y + dir.y * INFINITE_LINE_LENGTH
178
+ ]
179
+ ];
180
+ }
181
+ }
182
+ if (entity.type === "XLINE") {
183
+ const dir = normalize2(entity.direction.x, entity.direction.y);
184
+ if (dir === null) {
185
+ import_logger.default.warn("XLINE entity with zero direction vector");
186
+ polyline = [];
187
+ } else {
188
+ polyline = [
189
+ [
190
+ entity.basePoint.x - dir.x * INFINITE_LINE_LENGTH,
191
+ entity.basePoint.y - dir.y * INFINITE_LINE_LENGTH
192
+ ],
193
+ [
194
+ entity.basePoint.x + dir.x * INFINITE_LINE_LENGTH,
195
+ entity.basePoint.y + dir.y * INFINITE_LINE_LENGTH
196
+ ]
197
+ ];
198
+ }
199
+ }
200
+ if (entity.type === "SHAPE") {
201
+ const x = entity.insertionPoint?.x ?? 0;
202
+ const y = entity.insertionPoint?.y ?? 0;
203
+ const size = entity.size ?? 0;
204
+ const scaleX = entity.relativeXScale ?? 1;
205
+ const length = size * scaleX;
206
+ polyline = [
207
+ [x, y],
208
+ [x + length, y]
209
+ ];
210
+ }
211
+ if (entity.type === "WIPEOUT") {
212
+ const verts = entity.clipBoundaryVertices;
213
+ if (!verts || verts.length < 2) {
214
+ import_logger.default.warn("WIPEOUT entity with missing clip boundary vertices");
215
+ polyline = [];
216
+ } else {
217
+ const insX = entity.insertionPoint?.x ?? 0;
218
+ const insY = entity.insertionPoint?.y ?? 0;
219
+ const ux = entity.uVector?.x ?? 1;
220
+ const uy = entity.uVector?.y ?? 0;
221
+ const vx = entity.vVector?.x ?? 0;
222
+ const vy = entity.vVector?.y ?? 1;
223
+ polyline = verts.map((p) => [
224
+ insX + ux * p.x + vx * p.y,
225
+ insY + uy * p.x + vy * p.y
226
+ ]);
227
+ if (polyline.length > 0) {
228
+ const first = polyline[0];
229
+ const last = polyline[polyline.length - 1];
230
+ if (first[0] !== last[0] || first[1] !== last[1]) {
231
+ polyline.push(first);
232
+ }
233
+ }
234
+ }
235
+ }
153
236
  if (entity.type === "LWPOLYLINE" || entity.type === "POLYLINE") {
154
237
  polyline = [];
155
238
  if (entity.polyfaceMesh) {
@@ -234,6 +317,18 @@ function entityToPolyline(entity, options) {
234
317
  entity.weights
235
318
  );
236
319
  }
320
+ if (entity.type === "SOLID" || entity.type === "TRACE") {
321
+ const corners = entity.corners ?? entity.points;
322
+ if (corners && corners.length >= 4) {
323
+ polyline = [
324
+ [corners[0].x, corners[0].y],
325
+ [corners[1].x, corners[1].y],
326
+ [corners[2].x, corners[2].y],
327
+ [corners[3].x, corners[3].y],
328
+ [corners[0].x, corners[0].y]
329
+ ];
330
+ }
331
+ }
237
332
  if (!polyline) {
238
333
  import_logger.default.warn("unsupported entity for converting to polyline:", entity.type);
239
334
  return [];
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/entityToPolyline.ts"],
4
- "sourcesContent": ["import bSpline from './util/bSpline'\nimport createArcForLWPolyine from './util/createArcForLWPolyline'\nimport logger from './util/logger'\n\nimport type {\n ArcEntity,\n CircleEntity,\n ControlPoint,\n EllipseEntity,\n EntityToPolylineOptions,\n HandlerVertex,\n LineEntity,\n SplineEntity,\n} from './types'\nimport type { PointTuple } from './types/common'\n\n// Re-export types for backward compatibility\nexport type { ControlPoint, EntityToPolylineOptions } from './types'\n\ntype Point = PointTuple\n\n// Local vertex type with required coordinates for runtime processing\ninterface LocalVertex extends HandlerVertex {\n faces?: number[]\n}\n\n// Local polyline type that uses our vertex with required coordinates\ninterface LocalPolylineEntity {\n type: string\n vertices: LocalVertex[]\n closed?: boolean\n polyfaceMesh?: boolean\n polygonMesh?: boolean\n}\n\ntype Entity =\n | LineEntity\n | (LocalPolylineEntity & { type: 'LWPOLYLINE' | 'POLYLINE' })\n | CircleEntity\n | EllipseEntity\n | ArcEntity\n | SplineEntity\n\n/**\n * Rotate a set of points.\n *\n * @param points the points\n * @param angle the rotation angle\n */\nconst rotate = (points: Point[], angle: number): Point[] => {\n return points.map(function (p) {\n return [\n p[0] * Math.cos(angle) - p[1] * Math.sin(angle),\n p[1] * Math.cos(angle) + p[0] * Math.sin(angle),\n ]\n })\n}\n\n/**\n * Interpolate an ellipse\n * @param cx center X\n * @param cy center Y\n * @param rx radius X\n * @param ry radius Y\n * @param start start angle in radians\n * @param start end angle in radians\n */\nconst interpolateEllipse = (\n cx: number,\n cy: number,\n rx: number,\n ry: number,\n start: number,\n end: number,\n rotationAngle?: number\n): Point[] => {\n if (end < start) {\n end += Math.PI * 2\n }\n\n // ----- Relative points -----\n\n // Start point\n let points: Point[] = []\n const dTheta = (Math.PI * 2) / 72\n const EPS = 1e-6\n for (let theta = start; theta < end - EPS; theta += dTheta) {\n points.push([Math.cos(theta) * rx, Math.sin(theta) * ry])\n }\n points.push([Math.cos(end) * rx, Math.sin(end) * ry])\n\n // ----- Rotate -----\n if (rotationAngle) {\n points = rotate(points, rotationAngle)\n }\n\n // ----- Offset center -----\n points = points.map(function (p): Point {\n return [cx + p[0], cy + p[1]]\n })\n\n return points\n}\n\n/**\n * Interpolate a b-spline. The algorithm examins the knot vector\n * to create segments for interpolation. The parameterisation value\n * is re-normalised back to [0,1] as that is what the lib expects (\n * and t i de-normalised in the b-spline library)\n *\n * @param controlPoints the control points\n * @param degree the b-spline degree\n * @param knots the knot vector\n * @returns the polyline\n */\nexport const interpolateBSpline = (\n controlPoints: ControlPoint[],\n degree: number,\n knots: number[],\n interpolationsPerSplineSegment?: number,\n weights?: number[]\n): Point[] => {\n const polyline: Point[] = []\n const controlPointsForLib = controlPoints.map(function (p): Point {\n return [p.x, p.y]\n })\n\n const segmentTs = [knots[degree]]\n const domain: Point = [knots[degree], knots[knots.length - 1 - degree]]\n\n for (let k = degree + 1; k < knots.length - degree; ++k) {\n if (segmentTs[segmentTs.length - 1] !== knots[k]) {\n segmentTs.push(knots[k])\n }\n }\n\n interpolationsPerSplineSegment = interpolationsPerSplineSegment || 25\n for (let i = 1; i < segmentTs.length; ++i) {\n const uMin = segmentTs[i - 1]\n const uMax = segmentTs[i]\n for (let k = 0; k <= interpolationsPerSplineSegment; ++k) {\n const u = (k / interpolationsPerSplineSegment) * (uMax - uMin) + uMin\n // Clamp t to 0, 1 to handle numerical precision issues\n let t = (u - domain[0]) / (domain[1] - domain[0])\n t = Math.max(t, 0)\n t = Math.min(t, 1)\n const p = bSpline(t, degree, controlPointsForLib, knots, weights)\n polyline.push([p[0], p[1]])\n }\n }\n return polyline\n}\n\nexport const polyfaceOutline = (entity: LocalPolylineEntity): Point[][] => {\n const vertices: Array<{ x: number; y: number }> = []\n const faces: Array<{ indices: number[]; hiddens: boolean[] }> = []\n\n for (const v of entity.vertices) {\n if (v.faces) {\n const face: { indices: number[]; hiddens: boolean[] } = {\n indices: [],\n hiddens: [],\n }\n for (const i of v.faces) {\n if (i === 0) {\n break\n }\n // Negative indices signify hidden edges\n face.indices.push(i < 0 ? -i - 1 : i - 1)\n face.hiddens.push(i < 0)\n }\n if ([3, 4].includes(face.indices.length)) faces.push(face)\n } else {\n vertices.push({ x: v.x, y: v.y })\n }\n }\n\n // If a segment starts at the end of a previous line, continue it\n const polylines: number[][] = []\n const segment = (a: number, b: number): void => {\n for (const prev of polylines) {\n if (prev.slice(-1)[0] === a) {\n prev.push(b)\n return\n }\n }\n polylines.push([a, b])\n }\n\n for (const face of faces) {\n for (let beg = 0; beg < face.indices.length; beg++) {\n if (face.hiddens[beg]) {\n continue\n }\n const end = (beg + 1) % face.indices.length\n segment(face.indices[beg], face.indices[end])\n }\n }\n\n // Sometimes segments are not sequential, in that case\n // we need to find if they can mend gaps between others\n for (const a of polylines) {\n for (const b of polylines) {\n if (a !== b && a[0] === b.slice(-1)[0]) {\n b.push(...a.slice(1))\n a.splice(0, a.length)\n break\n }\n }\n }\n\n return polylines\n .filter((l) => l.length)\n .map((l) => l.map((i) => vertices[i]).map((v) => [v.x, v.y]))\n}\n\n/**\n * Convert a parsed DXF entity to a polyline. These can be used to render the\n * the DXF in SVG, Canvas, WebGL etc., without depending on native support\n * of primitive objects (ellispe, spline etc.)\n */\nexport default function entityToPolyline(\n entity: Entity,\n options?: EntityToPolylineOptions,\n): Point[] {\n options = options || {}\n let polyline: Point[] | undefined\n\n if (entity.type === 'LINE') {\n polyline = [\n [entity.start.x, entity.start.y],\n [entity.end.x, entity.end.y],\n ]\n }\n\n if (entity.type === 'LWPOLYLINE' || entity.type === 'POLYLINE') {\n polyline = []\n if (entity.polyfaceMesh) {\n // Only return the first polyline because we can't return many\n polyline.push(...polyfaceOutline(entity)[0])\n } else if (entity.polygonMesh) {\n // Do not attempt to render polygon meshes\n } else if (entity.vertices.length) {\n if (entity.closed) {\n entity.vertices = entity.vertices.concat(entity.vertices[0])\n }\n for (let i = 0, il = entity.vertices.length; i < il - 1; ++i) {\n const from: Point = [entity.vertices[i].x, entity.vertices[i].y]\n const to: Point = [entity.vertices[i + 1].x, entity.vertices[i + 1].y]\n polyline.push(from)\n if (entity.vertices[i].bulge) {\n polyline = polyline.concat(\n createArcForLWPolyine(from, to, entity.vertices[i].bulge!),\n )\n }\n // The last iteration of the for loop\n if (i === il - 2) {\n polyline.push(to)\n }\n }\n } else {\n logger.warn('Polyline entity with no vertices')\n }\n }\n\n if (entity.type === 'CIRCLE') {\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n entity.r,\n entity.r,\n 0,\n Math.PI * 2,\n )\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'ELLIPSE') {\n const rx = Math.hypot(entity.majorX, entity.majorY)\n const ry = entity.axisRatio * rx\n const majorAxisRotation = -Math.atan2(-entity.majorY, entity.majorX)\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n rx,\n ry,\n entity.startAngle,\n entity.endAngle,\n majorAxisRotation,\n )\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'ARC') {\n // Why on earth DXF has degree start & end angles for arc,\n // and radian start & end angles for ellipses is a mystery\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n entity.r,\n entity.r,\n entity.startAngle,\n entity.endAngle,\n )\n\n // I kid you not, ARCs and ELLIPSEs handle this differently,\n // as evidenced by how AutoCAD actually renders these entities\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'SPLINE') {\n polyline = interpolateBSpline(\n entity.controlPoints,\n entity.degree,\n entity.knots,\n options.interpolationsPerSplineSegment,\n entity.weights,\n )\n }\n\n if (!polyline) {\n logger.warn('unsupported entity for converting to polyline:', entity.type)\n return []\n }\n return polyline\n}\n"],
5
- "mappings": "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",
6
- "names": ["bSpline", "createArcForLWPolyine", "logger"]
4
+ "sourcesContent": ["import bSpline from './util/bSpline'\nimport createArcForLWPolyine from './util/createArcForLWPolyline'\nimport logger from './util/logger'\n\nimport type {\n ArcEntity,\n CircleEntity,\n ControlPoint,\n EllipseEntity,\n EntityToPolylineOptions,\n HandlerVertex,\n LeaderEntity,\n LineEntity,\n RayEntity,\n ShapeEntity,\n SplineEntity,\n WipeoutEntity,\n XLineEntity,\n} from './types'\nimport type { PointTuple } from './types/common'\n\n// Re-export types for backward compatibility\nexport type { ControlPoint, EntityToPolylineOptions } from './types'\n\ntype Point = PointTuple\n\n// Local vertex type with required coordinates for runtime processing\ninterface LocalVertex extends HandlerVertex {\n faces?: number[]\n}\n\n// Local polyline type that uses our vertex with required coordinates\ninterface LocalPolylineEntity {\n type: string\n vertices: LocalVertex[]\n closed?: boolean\n polyfaceMesh?: boolean\n polygonMesh?: boolean\n}\n\ntype Entity =\n | LineEntity\n | LeaderEntity\n | RayEntity\n | XLineEntity\n | ShapeEntity\n | WipeoutEntity\n | (LocalPolylineEntity & { type: 'LWPOLYLINE' | 'POLYLINE' })\n | {\n type: 'SOLID' | 'TRACE'\n corners?: Array<{ x: number; y: number }>\n points?: Array<{ x: number; y: number }>\n }\n | CircleEntity\n | EllipseEntity\n | ArcEntity\n | SplineEntity\n\n/**\n * Rotate a set of points.\n *\n * @param points the points\n * @param angle the rotation angle\n */\nconst rotate = (points: Point[], angle: number): Point[] => {\n return points.map(function (p) {\n return [\n p[0] * Math.cos(angle) - p[1] * Math.sin(angle),\n p[1] * Math.cos(angle) + p[0] * Math.sin(angle),\n ]\n })\n}\n\n/**\n * Interpolate an ellipse\n * @param cx center X\n * @param cy center Y\n * @param rx radius X\n * @param ry radius Y\n * @param start start angle in radians\n * @param start end angle in radians\n */\nconst interpolateEllipse = (\n cx: number,\n cy: number,\n rx: number,\n ry: number,\n start: number,\n end: number,\n rotationAngle?: number\n): Point[] => {\n if (end < start) {\n end += Math.PI * 2\n }\n\n // ----- Relative points -----\n\n // Start point\n let points: Point[] = []\n const dTheta = (Math.PI * 2) / 72\n const EPS = 1e-6\n for (let theta = start; theta < end - EPS; theta += dTheta) {\n points.push([Math.cos(theta) * rx, Math.sin(theta) * ry])\n }\n points.push([Math.cos(end) * rx, Math.sin(end) * ry])\n\n // ----- Rotate -----\n if (rotationAngle) {\n points = rotate(points, rotationAngle)\n }\n\n // ----- Offset center -----\n points = points.map(function (p): Point {\n return [cx + p[0], cy + p[1]]\n })\n\n return points\n}\n\n/**\n * Interpolate a b-spline. The algorithm examins the knot vector\n * to create segments for interpolation. The parameterisation value\n * is re-normalised back to [0,1] as that is what the lib expects (\n * and t i de-normalised in the b-spline library)\n *\n * @param controlPoints the control points\n * @param degree the b-spline degree\n * @param knots the knot vector\n * @returns the polyline\n */\nexport const interpolateBSpline = (\n controlPoints: ControlPoint[],\n degree: number,\n knots: number[],\n interpolationsPerSplineSegment?: number,\n weights?: number[]\n): Point[] => {\n const polyline: Point[] = []\n const controlPointsForLib = controlPoints.map(function (p): Point {\n return [p.x, p.y]\n })\n\n const segmentTs = [knots[degree]]\n const domain: Point = [knots[degree], knots[knots.length - 1 - degree]]\n\n for (let k = degree + 1; k < knots.length - degree; ++k) {\n if (segmentTs[segmentTs.length - 1] !== knots[k]) {\n segmentTs.push(knots[k])\n }\n }\n\n interpolationsPerSplineSegment = interpolationsPerSplineSegment || 25\n for (let i = 1; i < segmentTs.length; ++i) {\n const uMin = segmentTs[i - 1]\n const uMax = segmentTs[i]\n for (let k = 0; k <= interpolationsPerSplineSegment; ++k) {\n const u = (k / interpolationsPerSplineSegment) * (uMax - uMin) + uMin\n // Clamp t to 0, 1 to handle numerical precision issues\n let t = (u - domain[0]) / (domain[1] - domain[0])\n t = Math.max(t, 0)\n t = Math.min(t, 1)\n const p = bSpline(t, degree, controlPointsForLib, knots, weights)\n polyline.push([p[0], p[1]])\n }\n }\n return polyline\n}\n\nexport const polyfaceOutline = (entity: LocalPolylineEntity): Point[][] => { // NOSONAR\n const vertices: Array<{ x: number; y: number }> = []\n const faces: Array<{ indices: number[]; hiddens: boolean[] }> = []\n\n for (const v of entity.vertices) {\n if (v.faces) {\n const face: { indices: number[]; hiddens: boolean[] } = {\n indices: [],\n hiddens: [],\n }\n for (const i of v.faces) {\n if (i === 0) {\n break\n }\n // Negative indices signify hidden edges\n face.indices.push(i < 0 ? -i - 1 : i - 1)\n face.hiddens.push(i < 0)\n }\n if ([3, 4].includes(face.indices.length)) faces.push(face)\n } else {\n vertices.push({ x: v.x, y: v.y })\n }\n }\n\n // If a segment starts at the end of a previous line, continue it\n const polylines: number[][] = []\n const segment = (a: number, b: number): void => {\n for (const prev of polylines) {\n if (prev.slice(-1)[0] === a) {\n prev.push(b)\n return\n }\n }\n polylines.push([a, b])\n }\n\n for (const face of faces) {\n for (let beg = 0; beg < face.indices.length; beg++) {\n if (face.hiddens[beg]) {\n continue\n }\n const end = (beg + 1) % face.indices.length\n segment(face.indices[beg], face.indices[end])\n }\n }\n\n // Sometimes segments are not sequential, in that case\n // we need to find if they can mend gaps between others\n for (const a of polylines) {\n for (const b of polylines) {\n if (a !== b && a[0] === b.slice(-1)[0]) {\n b.push(...a.slice(1))\n a.splice(0, a.length)\n break\n }\n }\n }\n\n return polylines\n .filter((l) => l.length)\n .map((l) => l.map((i) => vertices[i]).map((v) => [v.x, v.y]))\n}\n\n/**\n * Convert a parsed DXF entity to a polyline. These can be used to render the\n * the DXF in SVG, Canvas, WebGL etc., without depending on native support\n * of primitive objects (ellispe, spline etc.)\n */\nexport default function entityToPolyline( // NOSONAR\n entity: Entity,\n options?: EntityToPolylineOptions,\n): Point[] {\n options = options || {}\n let polyline: Point[] | undefined\n\n const INFINITE_LINE_LENGTH = 1000\n\n const normalize2 = (x: number, y: number): { x: number; y: number } | null => {\n const len = Math.hypot(x, y)\n if (len === 0) return null\n return { x: x / len, y: y / len }\n }\n\n if (entity.type === 'LINE') {\n polyline = [\n [entity.start.x, entity.start.y],\n [entity.end.x, entity.end.y],\n ]\n }\n\n if (entity.type === 'LEADER') {\n if (entity.vertices.length >= 2) {\n polyline = entity.vertices.map((v) => [v.x, v.y])\n } else {\n logger.warn('LEADER entity with insufficient vertices')\n polyline = []\n }\n }\n\n if (entity.type === 'RAY') {\n const dir = normalize2(entity.direction.x, entity.direction.y)\n if (dir === null) {\n logger.warn('RAY entity with zero direction vector')\n polyline = []\n } else {\n polyline = [\n [entity.start.x, entity.start.y],\n [\n entity.start.x + dir.x * INFINITE_LINE_LENGTH,\n entity.start.y + dir.y * INFINITE_LINE_LENGTH,\n ],\n ]\n }\n }\n\n if (entity.type === 'XLINE') {\n const dir = normalize2(entity.direction.x, entity.direction.y)\n if (dir === null) {\n logger.warn('XLINE entity with zero direction vector')\n polyline = []\n } else {\n polyline = [\n [\n entity.basePoint.x - dir.x * INFINITE_LINE_LENGTH,\n entity.basePoint.y - dir.y * INFINITE_LINE_LENGTH,\n ],\n [\n entity.basePoint.x + dir.x * INFINITE_LINE_LENGTH,\n entity.basePoint.y + dir.y * INFINITE_LINE_LENGTH,\n ],\n ]\n }\n }\n\n if (entity.type === 'SHAPE') {\n const x = entity.insertionPoint?.x ?? 0\n const y = entity.insertionPoint?.y ?? 0\n const size = entity.size ?? 0\n const scaleX = entity.relativeXScale ?? 1\n const length = size * scaleX\n polyline = [\n [x, y],\n [x + length, y],\n ]\n }\n\n if (entity.type === 'WIPEOUT') {\n const verts = entity.clipBoundaryVertices\n if (!verts || verts.length < 2) {\n logger.warn('WIPEOUT entity with missing clip boundary vertices')\n polyline = []\n } else {\n const insX = entity.insertionPoint?.x ?? 0\n const insY = entity.insertionPoint?.y ?? 0\n\n const ux = entity.uVector?.x ?? 1\n const uy = entity.uVector?.y ?? 0\n\n const vx = entity.vVector?.x ?? 0\n const vy = entity.vVector?.y ?? 1\n\n polyline = verts.map((p) => [\n insX + ux * p.x + vx * p.y,\n insY + uy * p.x + vy * p.y,\n ])\n\n if (polyline.length > 0) {\n const first = polyline[0]\n const last = polyline[polyline.length - 1]\n if (first[0] !== last[0] || first[1] !== last[1]) {\n polyline.push(first)\n }\n }\n }\n }\n\n if (entity.type === 'LWPOLYLINE' || entity.type === 'POLYLINE') {\n polyline = []\n if (entity.polyfaceMesh) {\n // Only return the first polyline because we can't return many\n polyline.push(...polyfaceOutline(entity)[0])\n } else if (entity.polygonMesh) {\n // Do not attempt to render polygon meshes\n } else if (entity.vertices.length) {\n if (entity.closed) {\n entity.vertices = entity.vertices.concat(entity.vertices[0])\n }\n for (let i = 0, il = entity.vertices.length; i < il - 1; ++i) {\n const from: Point = [entity.vertices[i].x, entity.vertices[i].y]\n const to: Point = [entity.vertices[i + 1].x, entity.vertices[i + 1].y]\n polyline.push(from)\n if (entity.vertices[i].bulge) {\n polyline = polyline.concat(\n createArcForLWPolyine(from, to, entity.vertices[i].bulge!),\n )\n }\n // The last iteration of the for loop\n if (i === il - 2) {\n polyline.push(to)\n }\n }\n } else {\n logger.warn('Polyline entity with no vertices')\n }\n }\n\n if (entity.type === 'CIRCLE') {\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n entity.r,\n entity.r,\n 0,\n Math.PI * 2,\n )\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'ELLIPSE') {\n const rx = Math.hypot(entity.majorX, entity.majorY)\n const ry = entity.axisRatio * rx\n const majorAxisRotation = -Math.atan2(-entity.majorY, entity.majorX)\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n rx,\n ry,\n entity.startAngle,\n entity.endAngle,\n majorAxisRotation,\n )\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'ARC') {\n // Why on earth DXF has degree start & end angles for arc,\n // and radian start & end angles for ellipses is a mystery\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n entity.r,\n entity.r,\n entity.startAngle,\n entity.endAngle,\n )\n\n // I kid you not, ARCs and ELLIPSEs handle this differently,\n // as evidenced by how AutoCAD actually renders these entities\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'SPLINE') {\n polyline = interpolateBSpline(\n entity.controlPoints,\n entity.degree,\n entity.knots,\n options.interpolationsPerSplineSegment,\n entity.weights,\n )\n }\n\n if (entity.type === 'SOLID' || entity.type === 'TRACE') {\n const corners = entity.corners ?? entity.points\n if (corners && corners.length >= 4) {\n polyline = [\n [corners[0].x, corners[0].y],\n [corners[1].x, corners[1].y],\n [corners[2].x, corners[2].y],\n [corners[3].x, corners[3].y],\n [corners[0].x, corners[0].y],\n ]\n }\n }\n\n if (!polyline) {\n logger.warn('unsupported entity for converting to polyline:', entity.type)\n return []\n }\n return polyline\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["bSpline", "logger", "createArcForLWPolyine"]
7
7
  }
@@ -109,12 +109,95 @@ const polyfaceOutline = (entity) => {
109
109
  function entityToPolyline(entity, options) {
110
110
  options = options || {};
111
111
  let polyline;
112
+ const INFINITE_LINE_LENGTH = 1e3;
113
+ const normalize2 = (x, y) => {
114
+ const len = Math.hypot(x, y);
115
+ if (len === 0) return null;
116
+ return { x: x / len, y: y / len };
117
+ };
112
118
  if (entity.type === "LINE") {
113
119
  polyline = [
114
120
  [entity.start.x, entity.start.y],
115
121
  [entity.end.x, entity.end.y]
116
122
  ];
117
123
  }
124
+ if (entity.type === "LEADER") {
125
+ if (entity.vertices.length >= 2) {
126
+ polyline = entity.vertices.map((v) => [v.x, v.y]);
127
+ } else {
128
+ logger.warn("LEADER entity with insufficient vertices");
129
+ polyline = [];
130
+ }
131
+ }
132
+ if (entity.type === "RAY") {
133
+ const dir = normalize2(entity.direction.x, entity.direction.y);
134
+ if (dir === null) {
135
+ logger.warn("RAY entity with zero direction vector");
136
+ polyline = [];
137
+ } else {
138
+ polyline = [
139
+ [entity.start.x, entity.start.y],
140
+ [
141
+ entity.start.x + dir.x * INFINITE_LINE_LENGTH,
142
+ entity.start.y + dir.y * INFINITE_LINE_LENGTH
143
+ ]
144
+ ];
145
+ }
146
+ }
147
+ if (entity.type === "XLINE") {
148
+ const dir = normalize2(entity.direction.x, entity.direction.y);
149
+ if (dir === null) {
150
+ logger.warn("XLINE entity with zero direction vector");
151
+ polyline = [];
152
+ } else {
153
+ polyline = [
154
+ [
155
+ entity.basePoint.x - dir.x * INFINITE_LINE_LENGTH,
156
+ entity.basePoint.y - dir.y * INFINITE_LINE_LENGTH
157
+ ],
158
+ [
159
+ entity.basePoint.x + dir.x * INFINITE_LINE_LENGTH,
160
+ entity.basePoint.y + dir.y * INFINITE_LINE_LENGTH
161
+ ]
162
+ ];
163
+ }
164
+ }
165
+ if (entity.type === "SHAPE") {
166
+ const x = entity.insertionPoint?.x ?? 0;
167
+ const y = entity.insertionPoint?.y ?? 0;
168
+ const size = entity.size ?? 0;
169
+ const scaleX = entity.relativeXScale ?? 1;
170
+ const length = size * scaleX;
171
+ polyline = [
172
+ [x, y],
173
+ [x + length, y]
174
+ ];
175
+ }
176
+ if (entity.type === "WIPEOUT") {
177
+ const verts = entity.clipBoundaryVertices;
178
+ if (!verts || verts.length < 2) {
179
+ logger.warn("WIPEOUT entity with missing clip boundary vertices");
180
+ polyline = [];
181
+ } else {
182
+ const insX = entity.insertionPoint?.x ?? 0;
183
+ const insY = entity.insertionPoint?.y ?? 0;
184
+ const ux = entity.uVector?.x ?? 1;
185
+ const uy = entity.uVector?.y ?? 0;
186
+ const vx = entity.vVector?.x ?? 0;
187
+ const vy = entity.vVector?.y ?? 1;
188
+ polyline = verts.map((p) => [
189
+ insX + ux * p.x + vx * p.y,
190
+ insY + uy * p.x + vy * p.y
191
+ ]);
192
+ if (polyline.length > 0) {
193
+ const first = polyline[0];
194
+ const last = polyline[polyline.length - 1];
195
+ if (first[0] !== last[0] || first[1] !== last[1]) {
196
+ polyline.push(first);
197
+ }
198
+ }
199
+ }
200
+ }
118
201
  if (entity.type === "LWPOLYLINE" || entity.type === "POLYLINE") {
119
202
  polyline = [];
120
203
  if (entity.polyfaceMesh) {
@@ -199,6 +282,18 @@ function entityToPolyline(entity, options) {
199
282
  entity.weights
200
283
  );
201
284
  }
285
+ if (entity.type === "SOLID" || entity.type === "TRACE") {
286
+ const corners = entity.corners ?? entity.points;
287
+ if (corners && corners.length >= 4) {
288
+ polyline = [
289
+ [corners[0].x, corners[0].y],
290
+ [corners[1].x, corners[1].y],
291
+ [corners[2].x, corners[2].y],
292
+ [corners[3].x, corners[3].y],
293
+ [corners[0].x, corners[0].y]
294
+ ];
295
+ }
296
+ }
202
297
  if (!polyline) {
203
298
  logger.warn("unsupported entity for converting to polyline:", entity.type);
204
299
  return [];
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/entityToPolyline.ts"],
4
- "sourcesContent": ["import bSpline from './util/bSpline'\nimport createArcForLWPolyine from './util/createArcForLWPolyline'\nimport logger from './util/logger'\n\nimport type {\n ArcEntity,\n CircleEntity,\n ControlPoint,\n EllipseEntity,\n EntityToPolylineOptions,\n HandlerVertex,\n LineEntity,\n SplineEntity,\n} from './types'\nimport type { PointTuple } from './types/common'\n\n// Re-export types for backward compatibility\nexport type { ControlPoint, EntityToPolylineOptions } from './types'\n\ntype Point = PointTuple\n\n// Local vertex type with required coordinates for runtime processing\ninterface LocalVertex extends HandlerVertex {\n faces?: number[]\n}\n\n// Local polyline type that uses our vertex with required coordinates\ninterface LocalPolylineEntity {\n type: string\n vertices: LocalVertex[]\n closed?: boolean\n polyfaceMesh?: boolean\n polygonMesh?: boolean\n}\n\ntype Entity =\n | LineEntity\n | (LocalPolylineEntity & { type: 'LWPOLYLINE' | 'POLYLINE' })\n | CircleEntity\n | EllipseEntity\n | ArcEntity\n | SplineEntity\n\n/**\n * Rotate a set of points.\n *\n * @param points the points\n * @param angle the rotation angle\n */\nconst rotate = (points: Point[], angle: number): Point[] => {\n return points.map(function (p) {\n return [\n p[0] * Math.cos(angle) - p[1] * Math.sin(angle),\n p[1] * Math.cos(angle) + p[0] * Math.sin(angle),\n ]\n })\n}\n\n/**\n * Interpolate an ellipse\n * @param cx center X\n * @param cy center Y\n * @param rx radius X\n * @param ry radius Y\n * @param start start angle in radians\n * @param start end angle in radians\n */\nconst interpolateEllipse = (\n cx: number,\n cy: number,\n rx: number,\n ry: number,\n start: number,\n end: number,\n rotationAngle?: number\n): Point[] => {\n if (end < start) {\n end += Math.PI * 2\n }\n\n // ----- Relative points -----\n\n // Start point\n let points: Point[] = []\n const dTheta = (Math.PI * 2) / 72\n const EPS = 1e-6\n for (let theta = start; theta < end - EPS; theta += dTheta) {\n points.push([Math.cos(theta) * rx, Math.sin(theta) * ry])\n }\n points.push([Math.cos(end) * rx, Math.sin(end) * ry])\n\n // ----- Rotate -----\n if (rotationAngle) {\n points = rotate(points, rotationAngle)\n }\n\n // ----- Offset center -----\n points = points.map(function (p): Point {\n return [cx + p[0], cy + p[1]]\n })\n\n return points\n}\n\n/**\n * Interpolate a b-spline. The algorithm examins the knot vector\n * to create segments for interpolation. The parameterisation value\n * is re-normalised back to [0,1] as that is what the lib expects (\n * and t i de-normalised in the b-spline library)\n *\n * @param controlPoints the control points\n * @param degree the b-spline degree\n * @param knots the knot vector\n * @returns the polyline\n */\nexport const interpolateBSpline = (\n controlPoints: ControlPoint[],\n degree: number,\n knots: number[],\n interpolationsPerSplineSegment?: number,\n weights?: number[]\n): Point[] => {\n const polyline: Point[] = []\n const controlPointsForLib = controlPoints.map(function (p): Point {\n return [p.x, p.y]\n })\n\n const segmentTs = [knots[degree]]\n const domain: Point = [knots[degree], knots[knots.length - 1 - degree]]\n\n for (let k = degree + 1; k < knots.length - degree; ++k) {\n if (segmentTs[segmentTs.length - 1] !== knots[k]) {\n segmentTs.push(knots[k])\n }\n }\n\n interpolationsPerSplineSegment = interpolationsPerSplineSegment || 25\n for (let i = 1; i < segmentTs.length; ++i) {\n const uMin = segmentTs[i - 1]\n const uMax = segmentTs[i]\n for (let k = 0; k <= interpolationsPerSplineSegment; ++k) {\n const u = (k / interpolationsPerSplineSegment) * (uMax - uMin) + uMin\n // Clamp t to 0, 1 to handle numerical precision issues\n let t = (u - domain[0]) / (domain[1] - domain[0])\n t = Math.max(t, 0)\n t = Math.min(t, 1)\n const p = bSpline(t, degree, controlPointsForLib, knots, weights)\n polyline.push([p[0], p[1]])\n }\n }\n return polyline\n}\n\nexport const polyfaceOutline = (entity: LocalPolylineEntity): Point[][] => {\n const vertices: Array<{ x: number; y: number }> = []\n const faces: Array<{ indices: number[]; hiddens: boolean[] }> = []\n\n for (const v of entity.vertices) {\n if (v.faces) {\n const face: { indices: number[]; hiddens: boolean[] } = {\n indices: [],\n hiddens: [],\n }\n for (const i of v.faces) {\n if (i === 0) {\n break\n }\n // Negative indices signify hidden edges\n face.indices.push(i < 0 ? -i - 1 : i - 1)\n face.hiddens.push(i < 0)\n }\n if ([3, 4].includes(face.indices.length)) faces.push(face)\n } else {\n vertices.push({ x: v.x, y: v.y })\n }\n }\n\n // If a segment starts at the end of a previous line, continue it\n const polylines: number[][] = []\n const segment = (a: number, b: number): void => {\n for (const prev of polylines) {\n if (prev.slice(-1)[0] === a) {\n prev.push(b)\n return\n }\n }\n polylines.push([a, b])\n }\n\n for (const face of faces) {\n for (let beg = 0; beg < face.indices.length; beg++) {\n if (face.hiddens[beg]) {\n continue\n }\n const end = (beg + 1) % face.indices.length\n segment(face.indices[beg], face.indices[end])\n }\n }\n\n // Sometimes segments are not sequential, in that case\n // we need to find if they can mend gaps between others\n for (const a of polylines) {\n for (const b of polylines) {\n if (a !== b && a[0] === b.slice(-1)[0]) {\n b.push(...a.slice(1))\n a.splice(0, a.length)\n break\n }\n }\n }\n\n return polylines\n .filter((l) => l.length)\n .map((l) => l.map((i) => vertices[i]).map((v) => [v.x, v.y]))\n}\n\n/**\n * Convert a parsed DXF entity to a polyline. These can be used to render the\n * the DXF in SVG, Canvas, WebGL etc., without depending on native support\n * of primitive objects (ellispe, spline etc.)\n */\nexport default function entityToPolyline(\n entity: Entity,\n options?: EntityToPolylineOptions,\n): Point[] {\n options = options || {}\n let polyline: Point[] | undefined\n\n if (entity.type === 'LINE') {\n polyline = [\n [entity.start.x, entity.start.y],\n [entity.end.x, entity.end.y],\n ]\n }\n\n if (entity.type === 'LWPOLYLINE' || entity.type === 'POLYLINE') {\n polyline = []\n if (entity.polyfaceMesh) {\n // Only return the first polyline because we can't return many\n polyline.push(...polyfaceOutline(entity)[0])\n } else if (entity.polygonMesh) {\n // Do not attempt to render polygon meshes\n } else if (entity.vertices.length) {\n if (entity.closed) {\n entity.vertices = entity.vertices.concat(entity.vertices[0])\n }\n for (let i = 0, il = entity.vertices.length; i < il - 1; ++i) {\n const from: Point = [entity.vertices[i].x, entity.vertices[i].y]\n const to: Point = [entity.vertices[i + 1].x, entity.vertices[i + 1].y]\n polyline.push(from)\n if (entity.vertices[i].bulge) {\n polyline = polyline.concat(\n createArcForLWPolyine(from, to, entity.vertices[i].bulge!),\n )\n }\n // The last iteration of the for loop\n if (i === il - 2) {\n polyline.push(to)\n }\n }\n } else {\n logger.warn('Polyline entity with no vertices')\n }\n }\n\n if (entity.type === 'CIRCLE') {\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n entity.r,\n entity.r,\n 0,\n Math.PI * 2,\n )\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'ELLIPSE') {\n const rx = Math.hypot(entity.majorX, entity.majorY)\n const ry = entity.axisRatio * rx\n const majorAxisRotation = -Math.atan2(-entity.majorY, entity.majorX)\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n rx,\n ry,\n entity.startAngle,\n entity.endAngle,\n majorAxisRotation,\n )\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'ARC') {\n // Why on earth DXF has degree start & end angles for arc,\n // and radian start & end angles for ellipses is a mystery\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n entity.r,\n entity.r,\n entity.startAngle,\n entity.endAngle,\n )\n\n // I kid you not, ARCs and ELLIPSEs handle this differently,\n // as evidenced by how AutoCAD actually renders these entities\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'SPLINE') {\n polyline = interpolateBSpline(\n entity.controlPoints,\n entity.degree,\n entity.knots,\n options.interpolationsPerSplineSegment,\n entity.weights,\n )\n }\n\n if (!polyline) {\n logger.warn('unsupported entity for converting to polyline:', entity.type)\n return []\n }\n return polyline\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import bSpline from './util/bSpline'\nimport createArcForLWPolyine from './util/createArcForLWPolyline'\nimport logger from './util/logger'\n\nimport type {\n ArcEntity,\n CircleEntity,\n ControlPoint,\n EllipseEntity,\n EntityToPolylineOptions,\n HandlerVertex,\n LeaderEntity,\n LineEntity,\n RayEntity,\n ShapeEntity,\n SplineEntity,\n WipeoutEntity,\n XLineEntity,\n} from './types'\nimport type { PointTuple } from './types/common'\n\n// Re-export types for backward compatibility\nexport type { ControlPoint, EntityToPolylineOptions } from './types'\n\ntype Point = PointTuple\n\n// Local vertex type with required coordinates for runtime processing\ninterface LocalVertex extends HandlerVertex {\n faces?: number[]\n}\n\n// Local polyline type that uses our vertex with required coordinates\ninterface LocalPolylineEntity {\n type: string\n vertices: LocalVertex[]\n closed?: boolean\n polyfaceMesh?: boolean\n polygonMesh?: boolean\n}\n\ntype Entity =\n | LineEntity\n | LeaderEntity\n | RayEntity\n | XLineEntity\n | ShapeEntity\n | WipeoutEntity\n | (LocalPolylineEntity & { type: 'LWPOLYLINE' | 'POLYLINE' })\n | {\n type: 'SOLID' | 'TRACE'\n corners?: Array<{ x: number; y: number }>\n points?: Array<{ x: number; y: number }>\n }\n | CircleEntity\n | EllipseEntity\n | ArcEntity\n | SplineEntity\n\n/**\n * Rotate a set of points.\n *\n * @param points the points\n * @param angle the rotation angle\n */\nconst rotate = (points: Point[], angle: number): Point[] => {\n return points.map(function (p) {\n return [\n p[0] * Math.cos(angle) - p[1] * Math.sin(angle),\n p[1] * Math.cos(angle) + p[0] * Math.sin(angle),\n ]\n })\n}\n\n/**\n * Interpolate an ellipse\n * @param cx center X\n * @param cy center Y\n * @param rx radius X\n * @param ry radius Y\n * @param start start angle in radians\n * @param start end angle in radians\n */\nconst interpolateEllipse = (\n cx: number,\n cy: number,\n rx: number,\n ry: number,\n start: number,\n end: number,\n rotationAngle?: number\n): Point[] => {\n if (end < start) {\n end += Math.PI * 2\n }\n\n // ----- Relative points -----\n\n // Start point\n let points: Point[] = []\n const dTheta = (Math.PI * 2) / 72\n const EPS = 1e-6\n for (let theta = start; theta < end - EPS; theta += dTheta) {\n points.push([Math.cos(theta) * rx, Math.sin(theta) * ry])\n }\n points.push([Math.cos(end) * rx, Math.sin(end) * ry])\n\n // ----- Rotate -----\n if (rotationAngle) {\n points = rotate(points, rotationAngle)\n }\n\n // ----- Offset center -----\n points = points.map(function (p): Point {\n return [cx + p[0], cy + p[1]]\n })\n\n return points\n}\n\n/**\n * Interpolate a b-spline. The algorithm examins the knot vector\n * to create segments for interpolation. The parameterisation value\n * is re-normalised back to [0,1] as that is what the lib expects (\n * and t i de-normalised in the b-spline library)\n *\n * @param controlPoints the control points\n * @param degree the b-spline degree\n * @param knots the knot vector\n * @returns the polyline\n */\nexport const interpolateBSpline = (\n controlPoints: ControlPoint[],\n degree: number,\n knots: number[],\n interpolationsPerSplineSegment?: number,\n weights?: number[]\n): Point[] => {\n const polyline: Point[] = []\n const controlPointsForLib = controlPoints.map(function (p): Point {\n return [p.x, p.y]\n })\n\n const segmentTs = [knots[degree]]\n const domain: Point = [knots[degree], knots[knots.length - 1 - degree]]\n\n for (let k = degree + 1; k < knots.length - degree; ++k) {\n if (segmentTs[segmentTs.length - 1] !== knots[k]) {\n segmentTs.push(knots[k])\n }\n }\n\n interpolationsPerSplineSegment = interpolationsPerSplineSegment || 25\n for (let i = 1; i < segmentTs.length; ++i) {\n const uMin = segmentTs[i - 1]\n const uMax = segmentTs[i]\n for (let k = 0; k <= interpolationsPerSplineSegment; ++k) {\n const u = (k / interpolationsPerSplineSegment) * (uMax - uMin) + uMin\n // Clamp t to 0, 1 to handle numerical precision issues\n let t = (u - domain[0]) / (domain[1] - domain[0])\n t = Math.max(t, 0)\n t = Math.min(t, 1)\n const p = bSpline(t, degree, controlPointsForLib, knots, weights)\n polyline.push([p[0], p[1]])\n }\n }\n return polyline\n}\n\nexport const polyfaceOutline = (entity: LocalPolylineEntity): Point[][] => { // NOSONAR\n const vertices: Array<{ x: number; y: number }> = []\n const faces: Array<{ indices: number[]; hiddens: boolean[] }> = []\n\n for (const v of entity.vertices) {\n if (v.faces) {\n const face: { indices: number[]; hiddens: boolean[] } = {\n indices: [],\n hiddens: [],\n }\n for (const i of v.faces) {\n if (i === 0) {\n break\n }\n // Negative indices signify hidden edges\n face.indices.push(i < 0 ? -i - 1 : i - 1)\n face.hiddens.push(i < 0)\n }\n if ([3, 4].includes(face.indices.length)) faces.push(face)\n } else {\n vertices.push({ x: v.x, y: v.y })\n }\n }\n\n // If a segment starts at the end of a previous line, continue it\n const polylines: number[][] = []\n const segment = (a: number, b: number): void => {\n for (const prev of polylines) {\n if (prev.slice(-1)[0] === a) {\n prev.push(b)\n return\n }\n }\n polylines.push([a, b])\n }\n\n for (const face of faces) {\n for (let beg = 0; beg < face.indices.length; beg++) {\n if (face.hiddens[beg]) {\n continue\n }\n const end = (beg + 1) % face.indices.length\n segment(face.indices[beg], face.indices[end])\n }\n }\n\n // Sometimes segments are not sequential, in that case\n // we need to find if they can mend gaps between others\n for (const a of polylines) {\n for (const b of polylines) {\n if (a !== b && a[0] === b.slice(-1)[0]) {\n b.push(...a.slice(1))\n a.splice(0, a.length)\n break\n }\n }\n }\n\n return polylines\n .filter((l) => l.length)\n .map((l) => l.map((i) => vertices[i]).map((v) => [v.x, v.y]))\n}\n\n/**\n * Convert a parsed DXF entity to a polyline. These can be used to render the\n * the DXF in SVG, Canvas, WebGL etc., without depending on native support\n * of primitive objects (ellispe, spline etc.)\n */\nexport default function entityToPolyline( // NOSONAR\n entity: Entity,\n options?: EntityToPolylineOptions,\n): Point[] {\n options = options || {}\n let polyline: Point[] | undefined\n\n const INFINITE_LINE_LENGTH = 1000\n\n const normalize2 = (x: number, y: number): { x: number; y: number } | null => {\n const len = Math.hypot(x, y)\n if (len === 0) return null\n return { x: x / len, y: y / len }\n }\n\n if (entity.type === 'LINE') {\n polyline = [\n [entity.start.x, entity.start.y],\n [entity.end.x, entity.end.y],\n ]\n }\n\n if (entity.type === 'LEADER') {\n if (entity.vertices.length >= 2) {\n polyline = entity.vertices.map((v) => [v.x, v.y])\n } else {\n logger.warn('LEADER entity with insufficient vertices')\n polyline = []\n }\n }\n\n if (entity.type === 'RAY') {\n const dir = normalize2(entity.direction.x, entity.direction.y)\n if (dir === null) {\n logger.warn('RAY entity with zero direction vector')\n polyline = []\n } else {\n polyline = [\n [entity.start.x, entity.start.y],\n [\n entity.start.x + dir.x * INFINITE_LINE_LENGTH,\n entity.start.y + dir.y * INFINITE_LINE_LENGTH,\n ],\n ]\n }\n }\n\n if (entity.type === 'XLINE') {\n const dir = normalize2(entity.direction.x, entity.direction.y)\n if (dir === null) {\n logger.warn('XLINE entity with zero direction vector')\n polyline = []\n } else {\n polyline = [\n [\n entity.basePoint.x - dir.x * INFINITE_LINE_LENGTH,\n entity.basePoint.y - dir.y * INFINITE_LINE_LENGTH,\n ],\n [\n entity.basePoint.x + dir.x * INFINITE_LINE_LENGTH,\n entity.basePoint.y + dir.y * INFINITE_LINE_LENGTH,\n ],\n ]\n }\n }\n\n if (entity.type === 'SHAPE') {\n const x = entity.insertionPoint?.x ?? 0\n const y = entity.insertionPoint?.y ?? 0\n const size = entity.size ?? 0\n const scaleX = entity.relativeXScale ?? 1\n const length = size * scaleX\n polyline = [\n [x, y],\n [x + length, y],\n ]\n }\n\n if (entity.type === 'WIPEOUT') {\n const verts = entity.clipBoundaryVertices\n if (!verts || verts.length < 2) {\n logger.warn('WIPEOUT entity with missing clip boundary vertices')\n polyline = []\n } else {\n const insX = entity.insertionPoint?.x ?? 0\n const insY = entity.insertionPoint?.y ?? 0\n\n const ux = entity.uVector?.x ?? 1\n const uy = entity.uVector?.y ?? 0\n\n const vx = entity.vVector?.x ?? 0\n const vy = entity.vVector?.y ?? 1\n\n polyline = verts.map((p) => [\n insX + ux * p.x + vx * p.y,\n insY + uy * p.x + vy * p.y,\n ])\n\n if (polyline.length > 0) {\n const first = polyline[0]\n const last = polyline[polyline.length - 1]\n if (first[0] !== last[0] || first[1] !== last[1]) {\n polyline.push(first)\n }\n }\n }\n }\n\n if (entity.type === 'LWPOLYLINE' || entity.type === 'POLYLINE') {\n polyline = []\n if (entity.polyfaceMesh) {\n // Only return the first polyline because we can't return many\n polyline.push(...polyfaceOutline(entity)[0])\n } else if (entity.polygonMesh) {\n // Do not attempt to render polygon meshes\n } else if (entity.vertices.length) {\n if (entity.closed) {\n entity.vertices = entity.vertices.concat(entity.vertices[0])\n }\n for (let i = 0, il = entity.vertices.length; i < il - 1; ++i) {\n const from: Point = [entity.vertices[i].x, entity.vertices[i].y]\n const to: Point = [entity.vertices[i + 1].x, entity.vertices[i + 1].y]\n polyline.push(from)\n if (entity.vertices[i].bulge) {\n polyline = polyline.concat(\n createArcForLWPolyine(from, to, entity.vertices[i].bulge!),\n )\n }\n // The last iteration of the for loop\n if (i === il - 2) {\n polyline.push(to)\n }\n }\n } else {\n logger.warn('Polyline entity with no vertices')\n }\n }\n\n if (entity.type === 'CIRCLE') {\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n entity.r,\n entity.r,\n 0,\n Math.PI * 2,\n )\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'ELLIPSE') {\n const rx = Math.hypot(entity.majorX, entity.majorY)\n const ry = entity.axisRatio * rx\n const majorAxisRotation = -Math.atan2(-entity.majorY, entity.majorX)\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n rx,\n ry,\n entity.startAngle,\n entity.endAngle,\n majorAxisRotation,\n )\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'ARC') {\n // Why on earth DXF has degree start & end angles for arc,\n // and radian start & end angles for ellipses is a mystery\n polyline = interpolateEllipse(\n entity.x,\n entity.y,\n entity.r,\n entity.r,\n entity.startAngle,\n entity.endAngle,\n )\n\n // I kid you not, ARCs and ELLIPSEs handle this differently,\n // as evidenced by how AutoCAD actually renders these entities\n if (entity.extrusionZ === -1) {\n polyline = polyline.map(function (p): Point {\n return [-p[0], p[1]]\n })\n }\n }\n\n if (entity.type === 'SPLINE') {\n polyline = interpolateBSpline(\n entity.controlPoints,\n entity.degree,\n entity.knots,\n options.interpolationsPerSplineSegment,\n entity.weights,\n )\n }\n\n if (entity.type === 'SOLID' || entity.type === 'TRACE') {\n const corners = entity.corners ?? entity.points\n if (corners && corners.length >= 4) {\n polyline = [\n [corners[0].x, corners[0].y],\n [corners[1].x, corners[1].y],\n [corners[2].x, corners[2].y],\n [corners[3].x, corners[3].y],\n [corners[0].x, corners[0].y],\n ]\n }\n }\n\n if (!polyline) {\n logger.warn('unsupported entity for converting to polyline:', entity.type)\n return []\n }\n return polyline\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -39,7 +39,6 @@ var import_circle = __toESM(require("./entity/circle"), 1);
39
39
  var import_dgnUnderlay = __toESM(require("./entity/dgnUnderlay"), 1);
40
40
  var import_dimension = __toESM(require("./entity/dimension"), 1);
41
41
  var import_dwfUnderlay = __toESM(require("./entity/dwfUnderlay"), 1);
42
- var import_pdfUnderlay = __toESM(require("./entity/pdfUnderlay"), 1);
43
42
  var import_ellipse = __toESM(require("./entity/ellipse"), 1);
44
43
  var import_hatch = __toESM(require("./entity/hatch"), 1);
45
44
  var import_image = __toESM(require("./entity/image"), 1);
@@ -47,34 +46,52 @@ var import_insert = __toESM(require("./entity/insert"), 1);
47
46
  var import_leader = __toESM(require("./entity/leader"), 1);
48
47
  var import_line = __toESM(require("./entity/line"), 1);
49
48
  var import_lwpolyline = __toESM(require("./entity/lwpolyline"), 1);
49
+ var import_mleader = __toESM(require("./entity/mleader"), 1);
50
+ var import_mline = __toESM(require("./entity/mline"), 1);
50
51
  var import_mtext = __toESM(require("./entity/mtext"), 1);
51
52
  var import_ole2Frame = __toESM(require("./entity/ole2Frame"), 1);
53
+ var import_oleframe = __toESM(require("./entity/oleframe"), 1);
54
+ var import_pdfUnderlay = __toESM(require("./entity/pdfUnderlay"), 1);
52
55
  var import_point = __toESM(require("./entity/point"), 1);
53
56
  var import_polyline = __toESM(require("./entity/polyline"), 1);
57
+ var import_ray = __toESM(require("./entity/ray"), 1);
58
+ var import_region = __toESM(require("./entity/region"), 1);
59
+ var import_shape = __toESM(require("./entity/shape"), 1);
54
60
  var import_solid = __toESM(require("./entity/solid"), 1);
55
61
  var import_spline = __toESM(require("./entity/spline"), 1);
62
+ var import_table = __toESM(require("./entity/table"), 1);
56
63
  var import_text = __toESM(require("./entity/text"), 1);
57
64
  var import_threeDFace = __toESM(require("./entity/threeDFace"), 1);
58
65
  var import_tolerance = __toESM(require("./entity/tolerance"), 1);
66
+ var import_trace = __toESM(require("./entity/trace"), 1);
59
67
  var import_vertex = __toESM(require("./entity/vertex"), 1);
60
68
  var import_viewport = __toESM(require("./entity/viewport"), 1);
69
+ var import_wipeout = __toESM(require("./entity/wipeout"), 1);
70
+ var import_xline = __toESM(require("./entity/xline"), 1);
61
71
  const handlers = [
62
72
  import_point.default,
63
73
  import_line.default,
64
74
  import_lwpolyline.default,
75
+ import_mline.default,
76
+ import_mleader.default,
65
77
  import_polyline.default,
66
78
  import_vertex.default,
67
79
  import_circle.default,
68
80
  import_arc.default,
69
81
  import_ellipse.default,
70
82
  import_spline.default,
83
+ import_table.default,
71
84
  import_solid.default,
85
+ import_trace.default,
72
86
  import_hatch.default,
73
87
  import_image.default,
74
88
  import_leader.default,
89
+ import_ray.default,
90
+ import_region.default,
75
91
  import_dwfUnderlay.default,
76
92
  import_dgnUnderlay.default,
77
93
  import_pdfUnderlay.default,
94
+ import_shape.default,
78
95
  import_mtext.default,
79
96
  import_tolerance.default,
80
97
  import_attdef.default,
@@ -84,7 +101,10 @@ const handlers = [
84
101
  import_dimension.default,
85
102
  import_threeDFace.default,
86
103
  import_viewport.default,
87
- import_ole2Frame.default
104
+ import_ole2Frame.default,
105
+ import_oleframe.default,
106
+ import_xline.default,
107
+ import_wipeout.default
88
108
  ].reduce((acc, mod) => {
89
109
  acc[mod.TYPE] = mod;
90
110
  return acc;
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/handlers/entities.ts"],
4
- "sourcesContent": ["import type { DXFTuple } from '../types/dxf'\nimport type { Entity } from '../types/entity'\nimport type { PolylineEntity, Vertex } from '../types/polyline-entity'\n\nimport logger from '../util/logger'\nimport arc from './entity/arc'\nimport attdef from './entity/attdef'\nimport attrib from './entity/attrib'\nimport circle from './entity/circle'\nimport dgnUnderlay from './entity/dgnUnderlay'\nimport dimension from './entity/dimension'\nimport dwfUnderlay from './entity/dwfUnderlay'\nimport pdfUnderlay from './entity/pdfUnderlay'\nimport ellipse from './entity/ellipse'\nimport hatch from './entity/hatch'\nimport image from './entity/image'\nimport insert from './entity/insert'\nimport leader from './entity/leader'\nimport line from './entity/line'\nimport lwpolyline from './entity/lwpolyline'\nimport mtext from './entity/mtext'\nimport ole2Frame from './entity/ole2Frame'\nimport point from './entity/point'\nimport polyline from './entity/polyline'\nimport solid from './entity/solid'\nimport spline from './entity/spline'\nimport text from './entity/text'\nimport threeDFace from './entity/threeDFace'\nimport tolerance from './entity/tolerance'\nimport vertex from './entity/vertex'\nimport viewport from './entity/viewport'\n\ninterface EntityHandler {\n TYPE: string\n process: (tuples: DXFTuple[]) => Entity\n}\n\nconst handlers: Record<string, EntityHandler> = [\n point,\n line,\n lwpolyline,\n polyline,\n vertex,\n circle,\n arc,\n ellipse,\n spline,\n solid,\n hatch,\n image,\n leader,\n dwfUnderlay,\n dgnUnderlay,\n pdfUnderlay,\n mtext,\n tolerance,\n attdef,\n attrib,\n text,\n insert,\n dimension,\n threeDFace,\n viewport,\n ole2Frame,\n].reduce((acc, mod) => {\n acc[mod.TYPE] = mod\n return acc\n}, {} as Record<string, EntityHandler>)\n\n/**\n * Parses entities from DXF tuples\n *\n * @param tuples - Array of DXF tuples representing entities\n * @returns Array of parsed entities\n */\nclass EntityGroupProcessor {\n private readonly entities: Entity[] = []\n private currentPolyline: PolylineEntity | undefined\n\n getEntities(): Entity[] {\n return this.entities\n }\n\n finalize(): void {\n this.flushOpenPolyline('DXF ended with an open POLYLINE (missing SEQEND); flushing open polyline')\n }\n\n processGroup(tuples: DXFTuple[]): void {\n const entityType = String(tuples[0][1])\n const contentTuples = tuples.slice(1)\n\n switch (entityType) {\n case 'SEQEND':\n this.endSequence()\n break\n case 'POLYLINE':\n this.startPolyline(contentTuples)\n break\n case 'VERTEX':\n this.addVertex(contentTuples)\n break\n default:\n this.addEntity(entityType, contentTuples)\n break\n }\n }\n\n private parseEntity(entityType: string, contentTuples: DXFTuple[]): Entity | undefined {\n const handler = handlers[entityType]\n if (!handler) {\n logger.warn('unsupported type in ENTITIES section:', entityType)\n return undefined\n }\n return handler.process(contentTuples)\n }\n\n private flushOpenPolyline(reason: string): void {\n if (!this.currentPolyline) return\n logger.warn(reason)\n this.currentPolyline = undefined\n }\n\n private endSequence(): void {\n // SEQEND may also terminate other sequences (e.g. INSERT attributes).\n // Only treat it as significant when we're inside a POLYLINE sequence.\n this.currentPolyline = undefined\n }\n\n private startPolyline(contentTuples: DXFTuple[]): void {\n this.flushOpenPolyline(\n 'POLYLINE started while previous POLYLINE is still open; flushing previous polyline',\n )\n\n const e = this.parseEntity('POLYLINE', contentTuples)\n if (!e) return\n\n this.currentPolyline = e as PolylineEntity\n this.entities.push(e)\n }\n\n private addVertex(contentTuples: DXFTuple[]): void {\n const e = this.parseEntity('VERTEX', contentTuples)\n if (!e) return\n\n if (!this.currentPolyline) {\n logger.error('ignoring invalid VERTEX entity')\n return\n }\n\n this.currentPolyline.vertices.push(e as Vertex)\n }\n\n private addEntity(entityType: string, contentTuples: DXFTuple[]): void {\n this.flushOpenPolyline('POLYLINE sequence ended without SEQEND; flushing open polyline')\n\n const e = this.parseEntity(entityType, contentTuples)\n if (!e) return\n this.entities.push(e)\n }\n}\n\nfunction processEntityGroups(entityGroups: DXFTuple[][]): Entity[] {\n const processor = new EntityGroupProcessor()\n for (const tuples of entityGroups) {\n processor.processGroup(tuples)\n }\n processor.finalize()\n return processor.getEntities()\n}\n\nexport default function parseEntities(tuples: DXFTuple[]): Entity[] {\n const entityGroups: DXFTuple[][] = []\n let currentEntityTuples: DXFTuple[] = []\n\n // First group them together for easy processing\n for (const tuple of tuples) {\n const type = tuple[0]\n if (type === 0) {\n currentEntityTuples = []\n entityGroups.push(currentEntityTuples)\n }\n currentEntityTuples.push(tuple)\n }\n\n return processEntityGroups(entityGroups)\n}\n"],
5
- "mappings": "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",
6
- "names": ["point", "line", "lwpolyline", "polyline", "vertex", "circle", "arc", "ellipse", "spline", "solid", "hatch", "image", "leader", "dwfUnderlay", "dgnUnderlay", "pdfUnderlay", "mtext", "tolerance", "attdef", "attrib", "text", "insert", "dimension", "threeDFace", "viewport", "ole2Frame", "logger"]
4
+ "sourcesContent": ["import type { DXFTuple } from '../types/dxf'\nimport type { Entity } from '../types/entity'\nimport type { PolylineEntity, Vertex } from '../types/polyline-entity'\n\nimport logger from '../util/logger'\nimport arc from './entity/arc'\nimport attdef from './entity/attdef'\nimport attrib from './entity/attrib'\nimport circle from './entity/circle'\nimport dgnUnderlay from './entity/dgnUnderlay'\nimport dimension from './entity/dimension'\nimport dwfUnderlay from './entity/dwfUnderlay'\nimport ellipse from './entity/ellipse'\nimport hatch from './entity/hatch'\nimport image from './entity/image'\nimport insert from './entity/insert'\nimport leader from './entity/leader'\nimport line from './entity/line'\nimport lwpolyline from './entity/lwpolyline'\nimport mleader from './entity/mleader'\nimport mline from './entity/mline'\nimport mtext from './entity/mtext'\nimport ole2Frame from './entity/ole2Frame'\nimport oleFrame from './entity/oleframe'\nimport pdfUnderlay from './entity/pdfUnderlay'\nimport point from './entity/point'\nimport polyline from './entity/polyline'\nimport ray from './entity/ray'\nimport region from './entity/region'\nimport shape from './entity/shape'\nimport solid from './entity/solid'\nimport spline from './entity/spline'\nimport table from './entity/table'\nimport text from './entity/text'\nimport threeDFace from './entity/threeDFace'\nimport tolerance from './entity/tolerance'\nimport trace from './entity/trace'\nimport vertex from './entity/vertex'\nimport viewport from './entity/viewport'\nimport wipeout from './entity/wipeout'\nimport xline from './entity/xline'\n\ninterface EntityHandler {\n TYPE: string\n process: (tuples: DXFTuple[]) => Entity\n}\n\nconst handlers: Record<string, EntityHandler> = [\n point,\n line,\n lwpolyline,\n mline,\n mleader,\n polyline,\n vertex,\n circle,\n arc,\n ellipse,\n spline,\n table,\n solid,\n trace,\n hatch,\n image,\n leader,\n ray,\n region,\n dwfUnderlay,\n dgnUnderlay,\n pdfUnderlay,\n shape,\n mtext,\n tolerance,\n attdef,\n attrib,\n text,\n insert,\n dimension,\n threeDFace,\n viewport,\n ole2Frame,\n oleFrame,\n xline,\n wipeout,\n].reduce((acc, mod) => {\n acc[mod.TYPE] = mod\n return acc\n}, {} as Record<string, EntityHandler>)\n\n/**\n * Parses entities from DXF tuples\n *\n * @param tuples - Array of DXF tuples representing entities\n * @returns Array of parsed entities\n */\nclass EntityGroupProcessor {\n private readonly entities: Entity[] = []\n private currentPolyline: PolylineEntity | undefined\n\n getEntities(): Entity[] {\n return this.entities\n }\n\n finalize(): void {\n this.flushOpenPolyline('DXF ended with an open POLYLINE (missing SEQEND); flushing open polyline')\n }\n\n processGroup(tuples: DXFTuple[]): void {\n const entityType = String(tuples[0][1])\n const contentTuples = tuples.slice(1)\n\n switch (entityType) {\n case 'SEQEND':\n this.endSequence()\n break\n case 'POLYLINE':\n this.startPolyline(contentTuples)\n break\n case 'VERTEX':\n this.addVertex(contentTuples)\n break\n default:\n this.addEntity(entityType, contentTuples)\n break\n }\n }\n\n private parseEntity(entityType: string, contentTuples: DXFTuple[]): Entity | undefined {\n const handler = handlers[entityType]\n if (!handler) {\n logger.warn('unsupported type in ENTITIES section:', entityType)\n return undefined\n }\n return handler.process(contentTuples)\n }\n\n private flushOpenPolyline(reason: string): void {\n if (!this.currentPolyline) return\n logger.warn(reason)\n this.currentPolyline = undefined\n }\n\n private endSequence(): void {\n // SEQEND may also terminate other sequences (e.g. INSERT attributes).\n // Only treat it as significant when we're inside a POLYLINE sequence.\n this.currentPolyline = undefined\n }\n\n private startPolyline(contentTuples: DXFTuple[]): void {\n this.flushOpenPolyline(\n 'POLYLINE started while previous POLYLINE is still open; flushing previous polyline',\n )\n\n const e = this.parseEntity('POLYLINE', contentTuples)\n if (!e) return\n\n this.currentPolyline = e as PolylineEntity\n this.entities.push(e)\n }\n\n private addVertex(contentTuples: DXFTuple[]): void {\n const e = this.parseEntity('VERTEX', contentTuples)\n if (!e) return\n\n if (!this.currentPolyline) {\n logger.error('ignoring invalid VERTEX entity')\n return\n }\n\n this.currentPolyline.vertices.push(e as Vertex)\n }\n\n private addEntity(entityType: string, contentTuples: DXFTuple[]): void {\n this.flushOpenPolyline('POLYLINE sequence ended without SEQEND; flushing open polyline')\n\n const e = this.parseEntity(entityType, contentTuples)\n if (!e) return\n this.entities.push(e)\n }\n}\n\nfunction processEntityGroups(entityGroups: DXFTuple[][]): Entity[] {\n const processor = new EntityGroupProcessor()\n for (const tuples of entityGroups) {\n processor.processGroup(tuples)\n }\n processor.finalize()\n return processor.getEntities()\n}\n\nexport default function parseEntities(tuples: DXFTuple[]): Entity[] {\n const entityGroups: DXFTuple[][] = []\n let currentEntityTuples: DXFTuple[] = []\n\n // First group them together for easy processing\n for (const tuple of tuples) {\n const type = tuple[0]\n if (type === 0) {\n currentEntityTuples = []\n entityGroups.push(currentEntityTuples)\n }\n currentEntityTuples.push(tuple)\n }\n\n return processEntityGroups(entityGroups)\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["point", "line", "lwpolyline", "mline", "mleader", "polyline", "vertex", "circle", "arc", "ellipse", "spline", "table", "solid", "trace", "hatch", "image", "leader", "ray", "region", "dwfUnderlay", "dgnUnderlay", "pdfUnderlay", "shape", "mtext", "tolerance", "attdef", "attrib", "text", "insert", "dimension", "threeDFace", "viewport", "ole2Frame", "oleFrame", "xline", "wipeout", "logger"]
7
7
  }