@kaspernj/api-maker 1.0.2037 → 1.0.2039

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.
@@ -1,16 +1,22 @@
1
- import { useCallback, useLayoutEffect } from "react";
1
+ import { useCallback, useEffect, useLayoutEffect } from "react";
2
+ import useSSR from "use-ssr";
2
3
  const ApiMakerUseEventListener = (target, event, onCalled) => {
4
+ const {
5
+ isServer
6
+ } = useSSR();
7
+ const useWorkingEffect = isServer ? useEffect : useLayoutEffect;
3
8
  const onCalledCallback = useCallback((...args) => {
4
9
  onCalled.apply(null, args);
5
10
  }, [target, event, onCalled]);
6
- useLayoutEffect(() => {
11
+ useWorkingEffect(() => {
7
12
  if (target) {
8
- target.addEventListener(event, onCalledCallback);
13
+ const eventListener = target.addEventListener(event, onCalledCallback);
9
14
  return () => {
10
- target.removeEventListener(event, onCalledCallback);
15
+ if (eventListener) eventListener.remove(); // This is how its done in Expo + Jest.
16
+ if (target.removeEventListener) target.removeEventListener(event, onCalledCallback); // This is the "old" way in browsers.
11
17
  };
12
18
  }
13
19
  }, [target, event, onCalled]);
14
20
  };
15
21
  export default ApiMakerUseEventListener;
16
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ1c2VDYWxsYmFjayIsInVzZUxheW91dEVmZmVjdCIsIkFwaU1ha2VyVXNlRXZlbnRMaXN0ZW5lciIsInRhcmdldCIsImV2ZW50Iiwib25DYWxsZWQiLCJvbkNhbGxlZENhbGxiYWNrIiwiYXJncyIsImFwcGx5IiwiYWRkRXZlbnRMaXN0ZW5lciIsInJlbW92ZUV2ZW50TGlzdGVuZXIiXSwic291cmNlcyI6WyIuLi9zcmMvdXNlLWV2ZW50LWxpc3RlbmVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7dXNlQ2FsbGJhY2ssIHVzZUxheW91dEVmZmVjdH0gZnJvbSBcInJlYWN0XCJcblxuY29uc3QgQXBpTWFrZXJVc2VFdmVudExpc3RlbmVyID0gKHRhcmdldCwgZXZlbnQsIG9uQ2FsbGVkKSA9PiB7XG4gIGNvbnN0IG9uQ2FsbGVkQ2FsbGJhY2sgPSB1c2VDYWxsYmFjaygoLi4uYXJncykgPT4ge1xuICAgIG9uQ2FsbGVkLmFwcGx5KG51bGwsIGFyZ3MpXG4gIH0sIFt0YXJnZXQsIGV2ZW50LCBvbkNhbGxlZF0pXG5cbiAgdXNlTGF5b3V0RWZmZWN0KCgpID0+IHtcbiAgICBpZiAodGFyZ2V0KSB7XG4gICAgICB0YXJnZXQuYWRkRXZlbnRMaXN0ZW5lcihldmVudCwgb25DYWxsZWRDYWxsYmFjaylcblxuICAgICAgcmV0dXJuICgpID0+IHtcbiAgICAgICAgdGFyZ2V0LnJlbW92ZUV2ZW50TGlzdGVuZXIoZXZlbnQsIG9uQ2FsbGVkQ2FsbGJhY2spXG4gICAgICB9XG4gICAgfVxuICB9LCBbdGFyZ2V0LCBldmVudCwgb25DYWxsZWRdKVxufVxuXG5leHBvcnQgZGVmYXVsdCBBcGlNYWtlclVzZUV2ZW50TGlzdGVuZXJcbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBUUEsV0FBVyxFQUFFQyxlQUFlLFFBQU8sT0FBTztBQUVsRCxNQUFNQyx3QkFBd0IsR0FBR0EsQ0FBQ0MsTUFBTSxFQUFFQyxLQUFLLEVBQUVDLFFBQVEsS0FBSztFQUM1RCxNQUFNQyxnQkFBZ0IsR0FBR04sV0FBVyxDQUFDLENBQUMsR0FBR08sSUFBSSxLQUFLO0lBQ2hERixRQUFRLENBQUNHLEtBQUssQ0FBQyxJQUFJLEVBQUVELElBQUksQ0FBQztFQUM1QixDQUFDLEVBQUUsQ0FBQ0osTUFBTSxFQUFFQyxLQUFLLEVBQUVDLFFBQVEsQ0FBQyxDQUFDO0VBRTdCSixlQUFlLENBQUMsTUFBTTtJQUNwQixJQUFJRSxNQUFNLEVBQUU7TUFDVkEsTUFBTSxDQUFDTSxnQkFBZ0IsQ0FBQ0wsS0FBSyxFQUFFRSxnQkFBZ0IsQ0FBQztNQUVoRCxPQUFPLE1BQU07UUFDWEgsTUFBTSxDQUFDTyxtQkFBbUIsQ0FBQ04sS0FBSyxFQUFFRSxnQkFBZ0IsQ0FBQztNQUNyRCxDQUFDO0lBQ0g7RUFDRixDQUFDLEVBQUUsQ0FBQ0gsTUFBTSxFQUFFQyxLQUFLLEVBQUVDLFFBQVEsQ0FBQyxDQUFDO0FBQy9CLENBQUM7QUFFRCxlQUFlSCx3QkFBd0IiLCJpZ25vcmVMaXN0IjpbXX0=
22
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ1c2VDYWxsYmFjayIsInVzZUVmZmVjdCIsInVzZUxheW91dEVmZmVjdCIsInVzZVNTUiIsIkFwaU1ha2VyVXNlRXZlbnRMaXN0ZW5lciIsInRhcmdldCIsImV2ZW50Iiwib25DYWxsZWQiLCJpc1NlcnZlciIsInVzZVdvcmtpbmdFZmZlY3QiLCJvbkNhbGxlZENhbGxiYWNrIiwiYXJncyIsImFwcGx5IiwiZXZlbnRMaXN0ZW5lciIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZW1vdmUiLCJyZW1vdmVFdmVudExpc3RlbmVyIl0sInNvdXJjZXMiOlsiLi4vc3JjL3VzZS1ldmVudC1saXN0ZW5lci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge3VzZUNhbGxiYWNrLCB1c2VFZmZlY3QsIHVzZUxheW91dEVmZmVjdH0gZnJvbSBcInJlYWN0XCJcbmltcG9ydCB1c2VTU1IgZnJvbSBcInVzZS1zc3JcIlxuXG5jb25zdCBBcGlNYWtlclVzZUV2ZW50TGlzdGVuZXIgPSAodGFyZ2V0LCBldmVudCwgb25DYWxsZWQpID0+IHtcbiAgY29uc3Qge2lzU2VydmVyfSA9IHVzZVNTUigpXG4gIGNvbnN0IHVzZVdvcmtpbmdFZmZlY3QgPSBpc1NlcnZlciA/IHVzZUVmZmVjdCA6IHVzZUxheW91dEVmZmVjdFxuXG4gIGNvbnN0IG9uQ2FsbGVkQ2FsbGJhY2sgPSB1c2VDYWxsYmFjaygoLi4uYXJncykgPT4ge1xuICAgIG9uQ2FsbGVkLmFwcGx5KG51bGwsIGFyZ3MpXG4gIH0sIFt0YXJnZXQsIGV2ZW50LCBvbkNhbGxlZF0pXG5cbiAgdXNlV29ya2luZ0VmZmVjdCgoKSA9PiB7XG4gICAgaWYgKHRhcmdldCkge1xuICAgICAgY29uc3QgZXZlbnRMaXN0ZW5lciA9IHRhcmdldC5hZGRFdmVudExpc3RlbmVyKGV2ZW50LCBvbkNhbGxlZENhbGxiYWNrKVxuXG4gICAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgICBpZiAoZXZlbnRMaXN0ZW5lcikgZXZlbnRMaXN0ZW5lci5yZW1vdmUoKSAvLyBUaGlzIGlzIGhvdyBpdHMgZG9uZSBpbiBFeHBvICsgSmVzdC5cbiAgICAgICAgaWYgKHRhcmdldC5yZW1vdmVFdmVudExpc3RlbmVyKSB0YXJnZXQucmVtb3ZlRXZlbnRMaXN0ZW5lcihldmVudCwgb25DYWxsZWRDYWxsYmFjaykgLy8gVGhpcyBpcyB0aGUgXCJvbGRcIiB3YXkgaW4gYnJvd3NlcnMuXG4gICAgICB9XG4gICAgfVxuICB9LCBbdGFyZ2V0LCBldmVudCwgb25DYWxsZWRdKVxufVxuXG5leHBvcnQgZGVmYXVsdCBBcGlNYWtlclVzZUV2ZW50TGlzdGVuZXJcbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBUUEsV0FBVyxFQUFFQyxTQUFTLEVBQUVDLGVBQWUsUUFBTyxPQUFPO0FBQzdELE9BQU9DLE1BQU0sTUFBTSxTQUFTO0FBRTVCLE1BQU1DLHdCQUF3QixHQUFHQSxDQUFDQyxNQUFNLEVBQUVDLEtBQUssRUFBRUMsUUFBUSxLQUFLO0VBQzVELE1BQU07SUFBQ0M7RUFBUSxDQUFDLEdBQUdMLE1BQU0sQ0FBQyxDQUFDO0VBQzNCLE1BQU1NLGdCQUFnQixHQUFHRCxRQUFRLEdBQUdQLFNBQVMsR0FBR0MsZUFBZTtFQUUvRCxNQUFNUSxnQkFBZ0IsR0FBR1YsV0FBVyxDQUFDLENBQUMsR0FBR1csSUFBSSxLQUFLO0lBQ2hESixRQUFRLENBQUNLLEtBQUssQ0FBQyxJQUFJLEVBQUVELElBQUksQ0FBQztFQUM1QixDQUFDLEVBQUUsQ0FBQ04sTUFBTSxFQUFFQyxLQUFLLEVBQUVDLFFBQVEsQ0FBQyxDQUFDO0VBRTdCRSxnQkFBZ0IsQ0FBQyxNQUFNO0lBQ3JCLElBQUlKLE1BQU0sRUFBRTtNQUNWLE1BQU1RLGFBQWEsR0FBR1IsTUFBTSxDQUFDUyxnQkFBZ0IsQ0FBQ1IsS0FBSyxFQUFFSSxnQkFBZ0IsQ0FBQztNQUV0RSxPQUFPLE1BQU07UUFDWCxJQUFJRyxhQUFhLEVBQUVBLGFBQWEsQ0FBQ0UsTUFBTSxDQUFDLENBQUMsRUFBQztRQUMxQyxJQUFJVixNQUFNLENBQUNXLG1CQUFtQixFQUFFWCxNQUFNLENBQUNXLG1CQUFtQixDQUFDVixLQUFLLEVBQUVJLGdCQUFnQixDQUFDLEVBQUM7TUFDdEYsQ0FBQztJQUNIO0VBQ0YsQ0FBQyxFQUFFLENBQUNMLE1BQU0sRUFBRUMsS0FBSyxFQUFFQyxRQUFRLENBQUMsQ0FBQztBQUMvQixDQUFDO0FBRUQsZUFBZUgsd0JBQXdCIiwiaWdub3JlTGlzdCI6W119
@@ -41,6 +41,8 @@ export default memo(shapeComponent(class ApiMakerUtilsIcon extends BaseComponent
41
41
  actualVersion = "FontAwesome";
42
42
  } else if (name in MaterialIconsGlyphMap) {
43
43
  actualVersion = "MaterialIcons";
44
+ } else {
45
+ actualVersion = "FontAwesome";
44
46
  }
45
47
  }
46
48
 
@@ -95,4 +97,4 @@ export default memo(shapeComponent(class ApiMakerUtilsIcon extends BaseComponent
95
97
  }
96
98
  }
97
99
  }));
