From 240202662447040c0255f39e6c296207ba9a5457 Mon Sep 17 00:00:00 2001 From: Jason Johnston Date: Thu, 31 Oct 2024 20:51:39 -0600 Subject: [PATCH] fix: Error in derived materials in Three r170 They changed Material.type to a getter that queries the object's constructor --- packages/troika-three-utils/src/DerivedMaterial.js | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/packages/troika-three-utils/src/DerivedMaterial.js b/packages/troika-three-utils/src/DerivedMaterial.js index 0d18c357..0cc3f17a 100644 --- a/packages/troika-three-utils/src/DerivedMaterial.js +++ b/packages/troika-three-utils/src/DerivedMaterial.js @@ -66,7 +66,7 @@ let materialInstanceId = 1e10 * output value. Will be injected near the end of the `void main` function, but before any * of ThreeJS's color postprocessing shader chunks (tonemapping, fog, etc.), and before the * `fragmentMainOutro`. - * @param {function({fragmentShader: string, vertexShader:string}): + * @param {function({fragmentShader: string, vertexShader:string}): * {fragmentShader: string, vertexShader:string}} options.customRewriter - A function * for performing custom rewrites of the full shader code. Useful if you need to do something * special that's not covered by the other builtin options. This function will be executed before @@ -170,6 +170,11 @@ export function createDerivedMaterial(baseMaterial, options) { constructor: {value: DerivedMaterial}, isDerivedMaterial: {value: true}, + type: { + get: () => baseMaterial.type, + set: (value) => {baseMaterial.type = value} + }, + isDerivedFrom: { writable: true, configurable: true,