@combeenation/3d-viewer 5.2.0-alpha5 → 6.1.0-beta1

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 (191) hide show
  1. package/README.md +111 -111
  2. package/dist/lib-cjs/api/classes/animationInterface.d.ts +8 -8
  3. package/dist/lib-cjs/api/classes/animationInterface.js +2 -2
  4. package/dist/lib-cjs/api/classes/dottedPath.d.ts +79 -79
  5. package/dist/lib-cjs/api/classes/dottedPath.js +166 -166
  6. package/dist/lib-cjs/api/classes/element.d.ts +149 -149
  7. package/dist/lib-cjs/api/classes/element.js +669 -669
  8. package/dist/lib-cjs/api/classes/element.js.map +1 -1
  9. package/dist/lib-cjs/api/classes/event.d.ts +342 -326
  10. package/dist/lib-cjs/api/classes/event.js +365 -349
  11. package/dist/lib-cjs/api/classes/event.js.map +1 -1
  12. package/dist/lib-cjs/api/classes/eventBroadcaster.d.ts +26 -26
  13. package/dist/lib-cjs/api/classes/eventBroadcaster.js +49 -49
  14. package/dist/lib-cjs/api/classes/parameter.d.ts +339 -339
  15. package/dist/lib-cjs/api/classes/parameter.js +464 -464
  16. package/dist/lib-cjs/api/classes/parameterObservable.d.ts +36 -36
  17. package/dist/lib-cjs/api/classes/parameterObservable.js +97 -97
  18. package/dist/lib-cjs/api/classes/parameterizable.d.ts +15 -15
  19. package/dist/lib-cjs/api/classes/parameterizable.js +102 -102
  20. package/dist/lib-cjs/api/classes/placementAnimation.d.ts +45 -45
  21. package/dist/lib-cjs/api/classes/placementAnimation.js +176 -176
  22. package/dist/lib-cjs/api/classes/variant.d.ts +234 -234
  23. package/dist/lib-cjs/api/classes/variant.js +836 -836
  24. package/dist/lib-cjs/api/classes/variant.js.map +1 -1
  25. package/dist/lib-cjs/api/classes/variantInstance.d.ts +44 -44
  26. package/dist/lib-cjs/api/classes/variantInstance.js +105 -105
  27. package/dist/lib-cjs/api/classes/variantParameterizable.d.ts +17 -17
  28. package/dist/lib-cjs/api/classes/variantParameterizable.js +88 -88
  29. package/dist/lib-cjs/api/classes/viewer.d.ts +187 -189
  30. package/dist/lib-cjs/api/classes/viewer.js +594 -594
  31. package/dist/lib-cjs/api/classes/viewer.js.map +1 -1
  32. package/dist/lib-cjs/api/classes/viewerLight.d.ts +66 -66
  33. package/dist/lib-cjs/api/classes/viewerLight.js +348 -348
  34. package/dist/lib-cjs/api/internal/lensRendering.d.ts +8 -8
  35. package/dist/lib-cjs/api/internal/lensRendering.js +11 -11
  36. package/dist/lib-cjs/api/internal/sceneSetup.d.ts +13 -13
  37. package/dist/lib-cjs/api/internal/sceneSetup.js +226 -226
  38. package/dist/lib-cjs/api/manager/animationManager.d.ts +30 -30
  39. package/dist/lib-cjs/api/manager/animationManager.js +126 -126
  40. package/dist/lib-cjs/api/manager/gltfExportManager.d.ts +78 -65
  41. package/dist/lib-cjs/api/manager/gltfExportManager.js +241 -197
  42. package/dist/lib-cjs/api/manager/gltfExportManager.js.map +1 -1
  43. package/dist/lib-cjs/api/manager/sceneManager.d.ts +33 -31
  44. package/dist/lib-cjs/api/manager/sceneManager.js +130 -127
  45. package/dist/lib-cjs/api/manager/sceneManager.js.map +1 -1
  46. package/dist/lib-cjs/api/manager/textureLoadManager.d.ts +22 -0
  47. package/dist/lib-cjs/api/manager/textureLoadManager.js +98 -0
  48. package/dist/lib-cjs/api/manager/textureLoadManager.js.map +1 -0
  49. package/dist/lib-cjs/api/manager/variantInstanceManager.d.ts +92 -92
  50. package/dist/lib-cjs/api/manager/variantInstanceManager.js +260 -260
  51. package/dist/lib-cjs/api/store/specStorage.d.ts +24 -24
  52. package/dist/lib-cjs/api/store/specStorage.js +50 -50
  53. package/dist/lib-cjs/api/util/babylonHelper.d.ts +183 -174
  54. package/dist/lib-cjs/api/util/babylonHelper.js +596 -585
  55. package/dist/lib-cjs/api/util/babylonHelper.js.map +1 -1
  56. package/dist/lib-cjs/api/util/globalTypes.d.ts +383 -370
  57. package/dist/lib-cjs/api/util/globalTypes.js +1 -1
  58. package/dist/lib-cjs/api/util/resourceHelper.d.ts +58 -58
  59. package/dist/lib-cjs/api/util/resourceHelper.js +203 -203
  60. package/dist/lib-cjs/api/util/sceneLoaderHelper.d.ts +42 -35
  61. package/dist/lib-cjs/api/util/sceneLoaderHelper.js +139 -139
  62. package/dist/lib-cjs/api/util/sceneLoaderHelper.js.map +1 -1
  63. package/dist/lib-cjs/api/util/stringHelper.d.ts +9 -9
  64. package/dist/lib-cjs/api/util/stringHelper.js +25 -25
  65. package/dist/lib-cjs/api/util/structureHelper.d.ts +9 -9
  66. package/dist/lib-cjs/api/util/structureHelper.js +48 -48
  67. package/dist/lib-cjs/buildinfo.json +3 -3
  68. package/dist/lib-cjs/commonjs.tsconfig.tsbuildinfo +1 -1
  69. package/dist/lib-cjs/index.d.ts +51 -51
  70. package/dist/lib-cjs/index.js +110 -110
  71. package/dist/webpack-stats.json +0 -0
  72. package/package.json +79 -79
  73. package/src/api/classes/animationInterface.ts +10 -10
  74. package/src/api/classes/dottedPath.ts +181 -181
  75. package/src/api/classes/element.ts +717 -717
  76. package/src/api/classes/event.ts +385 -367
  77. package/src/api/classes/eventBroadcaster.ts +52 -52
  78. package/src/api/classes/parameter.ts +497 -497
  79. package/src/api/classes/parameterObservable.ts +100 -100
  80. package/src/api/classes/parameterizable.ts +87 -87
  81. package/src/api/classes/placementAnimation.ts +162 -162
  82. package/src/api/classes/variant.ts +904 -904
  83. package/src/api/classes/variantInstance.ts +97 -97
  84. package/src/api/classes/variantParameterizable.ts +85 -85
  85. package/src/api/classes/viewer.ts +672 -670
  86. package/src/api/classes/viewerLight.ts +339 -339
  87. package/src/api/internal/debugViewer.ts +90 -90
  88. package/src/api/internal/lensRendering.ts +9 -9
  89. package/src/api/internal/sceneSetup.ts +205 -205
  90. package/src/api/manager/animationManager.ts +143 -143
  91. package/src/api/manager/gltfExportManager.ts +236 -192
  92. package/src/api/manager/sceneManager.ts +132 -127
  93. package/src/api/manager/textureLoadManager.ts +95 -0
  94. package/src/api/manager/variantInstanceManager.ts +265 -265
  95. package/src/api/store/specStorage.ts +51 -51
  96. package/src/api/util/babylonHelper.ts +658 -645
  97. package/src/api/util/globalTypes.ts +432 -417
  98. package/src/api/util/resourceHelper.ts +191 -191
  99. package/src/api/util/sceneLoaderHelper.ts +137 -144
  100. package/src/api/util/stringHelper.ts +23 -23
  101. package/src/api/util/structureHelper.ts +49 -49
  102. package/src/buildinfo.json +3 -3
  103. package/src/dev.ts +61 -61
  104. package/src/index.ts +96 -96
  105. package/src/types.d.ts +28 -28
  106. package/dist/lib-es6/api/classes/animationInterface.d.ts +0 -8
  107. package/dist/lib-es6/api/classes/animationInterface.js +0 -2
  108. package/dist/lib-es6/api/classes/animationInterface.js.map +0 -1
  109. package/dist/lib-es6/api/classes/dottedPath.d.ts +0 -79
  110. package/dist/lib-es6/api/classes/dottedPath.js +0 -163
  111. package/dist/lib-es6/api/classes/dottedPath.js.map +0 -1
  112. package/dist/lib-es6/api/classes/element.d.ts +0 -149
  113. package/dist/lib-es6/api/classes/element.js +0 -666
  114. package/dist/lib-es6/api/classes/element.js.map +0 -1
  115. package/dist/lib-es6/api/classes/event.d.ts +0 -326
  116. package/dist/lib-es6/api/classes/event.js +0 -346
  117. package/dist/lib-es6/api/classes/event.js.map +0 -1
  118. package/dist/lib-es6/api/classes/eventBroadcaster.d.ts +0 -26
  119. package/dist/lib-es6/api/classes/eventBroadcaster.js +0 -43
  120. package/dist/lib-es6/api/classes/eventBroadcaster.js.map +0 -1
  121. package/dist/lib-es6/api/classes/parameter.d.ts +0 -339
  122. package/dist/lib-es6/api/classes/parameter.js +0 -461
  123. package/dist/lib-es6/api/classes/parameter.js.map +0 -1
  124. package/dist/lib-es6/api/classes/parameterObservable.d.ts +0 -36
  125. package/dist/lib-es6/api/classes/parameterObservable.js +0 -94
  126. package/dist/lib-es6/api/classes/parameterObservable.js.map +0 -1
  127. package/dist/lib-es6/api/classes/parameterizable.d.ts +0 -15
  128. package/dist/lib-es6/api/classes/parameterizable.js +0 -99
  129. package/dist/lib-es6/api/classes/parameterizable.js.map +0 -1
  130. package/dist/lib-es6/api/classes/placementAnimation.d.ts +0 -45
  131. package/dist/lib-es6/api/classes/placementAnimation.js +0 -173
  132. package/dist/lib-es6/api/classes/placementAnimation.js.map +0 -1
  133. package/dist/lib-es6/api/classes/variant.d.ts +0 -234
  134. package/dist/lib-es6/api/classes/variant.js +0 -833
  135. package/dist/lib-es6/api/classes/variant.js.map +0 -1
  136. package/dist/lib-es6/api/classes/variantInstance.d.ts +0 -44
  137. package/dist/lib-es6/api/classes/variantInstance.js +0 -102
  138. package/dist/lib-es6/api/classes/variantInstance.js.map +0 -1
  139. package/dist/lib-es6/api/classes/variantParameterizable.d.ts +0 -17
  140. package/dist/lib-es6/api/classes/variantParameterizable.js +0 -85
  141. package/dist/lib-es6/api/classes/variantParameterizable.js.map +0 -1
  142. package/dist/lib-es6/api/classes/viewer.d.ts +0 -189
  143. package/dist/lib-es6/api/classes/viewer.js +0 -588
  144. package/dist/lib-es6/api/classes/viewer.js.map +0 -1
  145. package/dist/lib-es6/api/classes/viewerLight.d.ts +0 -66
  146. package/dist/lib-es6/api/classes/viewerLight.js +0 -322
  147. package/dist/lib-es6/api/classes/viewerLight.js.map +0 -1
  148. package/dist/lib-es6/api/internal/lensRendering.d.ts +0 -8
  149. package/dist/lib-es6/api/internal/lensRendering.js +0 -9
  150. package/dist/lib-es6/api/internal/lensRendering.js.map +0 -1
  151. package/dist/lib-es6/api/internal/sceneSetup.d.ts +0 -13
  152. package/dist/lib-es6/api/internal/sceneSetup.js +0 -199
  153. package/dist/lib-es6/api/internal/sceneSetup.js.map +0 -1
  154. package/dist/lib-es6/api/manager/animationManager.d.ts +0 -30
  155. package/dist/lib-es6/api/manager/animationManager.js +0 -123
  156. package/dist/lib-es6/api/manager/animationManager.js.map +0 -1
  157. package/dist/lib-es6/api/manager/gltfExportManager.d.ts +0 -65
  158. package/dist/lib-es6/api/manager/gltfExportManager.js +0 -194
  159. package/dist/lib-es6/api/manager/gltfExportManager.js.map +0 -1
  160. package/dist/lib-es6/api/manager/sceneManager.d.ts +0 -31
  161. package/dist/lib-es6/api/manager/sceneManager.js +0 -124
  162. package/dist/lib-es6/api/manager/sceneManager.js.map +0 -1
  163. package/dist/lib-es6/api/manager/variantInstanceManager.d.ts +0 -92
  164. package/dist/lib-es6/api/manager/variantInstanceManager.js +0 -257
  165. package/dist/lib-es6/api/manager/variantInstanceManager.js.map +0 -1
  166. package/dist/lib-es6/api/store/specStorage.d.ts +0 -24
  167. package/dist/lib-es6/api/store/specStorage.js +0 -47
  168. package/dist/lib-es6/api/store/specStorage.js.map +0 -1
  169. package/dist/lib-es6/api/util/babylonHelper.d.ts +0 -174
  170. package/dist/lib-es6/api/util/babylonHelper.js +0 -556
  171. package/dist/lib-es6/api/util/babylonHelper.js.map +0 -1
  172. package/dist/lib-es6/api/util/globalTypes.d.ts +0 -370
  173. package/dist/lib-es6/api/util/globalTypes.js +0 -2
  174. package/dist/lib-es6/api/util/globalTypes.js.map +0 -1
  175. package/dist/lib-es6/api/util/resourceHelper.d.ts +0 -58
  176. package/dist/lib-es6/api/util/resourceHelper.js +0 -194
  177. package/dist/lib-es6/api/util/resourceHelper.js.map +0 -1
  178. package/dist/lib-es6/api/util/sceneLoaderHelper.d.ts +0 -35
  179. package/dist/lib-es6/api/util/sceneLoaderHelper.js +0 -130
  180. package/dist/lib-es6/api/util/sceneLoaderHelper.js.map +0 -1
  181. package/dist/lib-es6/api/util/stringHelper.d.ts +0 -9
  182. package/dist/lib-es6/api/util/stringHelper.js +0 -22
  183. package/dist/lib-es6/api/util/stringHelper.js.map +0 -1
  184. package/dist/lib-es6/api/util/structureHelper.d.ts +0 -9
  185. package/dist/lib-es6/api/util/structureHelper.js +0 -46
  186. package/dist/lib-es6/api/util/structureHelper.js.map +0 -1
  187. package/dist/lib-es6/buildinfo.json +0 -3
  188. package/dist/lib-es6/es6.tsconfig.tsbuildinfo +0 -1
  189. package/dist/lib-es6/index.d.ts +0 -51
  190. package/dist/lib-es6/index.js +0 -49
  191. package/dist/lib-es6/index.js.map +0 -1