98
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["BaseComponent","FontAwesomeIcon","FontAwesome5Icon","FontAwesome6Icon","MaterialIconsIcon","memo","React","useMemo","shapeComponent","useMergedStyle","FontAwesomeGlyphMap","getRawGlyphMap","FontAwesome5GlyphMap","FontAwesome6GlyphMap","MaterialIconsGlyphMap","iconMap","pencil","remove","search","ApiMakerUtilsIcon","render","dataSet","name","style","version","restProps","props","stylesList","actualVersion","actualStylesList","newStyle","count","key","push","actualDataSet","Object","assign","createElement","_extends","Error"],"sources":["../../src/utils/icon.jsx"],"sourcesContent":["import BaseComponent from \"../base-component\"\nimport FontAwesomeIcon from \"react-native-vector-icons/FontAwesome\"\nimport FontAwesome5Icon from \"react-native-vector-icons/FontAwesome5\"\nimport FontAwesome6Icon from \"react-native-vector-icons/FontAwesome6\"\nimport MaterialIconsIcon from \"react-native-vector-icons/MaterialIcons\"\nimport memo from \"set-state-compare/src/memo\"\nimport React, {useMemo} from \"react\"\nimport {shapeComponent} from \"set-state-compare/src/shape-component\"\nimport {useMergedStyle} from \"./default-style\"\n\nconst FontAwesomeGlyphMap = FontAwesomeIcon.getRawGlyphMap()\nconst FontAwesome5GlyphMap = FontAwesome5Icon.getRawGlyphMap()\nconst FontAwesome6GlyphMap = FontAwesome6Icon.getRawGlyphMap()\nconst MaterialIconsGlyphMap = MaterialIconsIcon.getRawGlyphMap()\n\nconst iconMap = {\n  pencil: \"FontAwesome\",\n  remove: \"FontAwesome\",\n  search: \"FontAwesome\"\n}\n\nexport default memo(shapeComponent(class ApiMakerUtilsIcon extends BaseComponent {\n  render() {\n    const {dataSet, name, style, version, ...restProps} = this.props\n    const {stylesList} = useMergedStyle(style, \"Text\")\n    let actualVersion = version\n\n    if (!actualVersion) {\n      if (name in iconMap) {\n        actualVersion = iconMap[name]\n      } else if (name in FontAwesome6GlyphMap) {\n        actualVersion = \"FontAwesome6\"\n      } else if (name in FontAwesome5GlyphMap) {\n        actualVersion = \"FontAwesome5\"\n      } else if (name in FontAwesomeGlyphMap) {\n        actualVersion = \"FontAwesome\"\n      } else if (name in MaterialIconsGlyphMap) {\n        actualVersion =  \"MaterialIcons\"\n      }\n    }\n\n    // Only forward some styles like color\n    const actualStylesList = useMemo(() => {\n      const actualStylesList = []\n\n      for (const style of stylesList) {\n        const newStyle = {}\n        let count = 0\n\n        for (const key in style) {\n          if (key == \"color\") {\n            newStyle[key] = style[key]\n            count++\n          }\n        }\n\n        if (count > 0) {\n          actualStylesList.push(newStyle)\n        }\n      }\n\n      return actualStylesList\n    }, [stylesList, style])\n\n    const actualDataSet = useMemo(() => Object.assign({name, version: actualVersion}, dataSet), [actualVersion, dataSet, name])\n\n    if (actualVersion == \"FontAwesome\") {\n      return <FontAwesomeIcon dataSet={actualDataSet} name={name} style={actualStylesList} {...restProps} />\n    } else if (actualVersion == \"FontAwesome5\") {\n      return <FontAwesome5Icon dataSet={actualDataSet} name={name} style={actualStylesList} {...restProps} />\n    } else if (actualVersion == \"FontAwesome6\") {\n      return <FontAwesome6Icon dataSet={actualDataSet} name={name} style={actualStylesList} {...restProps} />\n    } else if (actualVersion == \"MaterialIcons\") {\n      return <MaterialIconsIcon dataSet={actualDataSet} name={name} style={actualStylesList} {...restProps} />\n    } else {\n      throw new Error(`Unknown version: ${actualVersion}`)\n    }\n  }\n}))\n"],"mappings":";AAAA,OAAOA,aAAa,MAAM,mBAAmB;AAC7C,OAAOC,eAAe,MAAM,uCAAuC;AACnE,OAAOC,gBAAgB,MAAM,wCAAwC;AACrE,OAAOC,gBAAgB,MAAM,wCAAwC;AACrE,OAAOC,iBAAiB,MAAM,yCAAyC;AACvE,OAAOC,IAAI,MAAM,4BAA4B;AAC7C,OAAOC,KAAK,IAAGC,OAAO,QAAO,OAAO;AACpC,SAAQC,cAAc,QAAO,uCAAuC;AACpE,SAAQC,cAAc,QAAO,iBAAiB;AAE9C,MAAMC,mBAAmB,GAAGT,eAAe,CAACU,cAAc,CAAC,CAAC;AAC5D,MAAMC,oBAAoB,GAAGV,gBAAgB,CAACS,cAAc,CAAC,CAAC;AAC9D,MAAME,oBAAoB,GAAGV,gBAAgB,CAACQ,cAAc,CAAC,CAAC;AAC9D,MAAMG,qBAAqB,GAAGV,iBAAiB,CAACO,cAAc,CAAC,CAAC;AAEhE,MAAMI,OAAO,GAAG;EACdC,MAAM,EAAE,aAAa;EACrBC,MAAM,EAAE,aAAa;EACrBC,MAAM,EAAE;AACV,CAAC;AAED,eAAeb,IAAI,CAACG,cAAc,CAAC,MAAMW,iBAAiB,SAASnB,aAAa,CAAC;EAC/EoB,MAAMA,CAAA,EAAG;IACP,MAAM;MAACC,OAAO;MAAEC,IAAI;MAAEC,KAAK;MAAEC,OAAO;MAAE,GAAGC;IAAS,CAAC,GAAG,IAAI,CAACC,KAAK;IAChE,MAAM;MAACC;IAAU,CAAC,GAAGlB,cAAc,CAACc,KAAK,EAAE,MAAM,CAAC;IAClD,IAAIK,aAAa,GAAGJ,OAAO;IAE3B,IAAI,CAACI,aAAa,EAAE;MAClB,IAAIN,IAAI,IAAIP,OAAO,EAAE;QACnBa,aAAa,GAAGb,OAAO,CAACO,IAAI,CAAC;MAC/B,CAAC,MAAM,IAAIA,IAAI,IAAIT,oBAAoB,EAAE;QACvCe,aAAa,GAAG,cAAc;MAChC,CAAC,MAAM,IAAIN,IAAI,IAAIV,oBAAoB,EAAE;QACvCgB,aAAa,GAAG,cAAc;MAChC,CAAC,MAAM,IAAIN,IAAI,IAAIZ,mBAAmB,EAAE;QACtCkB,aAAa,GAAG,aAAa;MAC/B,CAAC,MAAM,IAAIN,IAAI,IAAIR,qBAAqB,EAAE;QACxCc,aAAa,GAAI,eAAe;MAClC;IACF;;IAEA;IACA,MAAMC,gBAAgB,GAAGtB,OAAO,CAAC,MAAM;MACrC,MAAMsB,gBAAgB,GAAG,EAAE;MAE3B,KAAK,MAAMN,KAAK,IAAII,UAAU,EAAE;QAC9B,MAAMG,QAAQ,GAAG,CAAC,CAAC;QACnB,IAAIC,KAAK,GAAG,CAAC;QAEb,KAAK,MAAMC,GAAG,IAAIT,KAAK,EAAE;UACvB,IAAIS,GAAG,IAAI,OAAO,EAAE;YAClBF,QAAQ,CAACE,GAAG,CAAC,GAAGT,KAAK,CAACS,GAAG,CAAC;YAC1BD,KAAK,EAAE;UACT;QACF;QAEA,IAAIA,KAAK,GAAG,CAAC,EAAE;UACbF,gBAAgB,CAACI,IAAI,CAACH,QAAQ,CAAC;QACjC;MACF;MAEA,OAAOD,gBAAgB;IACzB,CAAC,EAAE,CAACF,UAAU,EAAEJ,KAAK,CAAC,CAAC;IAEvB,MAAMW,aAAa,GAAG3B,OAAO,CAAC,MAAM4B,MAAM,CAACC,MAAM,CAAC;MAACd,IAAI;MAAEE,OAAO,EAAEI;IAAa,CAAC,EAAEP,OAAO,CAAC,EAAE,CAACO,aAAa,EAAEP,OAAO,EAAEC,IAAI,CAAC,CAAC;IAE3H,IAAIM,aAAa,IAAI,aAAa,EAAE;MAClC,oBAAOtB,KAAA,CAAA+B,aAAA,CAACpC,eAAe,EAAAqC,QAAA;QAACjB,OAAO,EAAEa,aAAc;QAACZ,IAAI,EAAEA,IAAK;QAACC,KAAK,EAAEM;MAAiB,GAAKJ,SAAS,CAAG,CAAC;IACxG,CAAC,MAAM,IAAIG,aAAa,IAAI,cAAc,EAAE;MAC1C,oBAAOtB,KAAA,CAAA+B,aAAA,CAACnC,gBAAgB,EAAAoC,QAAA;QAACjB,OAAO,EAAEa,aAAc;QAACZ,IAAI,EAAEA,IAAK;QAACC,KAAK,EAAEM;MAAiB,GAAKJ,SAAS,CAAG,CAAC;IACzG,CAAC,MAAM,IAAIG,aAAa,IAAI,cAAc,EAAE;MAC1C,oBAAOtB,KAAA,CAAA+B,aAAA,CAAClC,gBAAgB,EAAAmC,QAAA;QAACjB,OAAO,EAAEa,aAAc;QAACZ,IAAI,EAAEA,IAAK;QAACC,KAAK,EAAEM;MAAiB,GAAKJ,SAAS,CAAG,CAAC;IACzG,CAAC,MAAM,IAAIG,aAAa,IAAI,eAAe,EAAE;MAC3C,oBAAOtB,KAAA,CAAA+B,aAAA,CAACjC,iBAAiB,EAAAkC,QAAA;QAACjB,OAAO,EAAEa,aAAc;QAACZ,IAAI,EAAEA,IAAK;QAACC,KAAK,EAAEM;MAAiB,GAAKJ,SAAS,CAAG,CAAC;IAC1G,CAAC,MAAM;MACL,MAAM,IAAIc,KAAK,CAAC,oBAAoBX,aAAa,EAAE,CAAC;IACtD;EACF;AACF,CAAC,CAAC,CAAC","ignoreList":[]}
100
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["BaseComponent","FontAwesomeIcon","FontAwesome5Icon","FontAwesome6Icon","MaterialIconsIcon","memo","React","useMemo","shapeComponent","useMergedStyle","FontAwesomeGlyphMap","getRawGlyphMap","FontAwesome5GlyphMap","FontAwesome6GlyphMap","MaterialIconsGlyphMap","iconMap","pencil","remove","search","ApiMakerUtilsIcon","render","dataSet","name","style","version","restProps","props","stylesList","actualVersion","actualStylesList","newStyle","count","key","push","actualDataSet","Object","assign","createElement","_extends","Error"],"sources":["../../src/utils/icon.jsx"],"sourcesContent":["import BaseComponent from \"../base-component\"\nimport FontAwesomeIcon from \"react-native-vector-icons/FontAwesome\"\nimport FontAwesome5Icon from \"react-native-vector-icons/FontAwesome5\"\nimport FontAwesome6Icon from \"react-native-vector-icons/FontAwesome6\"\nimport MaterialIconsIcon from \"react-native-vector-icons/MaterialIcons\"\nimport memo from \"set-state-compare/src/memo\"\nimport React, {useMemo} from \"react\"\nimport {shapeComponent} from \"set-state-compare/src/shape-component\"\nimport {useMergedStyle} from \"./default-style\"\n\nconst FontAwesomeGlyphMap = FontAwesomeIcon.getRawGlyphMap()\nconst FontAwesome5GlyphMap = FontAwesome5Icon.getRawGlyphMap()\nconst FontAwesome6GlyphMap = FontAwesome6Icon.getRawGlyphMap()\nconst MaterialIconsGlyphMap = MaterialIconsIcon.getRawGlyphMap()\n\nconst iconMap = {\n  pencil: \"FontAwesome\",\n  remove: \"FontAwesome\",\n  search: \"FontAwesome\"\n}\n\nexport default memo(shapeComponent(class ApiMakerUtilsIcon extends BaseComponent {\n  render() {\n    const {dataSet, name, style, version, ...restProps} = this.props\n    const {stylesList} = useMergedStyle(style, \"Text\")\n    let actualVersion = version\n\n    if (!actualVersion) {\n      if (name in iconMap) {\n        actualVersion = iconMap[name]\n      } else if (name in FontAwesome6GlyphMap) {\n        actualVersion = \"FontAwesome6\"\n      } else if (name in FontAwesome5GlyphMap) {\n        actualVersion = \"FontAwesome5\"\n      } else if (name in FontAwesomeGlyphMap) {\n        actualVersion = \"FontAwesome\"\n      } else if (name in MaterialIconsGlyphMap) {\n        actualVersion =  \"MaterialIcons\"\n      } else {\n        actualVersion = \"FontAwesome\"\n      }\n    }\n\n    // Only forward some styles like color\n    const actualStylesList = useMemo(() => {\n      const actualStylesList = []\n\n      for (const style of stylesList) {\n        const newStyle = {}\n        let count = 0\n\n        for (const key in style) {\n          if (key == \"color\") {\n            newStyle[key] = style[key]\n            count++\n          }\n        }\n\n        if (count > 0) {\n          actualStylesList.push(newStyle)\n        }\n      }\n\n      return actualStylesList\n    }, [stylesList, style])\n\n    const actualDataSet = useMemo(() => Object.assign({name, version: actualVersion}, dataSet), [actualVersion, dataSet, name])\n\n    if (actualVersion == \"FontAwesome\") {\n      return <FontAwesomeIcon dataSet={actualDataSet} name={name} style={actualStylesList} {...restProps} />\n    } else if (actualVersion == \"FontAwesome5\") {\n      return <FontAwesome5Icon dataSet={actualDataSet} name={name} style={actualStylesList} {...restProps} />\n    } else if (actualVersion == \"FontAwesome6\") {\n      return <FontAwesome6Icon dataSet={actualDataSet} name={name} style={actualStylesList} {...restProps} />\n    } else if (actualVersion == \"MaterialIcons\") {\n      return <MaterialIconsIcon dataSet={actualDataSet} name={name} style={actualStylesList} {...restProps} />\n    } else {\n      throw new Error(`Unknown version: ${actualVersion}`)\n    }\n  }\n}))\n"],"mappings":"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","ignoreList":[]}
package/link.sh ADDED
@@ -0,0 +1,8 @@
1
+ #!/bin/sh
2
+
3
+ cd node_modules
4
+
5
+ rm -rf react
6
+ ln -s ../../../gratisbyggetilbud_rails/node_modules/react
7
+
8
+ yarn link i18n-on-steroids
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kaspernj/api-maker",
3
- "version": "1.0.2037",
3
+ "version": "1.0.2039",
4
4
  "description": "My new module",