@@ -1,181 +1,181 @@
1
- export class DottedPath {
2
- static DELIMITER: string = '.';
3
-
4
- static SAFE_CHAR: string = '·';
5
-
6
- public parts: string[] = [];
7
-
8
- /**
9
- * Magic factory function that creates a DottedPath based on the argument type.
10
- */
11
- public static create(dottedPath?: DottedPathArgument): DottedPath {
12
- if (dottedPath?.constructor === DottedPath) {
13
- return (dottedPath as DottedPath).clone();
14
- }
15
- if (dottedPath?.constructor === String) {
16
- return DottedPath.createFromPath(dottedPath as string);
17
- }
18
- if (dottedPath?.constructor === Array) {
19
- return DottedPath.createFromParts(dottedPath as string[]);
20
- }
21
- return DottedPath.createEmpty();
22
- }
23
-
24
- /**
25
- * Creates a DottedPath from a string.
26
- * Allows patterns with unsafe characters wrapped in apostrophes or quotes.
27
- * E.g. "part1.part2.'part.3'.part_4"
28
- */
29
- public static createFromPath(path: string): DottedPath {
30
- if (path.length === 0) {
31
- return this.createEmpty();
32
- }
33
- if (path.indexOf("'") > -1 || path.indexOf('"') > -1) {
34
- const bd = '[\'|"]';
35
- const search = new RegExp(`${bd}(.*)${bd}`, 'g');
36
- let matches = search.exec(path);
37
- while (matches !== null) {
38
- const _search = new RegExp(`${bd}${matches[1]}${bd}`, 'g');
39
- path = path.replace(_search, this.sanitizePart(matches[1]));
40
- matches = search.exec(path);
41
- }
42
- }
43
- return this.createFromParts(path.split(DottedPath.DELIMITER));
44
- }
45
-
46
- /**
47
- * Creates a DottedPath from a string list.
48
- */
49
- public static createFromParts(parts: string[]): DottedPath {
50
- const dottedPath = new DottedPath();
51
- parts.forEach(part => dottedPath.addPart(part));
52
- return dottedPath;
53
- }
54
-
55
- /**
56
- * Creates an empty DottedPath.
57
- */
58
- public static createEmpty(): DottedPath {
59
- return new DottedPath();
60
- }
61
-
62
- /**
63
- * Sanitizes given part: replaces all characters like {@link DottedPath.DELIMITER}
64
- * with a "safe" character like {@link DottedPath.SAFE_CHAR}.
65
- * (i) Does not trim whitespace.
66
- */
67
- public static sanitizePart(part: string): string {
68
- return part.split(DottedPath.DELIMITER).join(DottedPath.SAFE_CHAR);
69
- }
70
-
71
- /**
72
- * Constructor
73
- */
74
- private constructor() {}
75
-
76
- /**
77
- * The path.
78
- * (i) Does not return an empty dot for no path.
79
- */
80
- get path(): string {
81
- return this.parts.length > 0 ? this.parts.join(DottedPath.DELIMITER) : '';
82
- }
83
-
84
- /**
85
- * The first part.
86
- */
87
- get firstPart(): string | null {
88
- if (this.parts.length > 0) {
89
- return this.parts[0];
90
- }
91
- return null;
92
- }
93
-
94
- /**
95
- * The last part.
96
- */
97
- get lastPart(): string | null {
98
- if (this.parts.length > 0) {
99
- return this.parts[this.parts.length - 1];
100
- }
101
- return null;
102
- }
103
-
104
- /**
105
- * Gets the tokens to each leaf of the DottedPath tree.
106
- * E.g. "part1.part2.part_3" will return an array like
107
- * ["part1", "part1.part2", "part1.part2.part_3"]
108
- */
109
- get leafTokens(): string[] {
110
- const parents: string[] = [];
111
- return this.parts.map(part => {
112
- parents.push(part);
113
- return DottedPath.create(parents).path;
114
- });
115
- }
116
-
117
- /**
118
- * Removes the first part and returns it.
119
- */
120
- public shiftPart(): string | undefined {
121
- return this.parts.shift();
122
- }
123
-
124
- /**
125
- * Adds part to the beginning of parts list.
126
- */
127
- public unshiftPart(part: string, duplicateCheck: boolean = false): DottedPath {
128
- part = DottedPath.sanitizePart(part);
129
- if (duplicateCheck && this.firstPart === part) {
130
- return this;
131
- }
132
- this.parts.unshift(part);
133
- return this;
134
- }
135
-
136
- /**
137
- * Adds part to the end of parts list.
138
- * (i) Does not add a part if the last char already is the delimiter or if an empty string was passed.
139
- */
140
- public addPart(part: string, duplicateCheck: boolean = false): DottedPath {
141
- if (part.length < 1 || this.lastPart === DottedPath.DELIMITER) {
142
- return this;
143
- }
144
- part = DottedPath.sanitizePart(part);
145
- if (duplicateCheck && this.lastPart === part) {
146
- return this;
147
- }
148
- this.parts.push(part);
149
- return this;
150
- }
151
-
152
- /**
153
- * Adds multiple parts to the end of parts list.
154
- */
155
- public addParts(parts: string[], duplicateCheck: boolean = false): DottedPath {
156
- parts.forEach(part => this.addPart(part, duplicateCheck));
157
- return this;
158
- }
159
-
160
- /**
161
- * Removes the last part and returns it.
162
- */
163
- public popPart(): string | undefined {
164
- return this.parts.pop();
165
- }
166
-
167
- public toString(): string {
168
- return this.path;
169
- }
170
-
171
- public valueOf(): string {
172
- return this.path;
173
- }
174
-
175
- /**
176
- * Clones the DottedPath.
177
- */
178
- public clone(): DottedPath {
179
- return DottedPath.createFromParts(this.parts);
180
- }
181
- }
1
+ export class DottedPath {
2
+ static DELIMITER: string = '.';
3
+
4
+ static SAFE_CHAR: string = '·';
5
+
6
+ public parts: string[] = [];
7
+
8
+ /**
9
+ * Magic factory function that creates a DottedPath based on the argument type.
10
+ */
11
+ public static create(dottedPath?: DottedPathArgument): DottedPath {
12
+ if (dottedPath?.constructor === DottedPath) {
13
+ return (dottedPath as DottedPath).clone();
14
+ }
15
+ if (dottedPath?.constructor === String) {
16
+ return DottedPath.createFromPath(dottedPath as string);
17
+ }
18
+ if (dottedPath?.constructor === Array) {
19
+ return DottedPath.createFromParts(dottedPath as string[]);
20
+ }
21
+ return DottedPath.createEmpty();
22
+ }
23
+
24
+ /**
25
+ * Creates a DottedPath from a string.
26
+ * Allows patterns with unsafe characters wrapped in apostrophes or quotes.
27
+ * E.g. "part1.part2.'part.3'.part_4"
28
+ */
29
+ public static createFromPath(path: string): DottedPath {
30
+ if (path.length === 0) {
31
+ return this.createEmpty();
32
+ }
33
+ if (path.indexOf("'") > -1 || path.indexOf('"') > -1) {
34
+ const bd = '[\'|"]';
35
+ const search = new RegExp(`${bd}(.*)${bd}`, 'g');
36
+ let matches = search.exec(path);
37
+ while (matches !== null) {
38
+ const _search = new RegExp(`${bd}${matches[1]}${bd}`, 'g');
39
+ path = path.replace(_search, this.sanitizePart(matches[1]));
40
+ matches = search.exec(path);
41
+ }
42
+ }
43
+ return this.createFromParts(path.split(DottedPath.DELIMITER));
44
+ }
45
+
46
+ /**
47
+ * Creates a DottedPath from a string list.
48
+ */
49
+ public static createFromParts(parts: string[]): DottedPath {
50
+ const dottedPath = new DottedPath();
51
+ parts.forEach(part => dottedPath.addPart(part));
52
+ return dottedPath;
53
+ }
54
+
55
+ /**
56
+ * Creates an empty DottedPath.
57
+ */
58
+ public static createEmpty(): DottedPath {
59
+ return new DottedPath();
60
+ }
61
+
62
+ /**
63
+ * Sanitizes given part: replaces all characters like {@link DottedPath.DELIMITER}
64
+ * with a "safe" character like {@link DottedPath.SAFE_CHAR}.
65
+ * (i) Does not trim whitespace.
66
+ */
67
+ public static sanitizePart(part: string): string {
68
+ return part.split(DottedPath.DELIMITER).join(DottedPath.SAFE_CHAR);
69
+ }
70
+
71
+ /**
72
+ * Constructor
73
+ */
74
+ private constructor() {}
75
+
76
+ /**
77
+ * The path.
78
+ * (i) Does not return an empty dot for no path.
79
+ */
80
+ get path(): string {
81
+ return this.parts.length > 0 ? this.parts.join(DottedPath.DELIMITER) : '';
82
+ }
83
+
84
+ /**
85
+ * The first part.
86
+ */
87
+ get firstPart(): string | null {
88
+ if (this.parts.length > 0) {
89
+ return this.parts[0];
90
+ }
91
+ return null;
92
+ }
93
+
94
+ /**
95
+ * The last part.
96
+ */
97
+ get lastPart(): string | null {
98
+ if (this.parts.length > 0) {
99
+ return this.parts[this.parts.length - 1];
100
+ }
101
+ return null;
102
+ }
103
+
104
+ /**
105
+ * Gets the tokens to each leaf of the DottedPath tree.
106
+ * E.g. "part1.part2.part_3" will return an array like
107
+ * ["part1", "part1.part2", "part1.part2.part_3"]
108
+ */
109
+ get leafTokens(): string[] {
110
+ const parents: string[] = [];
111
+ return this.parts.map(part => {
112
+ parents.push(part);
113
+ return DottedPath.create(parents).path;
114
+ });
115
+ }
116
+
117
+ /**
118
+ * Removes the first part and returns it.
119
+ */
120
+ public shiftPart(): string | undefined {
121
+ return this.parts.shift();
122
+ }
123
+
124
+ /**
125
+ * Adds part to the beginning of parts list.
126
+ */
127
+ public unshiftPart(part: string, duplicateCheck: boolean = false): DottedPath {
128
+ part = DottedPath.sanitizePart(part);
129
+ if (duplicateCheck && this.firstPart === part) {
130
+ return this;
131
+ }
132
+ this.parts.unshift(part);
133
+ return this;
134
+ }
135
+
136
+ /**
137
+ * Adds part to the end of parts list.
138
+ * (i) Does not add a part if the last char already is the delimiter or if an empty string was passed.
139
+ */
140
+ public addPart(part: string, duplicateCheck: boolean = false): DottedPath {
141
+ if (part.length < 1 || this.lastPart === DottedPath.DELIMITER) {
142
+ return this;
143
+ }
144
+ part = DottedPath.sanitizePart(part);
145
+ if (duplicateCheck && this.lastPart === part) {
146
+ return this;
147
+ }
148
+ this.parts.push(part);
149
+ return this;
150
+ }
151
+
152
+ /**
153
+ * Adds multiple parts to the end of parts list.
154
+ */
155
+ public addParts(parts: string[], duplicateCheck: boolean = false): DottedPath {
156
+ parts.forEach(part => this.addPart(part, duplicateCheck));
157
+ return this;
158
+ }
159
+
160
+ /**
161
+ * Removes the last part and returns it.
162
+ */
163
+ public popPart(): string | undefined {
164
+ return this.parts.pop();
165
+ }
166
+
167
+ public toString(): string {
168
+ return this.path;
169
+ }
170
+
171
+ public valueOf(): string {
172
+ return this.path;
173
+ }
174
+
175
+ /**
176
+ * Clones the DottedPath.
177
+ */
178
+ public clone(): DottedPath {
179
+ return DottedPath.createFromParts(this.parts);
180
+ }
181
+ }