5
5
  "main": "build/index.js",
6
6
  "scripts": {
@@ -57,6 +57,7 @@
57
57
  "strftime": ">= 0.10.0",
58
58
  "uniqunize": "^1.0.1",
59
59
  "url-parse": "^1.5.10",
60
+ "use-ssr": "^1.0.25",
60
61
  "wake-event": ">= 0.0.1"
61
62
  },
62
63
  "devDependencies": {
@@ -68,7 +69,7 @@
68
69
  "eslint-find-rules": "^5.0.0",
69
70
  "eslint-plugin-jest": "^28.2.0",
70
71
  "eslint-plugin-react": "^7.23.2",
71
- "expo": "~52.0.0",
72
+ "expo": "~53.0.9",
72
73
  "expo-module-scripts": "^4.0.2",
73
74
  "jest": "^29.0.1"
74
75
  },
@@ -1,16 +1,21 @@
1
- import {useCallback, useLayoutEffect} from "react"
1
+ import {useCallback, useEffect, useLayoutEffect} from "react"
2
+ import useSSR from "use-ssr"
2
3
 
3
4
  const ApiMakerUseEventListener = (target, event, onCalled) => {
5
+ const {isServer} = useSSR()
6
+ const useWorkingEffect = isServer ? useEffect : useLayoutEffect
7
+
4
8
  const onCalledCallback = useCallback((...args) => {
5
9
  onCalled.apply(null, args)
6
10
  }, [target, event, onCalled])
7
11
 
8
- useLayoutEffect(() => {
12
+ useWorkingEffect(() => {
9
13
  if (target) {
10
- target.addEventListener(event, onCalledCallback)
14
+ const eventListener = target.addEventListener(event, onCalledCallback)
11
15
 
12
16
  return () => {
13
- target.removeEventListener(event, onCalledCallback)
17
+ if (eventListener) eventListener.remove() // This is how its done in Expo + Jest.
18
+ if (target.removeEventListener) target.removeEventListener(event, onCalledCallback) // This is the "old" way in browsers.
14
19
  }
15
20
  }
16
21
  }, [target, event, onCalled])
@@ -36,6 +36,8 @@ export default memo(shapeComponent(class ApiMakerUtilsIcon extends BaseComponent
36
36
  actualVersion = "FontAwesome"
37
37
  } else if (name in MaterialIconsGlyphMap) {
38
38
  actualVersion = "MaterialIcons"
39
+ } else {
40
+ actualVersion = "FontAwesome"
39
41
  }
40
42
  }
41
43