flash-notifications 0.0.41 → 0.0.44

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,4 +1,4 @@
1
- declare const _default: React.MemoExoticComponent<(arg0: Record<string, any>) => any>;
1
+ declare const _default: React.NamedExoticComponent<FlashNotificationsContainerProps>;
2
2
  export default _default;
3
3
  export type NotificationObjectType = {
4
4
  count: number;
@@ -18,5 +18,16 @@ export type StoredNotificationType = {
18
18
  title: string;
19
19
  type: string;
20
20
  };
21
+ export type FlashNotificationsContainerProps = {
22
+ insets?: {
23
+ top?: number;
24
+ right?: number;
25
+ left?: number;
26
+ } | undefined;
27
+ };
28
+ export type FlashNotificationsContainerState = {
29
+ count: number;
30
+ notifications: StoredNotificationType[];
31
+ };
21
32
  import React from "react";
22
33
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"/src/","sources":["container/index.jsx"],"names":[],"mappings":";;;WAmBc,MAAM;aACN,MAAM;WACN,MAAM;UACN,MAAM;;;WAKN,MAAM;YACN,OAAO,cAAc,EAAE,QAAQ,CAAC,KAAK;kBACrC,OAAO,cAAc,EAAE,QAAQ,CAAC,KAAK;oBACrC,MAAM,GAAG,SAAS;aAClB,MAAM;aACN,OAAO,cAAc,EAAE,QAAQ,CAAC,KAAK;cACrC,OAAO;aACP,UAAU,CAAC,OAAO,UAAU,CAAC;WAC7B,MAAM;UACN,MAAM;;kBA9B0B,OAAO"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"/src/","sources":["container/index.jsx"],"names":[],"mappings":";;;WAmBc,MAAM;aACN,MAAM;WACN,MAAM;UACN,MAAM;;;WAKN,MAAM;YACN,OAAO,cAAc,EAAE,QAAQ,CAAC,KAAK;kBACrC,OAAO,cAAc,EAAE,QAAQ,CAAC,KAAK;oBACrC,MAAM,GAAG,SAAS;aAClB,MAAM;aACN,OAAO,cAAc,EAAE,QAAQ,CAAC,KAAK;cACrC,OAAO;aACP,UAAU,CAAC,OAAO,UAAU,CAAC;WAC7B,MAAM;UACN,MAAM;;;aAKN;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAC,YAAC;;;WAK9C,MAAM;mBACN,sBAAsB,EAAE;;kBAzCQ,OAAO"}
@@ -32,19 +32,32 @@ import FlashNotification from "./notification";
32
32
  * @property {string} title
33
33
  * @property {string} type
34
34
  */
35
- export default memo(shapeComponent(class FlashNotificationsContainer extends ShapeComponent {
35
+ /**
36
+ * @typedef {object} FlashNotificationsContainerProps
37
+ * @property {{top?: number, right?: number, left?: number}=} insets
38
+ */
39
+ /**
40
+ * @typedef {object} FlashNotificationsContainerState
41
+ * @property {number} count
42
+ * @property {StoredNotificationType[]} notifications
43
+ */
44
+ export default memo(shapeComponent(
45
+ /**
46
+ * @augments {ShapeComponent<FlashNotificationsContainerProps, FlashNotificationsContainerState>}
47
+ */
48
+ class FlashNotificationsContainer extends ShapeComponent {
36
49
  static propTypes = propTypesExact({
37
50
  insets: PropTypes.object
38
51
  });
52
+ state = {
53
+ count: 0,
54
+ /** @type {StoredNotificationType[]} */
55
+ notifications: []
56
+ };
39
57
  /** @type {number[]} */
40
58
  timeouts = [];
41
59
  notificationSpacing = 15;
42
60
  setup() {
43
- this.useStates({
44
- count: 0,
45
- /** @type {StoredNotificationType[]} */
46
- notifications: []
47
- });
48
61
  useEventEmitter(events, "pushNotification", this.onPushNotificationEvent);
49
62
  useEffect(() => {
50
63
  return () => {
@@ -215,4 +228,4 @@ export default memo(shapeComponent(class FlashNotificationsContainer extends Sha
215
228
  });
216
229
  };
217
230
  }));
218
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"/src/","sources":["container/index.jsx"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {digg} from \"diggerize\"\nimport PropTypes from \"prop-types\"\n// @ts-expect-error Package ships no .d.ts files.\nimport propTypesExact from \"prop-types-exact\"\nimport React, {memo, useEffect, useMemo} from \"react\"\nimport {shapeComponent, ShapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport {useBreakpoint} from \"responsive-breakpoints\"\nimport useEventEmitter from \"ya-use-event-emitter\"\nimport useEnvSense from \"env-sense/build/use-env-sense.js\"\nimport {Animated, View} from \"react-native\"\n\nimport debugLog from \"../debug.js\"\nimport events from \"../events.js\"\nimport FlashNotification from \"./notification\"\n\n/**\n * @typedef {object} NotificationObjectType\n * @property {number} count\n * @property {string} message\n * @property {string} title\n * @property {string} type\n */\n\n/**\n * @typedef {object} StoredNotificationType\n * @property {number} count\n * @property {import(\"react-native\").Animated.Value} height\n * @property {import(\"react-native\").Animated.Value} marginBottom\n * @property {number | undefined} measuredHeight\n * @property {string} message\n * @property {import(\"react-native\").Animated.Value} opacity\n * @property {boolean} removing\n * @property {ReturnType<typeof setTimeout>} timeout\n * @property {string} title\n * @property {string} type\n */\n\nexport default memo(shapeComponent(class FlashNotificationsContainer extends ShapeComponent {\n  static propTypes = propTypesExact({\n    insets: PropTypes.object\n  })\n\n  /** @type {number[]} */\n  timeouts = []\n  notificationSpacing = 15\n\n  setup() {\n    this.useStates({\n      count: 0,\n      /** @type {StoredNotificationType[]} */\n      notifications: []\n    })\n\n    useEventEmitter(events, \"pushNotification\", this.onPushNotificationEvent)\n    useEffect(() => {\n      return () => {\n        for (const timeout of this.timeouts) {\n          clearTimeout(timeout)\n        }\n      }\n    }, [])\n  }\n\n  render() {\n    const {notifications} = this.s\n    const insets = this.props.insets || {}\n\n    const {smDown, mdUp} = useBreakpoint()\n    const {isNative} = useEnvSense()\n\n    const viewStyle = useMemo(() => {\n      let top = 20\n      let right = 0\n      let left = undefined\n\n      if (insets.top) top += insets.top\n      if (insets.right) right += insets.right\n\n      if (smDown) {\n        left = 20\n\n        if (insets.left) left += insets.left\n\n        right += 20\n      } else if (mdUp) {\n        right += 20\n      }\n\n      const style = {\n        position: isNative ? \"absolute\" : \"fixed\",\n        top,\n        right,\n        left,\n        zIndex: 99999\n      }\n\n      return style\n    }, [isNative, smDown, mdUp, insets.top, insets.right, insets.left])\n\n    return (\n      <View\n        // @ts-expect-error\n        dataSet={this.rootViewDataSet ||= {component: \"flash-notifications-container\"}}\n        // @ts-expect-error React Native types do not include the web-only \"fixed\" position.\n        style={viewStyle}\n        testID=\"flash-notificaitons/container\"\n      >\n        {notifications.map(\n          /** @param {StoredNotificationType} notification */\n          (notification) =>\n          <FlashNotification\n            count={notification.count}\n            key={`notification-${notification.count}`}\n            message={notification.message}\n            notification={notification}\n            onMeasured={this.onNotificationMeasured}\n            onRemovedClicked={this.onRemovedClicked}\n            title={notification.title}\n            type={notification.type}\n          />\n        )}\n      </View>\n    )\n  }\n\n  /**\n   * @param {...unknown} args\n   * @returns {void}\n   */\n  onPushNotificationEvent = (...args) => {\n    this.onPushNotification(/** @type {NotificationObjectType} */ (args[0]))\n  }\n\n  /**\n   * @param {NotificationObjectType} detail\n   * @returns {void}\n   */\n  onPushNotification = (detail) => {\n    const count = this.s.count + 1\n    const timeout = setTimeout(() => {\n      debugLog(\"FlashNotifications: notification timeout\", {id: count})\n      this.dismissNotificationByCount(count, \"timeout\")\n    }, 4000)\n\n    this.timeouts.push(timeout)\n\n    /** @type {StoredNotificationType} */\n    const notification = {\n      count,\n      height: new Animated.Value(0),\n      marginBottom: new Animated.Value(this.notificationSpacing),\n      measuredHeight: undefined,\n      message: digg(detail, \"message\"),\n      opacity: new Animated.Value(1),\n      removing: false,\n      timeout,\n      title: digg(detail, \"title\"),\n      type: digg(detail, \"type\")\n    }\n\n    debugLog(\"FlashNotifications: notification added\", {\n      id: count,\n      title: notification.title,\n      type: notification.type\n    })\n\n    this.setState({count, notifications: this.s.notifications.concat([notification])})\n  }\n\n  /**\n   * @param {StoredNotificationType} notification\n   * @returns {void}\n   */\n  onRemovedClicked = (notification) => {\n    debugLog(\"FlashNotifications: notification pressed\", {id: notification.count})\n    this.dismissNotification(notification, \"press\")\n  }\n\n  /**\n   * @param {StoredNotificationType} notification\n   * @param {number} measuredHeight\n   * @returns {void}\n   */\n  onNotificationMeasured = (notification, measuredHeight) => {\n    if (notification.measuredHeight) return\n\n    debugLog(\"FlashNotifications: notification measured\", {id: notification.count, height: measuredHeight})\n\n    notification.measuredHeight = measuredHeight\n    notification.height.setValue(measuredHeight)\n    this.setState({notifications: [...this.s.notifications]})\n  }\n\n  /**\n   * @param {number} count\n   * @param {string} [reason]\n   * @returns {void}\n  */\n  dismissNotificationByCount = (count, reason = \"unknown\") => {\n    const notification = /** @type {StoredNotificationType | undefined} */ (this.s.notifications.find(\n      /** @param {StoredNotificationType} item */\n      (item) => item.count == count\n    ))\n    if (!notification) {\n      debugLog(\"FlashNotifications: notification not found\", {id: count, reason})\n      return\n    }\n\n    this.dismissNotification(notification, reason)\n  }\n\n  /**\n   * @param {StoredNotificationType} notification\n   * @param {string} [reason]\n   * @returns {void}\n   */\n  dismissNotification = (notification, reason = \"unknown\") => {\n    if (notification.removing) {\n      debugLog(\"FlashNotifications: notification already removing\", {id: notification.count, reason})\n      return\n    }\n\n    notification.removing = true\n    if (notification.timeout) clearTimeout(notification.timeout)\n\n    if (!notification.measuredHeight) {\n      debugLog(\"FlashNotifications: notification missing measured height\", {id: notification.count})\n      notification.measuredHeight = 1\n      notification.height.setValue(1)\n      this.setState({notifications: [...this.s.notifications]})\n    }\n\n    debugLog(\"FlashNotifications: animations begin\", {\n      id: notification.count,\n      animations: [\"opacity\", \"height\", \"marginBottom\"],\n      reason\n    })\n    debugLog(\"FlashNotifications: fade animation begin\", {id: notification.count, reason})\n\n    const dismissDuration = reason === \"press\" ? 80 : 200\n\n    Animated.parallel([\n      Animated.timing(notification.opacity, {toValue: 0, duration: dismissDuration, useNativeDriver: false}),\n      Animated.timing(notification.height, {toValue: 0, duration: dismissDuration, useNativeDriver: false}),\n      Animated.timing(notification.marginBottom, {toValue: 0, duration: dismissDuration, useNativeDriver: false})\n    ]).start(() => {\n      debugLog(\"FlashNotifications: animations end\", {\n        id: notification.count,\n        animations: [\"opacity\", \"height\", \"marginBottom\"],\n        reason\n      })\n      debugLog(\"FlashNotifications: fade animation end\", {id: notification.count, reason})\n\n      this.setState({\n        notifications: this.s.notifications.filter(\n          /** @param {StoredNotificationType} item */\n          (item) => item.count != notification.count\n        )\n      })\n\n      debugLog(\"FlashNotifications: notification removed\", {id: notification.count, reason})\n    })\n  }\n}))\n"]}
231
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"/src/","sources":["container/index.jsx"],"names":[],"mappings":"AAAA,YAAY;AAEZ,OAAO,EAAC,IAAI,EAAC,MAAM,WAAW,CAAA;AAC9B,OAAO,SAAS,MAAM,YAAY,CAAA;AAClC,iDAAiD;AACjD,OAAO,cAAc,MAAM,kBAAkB,CAAA;AAC7C,OAAO,KAAK,EAAE,EAAC,IAAI,EAAE,SAAS,EAAE,OAAO,EAAC,MAAM,OAAO,CAAA;AACrD,OAAO,EAAC,cAAc,EAAE,cAAc,EAAC,MAAM,4CAA4C,CAAA;AACzF,OAAO,EAAC,aAAa,EAAC,MAAM,wBAAwB,CAAA;AACpD,OAAO,eAAe,MAAM,sBAAsB,CAAA;AAClD,OAAO,WAAW,MAAM,kCAAkC,CAAA;AAC1D,OAAO,EAAC,QAAQ,EAAE,IAAI,EAAC,MAAM,cAAc,CAAA;AAE3C,OAAO,QAAQ,MAAM,aAAa,CAAA;AAClC,OAAO,MAAM,MAAM,cAAc,CAAA;AACjC,OAAO,iBAAiB,MAAM,gBAAgB,CAAA;AAE9C;;;;;;GAMG;AAEH;;;;;;;;;;;;GAYG;AAEH;;;GAGG;AAEH;;;;GAIG;AAEH,eAAe,IAAI,CAAC,cAAc;AAChC;;GAEG;AACH,MAAM,2BAA4B,SAAQ,cAAc;IACxD,MAAM,CAAC,SAAS,GAAG,cAAc,CAAC;QAChC,MAAM,EAAE,SAAS,CAAC,MAAM;KACzB,CAAC,CAAA;IAEF,KAAK,GAAG;QACN,KAAK,EAAE,CAAC;QACR,uCAAuC;QACvC,aAAa,EAAE,EAAE;KAClB,CAAA;IAED,uBAAuB;IACvB,QAAQ,GAAG,EAAE,CAAA;IACb,mBAAmB,GAAG,EAAE,CAAA;IAExB,KAAK;QACH,eAAe,CAAC,MAAM,EAAE,kBAAkB,EAAE,IAAI,CAAC,uBAAuB,CAAC,CAAA;QACzE,SAAS,CAAC,GAAG,EAAE;YACb,OAAO,GAAG,EAAE;gBACV,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;oBACpC,YAAY,CAAC,OAAO,CAAC,CAAA;gBACvB,CAAC;YACH,CAAC,CAAA;QACH,CAAC,EAAE,EAAE,CAAC,CAAA;IACR,CAAC;IAED,MAAM;QACJ,MAAM,EAAC,aAAa,EAAC,GAAG,IAAI,CAAC,CAAC,CAAA;QAC9B,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,EAAE,CAAA;QAEtC,MAAM,EAAC,MAAM,EAAE,IAAI,EAAC,GAAG,aAAa,EAAE,CAAA;QACtC,MAAM,EAAC,QAAQ,EAAC,GAAG,WAAW,EAAE,CAAA;QAEhC,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,EAAE;YAC7B,IAAI,GAAG,GAAG,EAAE,CAAA;YACZ,IAAI,KAAK,GAAG,CAAC,CAAA;YACb,IAAI,IAAI,GAAG,SAAS,CAAA;YAEpB,IAAI,MAAM,CAAC,GAAG;gBAAE,GAAG,IAAI,MAAM,CAAC,GAAG,CAAA;YACjC,IAAI,MAAM,CAAC,KAAK;gBAAE,KAAK,IAAI,MAAM,CAAC,KAAK,CAAA;YAEvC,IAAI,MAAM,EAAE,CAAC;gBACX,IAAI,GAAG,EAAE,CAAA;gBAET,IAAI,MAAM,CAAC,IAAI;oBAAE,IAAI,IAAI,MAAM,CAAC,IAAI,CAAA;gBAEpC,KAAK,IAAI,EAAE,CAAA;YACb,CAAC;iBAAM,IAAI,IAAI,EAAE,CAAC;gBAChB,KAAK,IAAI,EAAE,CAAA;YACb,CAAC;YAED,MAAM,KAAK,GAAG;gBACZ,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO;gBACzC,GAAG;gBACH,KAAK;gBACL,IAAI;gBACJ,MAAM,EAAE,KAAK;aACd,CAAA;YAED,OAAO,KAAK,CAAA;QACd,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,CAAA;QAEnE,OAAO,CACL,oBAAC,IAAI;QACH,mBAAmB;;YAAnB,mBAAmB;YACnB,OAAO,EAAE,IAAI,CAAC,eAAe,KAAK,EAAC,SAAS,EAAE,+BAA+B,EAAC;YAC9E,oFAAoF;YACpF,KAAK,EAAE,SAAS,EAChB,MAAM,EAAC,+BAA+B,IAErC,aAAa,CAAC,GAAG;QAChB,mDAAmD;QACnD,CAAC,YAAY,EAAE,EAAE,CACjB,oBAAC,iBAAiB,IAChB,KAAK,EAAE,YAAY,CAAC,KAAK,EACzB,GAAG,EAAE,gBAAgB,YAAY,CAAC,KAAK,EAAE,EACzC,OAAO,EAAE,YAAY,CAAC,OAAO,EAC7B,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,IAAI,CAAC,sBAAsB,EACvC,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,EACvC,KAAK,EAAE,YAAY,CAAC,KAAK,EACzB,IAAI,EAAE,YAAY,CAAC,IAAI,GACvB,CACH,CACI,CACR,CAAA;IACH,CAAC;IAED;;;OAGG;IACH,uBAAuB,GAAG,CAAC,GAAG,IAAI,EAAE,EAAE;QACpC,IAAI,CAAC,kBAAkB,CAAC,qCAAqC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IAC1E,CAAC,CAAA;IAED;;;OAGG;IACH,kBAAkB,GAAG,CAAC,MAAM,EAAE,EAAE;QAC9B,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAA;QAC9B,MAAM,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE;YAC9B,QAAQ,CAAC,0CAA0C,EAAE,EAAC,EAAE,EAAE,KAAK,EAAC,CAAC,CAAA;YACjE,IAAI,CAAC,0BAA0B,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;QACnD,CAAC,EAAE,IAAI,CAAC,CAAA;QAER,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAE3B,qCAAqC;QACrC,MAAM,YAAY,GAAG;YACnB,KAAK;YACL,MAAM,EAAE,IAAI,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;YAC7B,YAAY,EAAE,IAAI,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,mBAAmB,CAAC;YAC1D,cAAc,EAAE,SAAS;YACzB,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC;YAChC,OAAO,EAAE,IAAI,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;YAC9B,QAAQ,EAAE,KAAK;YACf,OAAO;YACP,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC;YAC5B,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC;SAC3B,CAAA;QAED,QAAQ,CAAC,wCAAwC,EAAE;YACjD,EAAE,EAAE,KAAK;YACT,KAAK,EAAE,YAAY,CAAC,KAAK;YACzB,IAAI,EAAE,YAAY,CAAC,IAAI;SACxB,CAAC,CAAA;QAEF,IAAI,CAAC,QAAQ,CAAC,EAAC,KAAK,EAAE,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,EAAC,CAAC,CAAA;IACpF,CAAC,CAAA;IAED;;;OAGG;IACH,gBAAgB,GAAG,CAAC,YAAY,EAAE,EAAE;QAClC,QAAQ,CAAC,0CAA0C,EAAE,EAAC,EAAE,EAAE,YAAY,CAAC,KAAK,EAAC,CAAC,CAAA;QAC9E,IAAI,CAAC,mBAAmB,CAAC,YAAY,EAAE,OAAO,CAAC,CAAA;IACjD,CAAC,CAAA;IAED;;;;OAIG;IACH,sBAAsB,GAAG,CAAC,YAAY,EAAE,cAAc,EAAE,EAAE;QACxD,IAAI,YAAY,CAAC,cAAc;YAAE,OAAM;QAEvC,QAAQ,CAAC,2CAA2C,EAAE,EAAC,EAAE,EAAE,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,cAAc,EAAC,CAAC,CAAA;QAEvG,YAAY,CAAC,cAAc,GAAG,cAAc,CAAA;QAC5C,YAAY,CAAC,MAAM,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAA;QAC5C,IAAI,CAAC,QAAQ,CAAC,EAAC,aAAa,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC,EAAC,CAAC,CAAA;IAC3D,CAAC,CAAA;IAED;;;;MAIE;IACF,0BAA0B,GAAG,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAAE,EAAE;QACzD,MAAM,YAAY,GAAG,iDAAiD,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI;QAC/F,2CAA2C;QAC3C,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,IAAI,KAAK,CAC9B,CAAC,CAAA;QACF,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,QAAQ,CAAC,4CAA4C,EAAE,EAAC,EAAE,EAAE,KAAK,EAAE,MAAM,EAAC,CAAC,CAAA;YAC3E,OAAM;QACR,CAAC;QAED,IAAI,CAAC,mBAAmB,CAAC,YAAY,EAAE,MAAM,CAAC,CAAA;IAChD,CAAC,CAAA;IAED;;;;OAIG;IACH,mBAAmB,GAAG,CAAC,YAAY,EAAE,MAAM,GAAG,SAAS,EAAE,EAAE;QACzD,IAAI,YAAY,CAAC,QAAQ,EAAE,CAAC;YAC1B,QAAQ,CAAC,mDAAmD,EAAE,EAAC,EAAE,EAAE,YAAY,CAAC,KAAK,EAAE,MAAM,EAAC,CAAC,CAAA;YAC/F,OAAM;QACR,CAAC;QAED,YAAY,CAAC,QAAQ,GAAG,IAAI,CAAA;QAC5B,IAAI,YAAY,CAAC,OAAO;YAAE,YAAY,CAAC,YAAY,CAAC,OAAO,CAAC,CAAA;QAE5D,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,CAAC;YACjC,QAAQ,CAAC,0DAA0D,EAAE,EAAC,EAAE,EAAE,YAAY,CAAC,KAAK,EAAC,CAAC,CAAA;YAC9F,YAAY,CAAC,cAAc,GAAG,CAAC,CAAA;YAC/B,YAAY,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAA;YAC/B,IAAI,CAAC,QAAQ,CAAC,EAAC,aAAa,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC,EAAC,CAAC,CAAA;QAC3D,CAAC;QAED,QAAQ,CAAC,sCAAsC,EAAE;YAC/C,EAAE,EAAE,YAAY,CAAC,KAAK;YACtB,UAAU,EAAE,CAAC,SAAS,EAAE,QAAQ,EAAE,cAAc,CAAC;YACjD,MAAM;SACP,CAAC,CAAA;QACF,QAAQ,CAAC,0CAA0C,EAAE,EAAC,EAAE,EAAE,YAAY,CAAC,KAAK,EAAE,MAAM,EAAC,CAAC,CAAA;QAEtF,MAAM,eAAe,GAAG,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAA;QAErD,QAAQ,CAAC,QAAQ,CAAC;YAChB,QAAQ,CAAC,MAAM,CAAC,YAAY,CAAC,OAAO,EAAE,EAAC,OAAO,EAAE,CAAC,EAAE,QAAQ,EAAE,eAAe,EAAE,eAAe,EAAE,KAAK,EAAC,CAAC;YACtG,QAAQ,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,EAAE,EAAC,OAAO,EAAE,CAAC,EAAE,QAAQ,EAAE,eAAe,EAAE,eAAe,EAAE,KAAK,EAAC,CAAC;YACrG,QAAQ,CAAC,MAAM,CAAC,YAAY,CAAC,YAAY,EAAE,EAAC,OAAO,EAAE,CAAC,EAAE,QAAQ,EAAE,eAAe,EAAE,eAAe,EAAE,KAAK,EAAC,CAAC;SAC5G,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE;YACZ,QAAQ,CAAC,oCAAoC,EAAE;gBAC7C,EAAE,EAAE,YAAY,CAAC,KAAK;gBACtB,UAAU,EAAE,CAAC,SAAS,EAAE,QAAQ,EAAE,cAAc,CAAC;gBACjD,MAAM;aACP,CAAC,CAAA;YACF,QAAQ,CAAC,wCAAwC,EAAE,EAAC,EAAE,EAAE,YAAY,CAAC,KAAK,EAAE,MAAM,EAAC,CAAC,CAAA;YAEpF,IAAI,CAAC,QAAQ,CAAC;gBACZ,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC,MAAM;gBACxC,2CAA2C;gBAC3C,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,KAAK,CAC3C;aACF,CAAC,CAAA;YAEF,QAAQ,CAAC,0CAA0C,EAAE,EAAC,EAAE,EAAE,YAAY,CAAC,KAAK,EAAE,MAAM,EAAC,CAAC,CAAA;QACxF,CAAC,CAAC,CAAA;IACJ,CAAC,CAAA;CACF,CAAC,CAAC,CAAA","sourcesContent":["// @ts-check\n\nimport {digg} from \"diggerize\"\nimport PropTypes from \"prop-types\"\n// @ts-expect-error Package ships no .d.ts files.\nimport propTypesExact from \"prop-types-exact\"\nimport React, {memo, useEffect, useMemo} from \"react\"\nimport {shapeComponent, ShapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport {useBreakpoint} from \"responsive-breakpoints\"\nimport useEventEmitter from \"ya-use-event-emitter\"\nimport useEnvSense from \"env-sense/build/use-env-sense.js\"\nimport {Animated, View} from \"react-native\"\n\nimport debugLog from \"../debug.js\"\nimport events from \"../events.js\"\nimport FlashNotification from \"./notification\"\n\n/**\n * @typedef {object} NotificationObjectType\n * @property {number} count\n * @property {string} message\n * @property {string} title\n * @property {string} type\n */\n\n/**\n * @typedef {object} StoredNotificationType\n * @property {number} count\n * @property {import(\"react-native\").Animated.Value} height\n * @property {import(\"react-native\").Animated.Value} marginBottom\n * @property {number | undefined} measuredHeight\n * @property {string} message\n * @property {import(\"react-native\").Animated.Value} opacity\n * @property {boolean} removing\n * @property {ReturnType<typeof setTimeout>} timeout\n * @property {string} title\n * @property {string} type\n */\n\n/**\n * @typedef {object} FlashNotificationsContainerProps\n * @property {{top?: number, right?: number, left?: number}=} insets\n */\n\n/**\n * @typedef {object} FlashNotificationsContainerState\n * @property {number} count\n * @property {StoredNotificationType[]} notifications\n */\n\nexport default memo(shapeComponent(\n  /**\n   * @augments {ShapeComponent<FlashNotificationsContainerProps, FlashNotificationsContainerState>}\n   */\n  class FlashNotificationsContainer extends ShapeComponent {\n  static propTypes = propTypesExact({\n    insets: PropTypes.object\n  })\n\n  state = {\n    count: 0,\n    /** @type {StoredNotificationType[]} */\n    notifications: []\n  }\n\n  /** @type {number[]} */\n  timeouts = []\n  notificationSpacing = 15\n\n  setup() {\n    useEventEmitter(events, \"pushNotification\", this.onPushNotificationEvent)\n    useEffect(() => {\n      return () => {\n        for (const timeout of this.timeouts) {\n          clearTimeout(timeout)\n        }\n      }\n    }, [])\n  }\n\n  render() {\n    const {notifications} = this.s\n    const insets = this.props.insets || {}\n\n    const {smDown, mdUp} = useBreakpoint()\n    const {isNative} = useEnvSense()\n\n    const viewStyle = useMemo(() => {\n      let top = 20\n      let right = 0\n      let left = undefined\n\n      if (insets.top) top += insets.top\n      if (insets.right) right += insets.right\n\n      if (smDown) {\n        left = 20\n\n        if (insets.left) left += insets.left\n\n        right += 20\n      } else if (mdUp) {\n        right += 20\n      }\n\n      const style = {\n        position: isNative ? \"absolute\" : \"fixed\",\n        top,\n        right,\n        left,\n        zIndex: 99999\n      }\n\n      return style\n    }, [isNative, smDown, mdUp, insets.top, insets.right, insets.left])\n\n    return (\n      <View\n        // @ts-expect-error\n        dataSet={this.rootViewDataSet ||= {component: \"flash-notifications-container\"}}\n        // @ts-expect-error React Native types do not include the web-only \"fixed\" position.\n        style={viewStyle}\n        testID=\"flash-notificaitons/container\"\n      >\n        {notifications.map(\n          /** @param {StoredNotificationType} notification */\n          (notification) =>\n          <FlashNotification\n            count={notification.count}\n            key={`notification-${notification.count}`}\n            message={notification.message}\n            notification={notification}\n            onMeasured={this.onNotificationMeasured}\n            onRemovedClicked={this.onRemovedClicked}\n            title={notification.title}\n            type={notification.type}\n          />\n        )}\n      </View>\n    )\n  }\n\n  /**\n   * @param {...unknown} args\n   * @returns {void}\n   */\n  onPushNotificationEvent = (...args) => {\n    this.onPushNotification(/** @type {NotificationObjectType} */ (args[0]))\n  }\n\n  /**\n   * @param {NotificationObjectType} detail\n   * @returns {void}\n   */\n  onPushNotification = (detail) => {\n    const count = this.s.count + 1\n    const timeout = setTimeout(() => {\n      debugLog(\"FlashNotifications: notification timeout\", {id: count})\n      this.dismissNotificationByCount(count, \"timeout\")\n    }, 4000)\n\n    this.timeouts.push(timeout)\n\n    /** @type {StoredNotificationType} */\n    const notification = {\n      count,\n      height: new Animated.Value(0),\n      marginBottom: new Animated.Value(this.notificationSpacing),\n      measuredHeight: undefined,\n      message: digg(detail, \"message\"),\n      opacity: new Animated.Value(1),\n      removing: false,\n      timeout,\n      title: digg(detail, \"title\"),\n      type: digg(detail, \"type\")\n    }\n\n    debugLog(\"FlashNotifications: notification added\", {\n      id: count,\n      title: notification.title,\n      type: notification.type\n    })\n\n    this.setState({count, notifications: this.s.notifications.concat([notification])})\n  }\n\n  /**\n   * @param {StoredNotificationType} notification\n   * @returns {void}\n   */\n  onRemovedClicked = (notification) => {\n    debugLog(\"FlashNotifications: notification pressed\", {id: notification.count})\n    this.dismissNotification(notification, \"press\")\n  }\n\n  /**\n   * @param {StoredNotificationType} notification\n   * @param {number} measuredHeight\n   * @returns {void}\n   */\n  onNotificationMeasured = (notification, measuredHeight) => {\n    if (notification.measuredHeight) return\n\n    debugLog(\"FlashNotifications: notification measured\", {id: notification.count, height: measuredHeight})\n\n    notification.measuredHeight = measuredHeight\n    notification.height.setValue(measuredHeight)\n    this.setState({notifications: [...this.s.notifications]})\n  }\n\n  /**\n   * @param {number} count\n   * @param {string} [reason]\n   * @returns {void}\n  */\n  dismissNotificationByCount = (count, reason = \"unknown\") => {\n    const notification = /** @type {StoredNotificationType | undefined} */ (this.s.notifications.find(\n      /** @param {StoredNotificationType} item */\n      (item) => item.count == count\n    ))\n    if (!notification) {\n      debugLog(\"FlashNotifications: notification not found\", {id: count, reason})\n      return\n    }\n\n    this.dismissNotification(notification, reason)\n  }\n\n  /**\n   * @param {StoredNotificationType} notification\n   * @param {string} [reason]\n   * @returns {void}\n   */\n  dismissNotification = (notification, reason = \"unknown\") => {\n    if (notification.removing) {\n      debugLog(\"FlashNotifications: notification already removing\", {id: notification.count, reason})\n      return\n    }\n\n    notification.removing = true\n    if (notification.timeout) clearTimeout(notification.timeout)\n\n    if (!notification.measuredHeight) {\n      debugLog(\"FlashNotifications: notification missing measured height\", {id: notification.count})\n      notification.measuredHeight = 1\n      notification.height.setValue(1)\n      this.setState({notifications: [...this.s.notifications]})\n    }\n\n    debugLog(\"FlashNotifications: animations begin\", {\n      id: notification.count,\n      animations: [\"opacity\", \"height\", \"marginBottom\"],\n      reason\n    })\n    debugLog(\"FlashNotifications: fade animation begin\", {id: notification.count, reason})\n\n    const dismissDuration = reason === \"press\" ? 80 : 200\n\n    Animated.parallel([\n      Animated.timing(notification.opacity, {toValue: 0, duration: dismissDuration, useNativeDriver: false}),\n      Animated.timing(notification.height, {toValue: 0, duration: dismissDuration, useNativeDriver: false}),\n      Animated.timing(notification.marginBottom, {toValue: 0, duration: dismissDuration, useNativeDriver: false})\n    ]).start(() => {\n      debugLog(\"FlashNotifications: animations end\", {\n        id: notification.count,\n        animations: [\"opacity\", \"height\", \"marginBottom\"],\n        reason\n      })\n      debugLog(\"FlashNotifications: fade animation end\", {id: notification.count, reason})\n\n      this.setState({\n        notifications: this.s.notifications.filter(\n          /** @param {StoredNotificationType} item */\n          (item) => item.count != notification.count\n        )\n      })\n\n      debugLog(\"FlashNotifications: notification removed\", {id: notification.count, reason})\n    })\n  }\n}))\n"]}
@@ -1,4 +1,26 @@
1
- declare const _default: React.MemoExoticComponent<(arg0: Record<string, any>) => any>;
1
+ declare const _default: React.NamedExoticComponent<FlashNotificationsNotificationProps>;
2
2
  export default _default;
3
+ export type StoredNotificationType = {
4
+ count: number;
5
+ height: import("react-native").Animated.Value;
6
+ marginBottom: import("react-native").Animated.Value;
7
+ measuredHeight: number | undefined;
8
+ message: string;
9
+ opacity: import("react-native").Animated.Value;
10
+ removing: boolean;
11
+ timeout: ReturnType<typeof setTimeout>;
12
+ title: string;
13
+ type: string;
14
+ };
15
+ export type FlashNotificationsNotificationProps = {
16
+ className?: string | undefined;
17
+ count: number;
18
+ message: string;
19
+ notification: StoredNotificationType;
20
+ onMeasured: (notification: StoredNotificationType, measuredHeight: number) => void;
21
+ onRemovedClicked: (notification: StoredNotificationType) => void;
22
+ title: string;
23
+ type: string;
24
+ };
3
25
  import React from "react";
4
26
  //# sourceMappingURL=notification.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"notification.d.ts","sourceRoot":"/src/","sources":["container/notification.jsx"],"names":[],"mappings":";;kBAGmC,OAAO"}
1
+ {"version":3,"file":"notification.d.ts","sourceRoot":"/src/","sources":["container/notification.jsx"],"names":[],"mappings":";;;WAYc,MAAM;YACN,OAAO,cAAc,EAAE,QAAQ,CAAC,KAAK;kBACrC,OAAO,cAAc,EAAE,QAAQ,CAAC,KAAK;oBACrC,MAAM,GAAG,SAAS;aAClB,MAAM;aACN,OAAO,cAAc,EAAE,QAAQ,CAAC,KAAK;cACrC,OAAO;aACP,UAAU,CAAC,OAAO,UAAU,CAAC;WAC7B,MAAM;UACN,MAAM;;;gBAKN,MAAM,YAAC;WACP,MAAM;aACN,MAAM;kBACN,sBAAsB;gBACtB,CAAC,YAAY,EAAE,sBAAsB,EAAE,cAAc,EAAE,MAAM,KAAK,IAAI;sBACtE,CAAC,YAAY,EAAE,sBAAsB,KAAK,IAAI;WAC9C,MAAM;UACN,MAAM;;kBA5Be,OAAO"}
@@ -1,3 +1,4 @@
1
+ // @ts-check
1
2
  import PropTypes from "prop-types";
2
3
  // @ts-expect-error Package ships no .d.ts files.
3
4
  import PropTypesExact from "prop-types-exact";
@@ -5,11 +6,40 @@ import React, { memo, useMemo } from "react";
5
6
  import { Animated, Pressable, Text, View } from "react-native";
6
7
  import { shapeComponent, ShapeComponent } from "set-state-compare/build/shape-component.js";
7
8
  import { useBreakpoint } from "responsive-breakpoints";
9
+ /**
10
+ * @typedef {object} StoredNotificationType
11
+ * @property {number} count
12
+ * @property {import("react-native").Animated.Value} height
13
+ * @property {import("react-native").Animated.Value} marginBottom
14
+ * @property {number | undefined} measuredHeight
15
+ * @property {string} message
16
+ * @property {import("react-native").Animated.Value} opacity
17
+ * @property {boolean} removing
18
+ * @property {ReturnType<typeof setTimeout>} timeout
19
+ * @property {string} title
20
+ * @property {string} type
21
+ */
22
+ /**
23
+ * @typedef {object} FlashNotificationsNotificationProps
24
+ * @property {string=} className
25
+ * @property {number} count
26
+ * @property {string} message
27
+ * @property {StoredNotificationType} notification
28
+ * @property {(notification: StoredNotificationType, measuredHeight: number) => void} onMeasured
29
+ * @property {(notification: StoredNotificationType) => void} onRemovedClicked
30
+ * @property {string} title
31
+ * @property {string} type
32
+ */
8
33
  /** @type {Record<string, object>} */
9
34
  const dataSets = {};
10
- /** @type {Record<string, object>} */
11
- const styles = {};
12
- export default memo(shapeComponent(class FlashNotificationsNotification extends ShapeComponent {
35
+ /** @type {Record<string, import("react-native").ViewStyle>} */
36
+ const viewStyles = {};
37
+ /** @type {Record<string, import("react-native").TextStyle>} */
38
+ const textStyles = {};
39
+ /**
40
+ * @augments {ShapeComponent<FlashNotificationsNotificationProps>}
41
+ */
42
+ class FlashNotificationsNotification extends ShapeComponent {
13
43
  static propTypes = PropTypesExact({
14
44
  className: PropTypes.string,
15
45
  count: PropTypes.number.isRequired,
@@ -30,69 +60,80 @@ export default memo(shapeComponent(class FlashNotificationsNotification extends
30
60
  type
31
61
  }), [className, type]);
32
62
  return (React.createElement(Animated.View, { style: this.tt.wrapperStyle },
33
- React.createElement(Pressable, { dataSet: pressableDataSet, onLayout: this.tt.onLayout, onPress: this.tt.onRemovedClicked, style: styles[`pressable-${type}-${breakpoint.smDown}-${breakpoint.mdUp}`] ||= {
34
- padding: 15,
35
- borderRadius: 11,
36
- cursor: "pointer",
37
- width: (() => {
38
- if (breakpoint.smDown) {
39
- return "100%";
40
- }
41
- else if (breakpoint.mdUp) {
42
- return 300;
43
- }
44
- })(),
45
- maxWidth: (() => {
46
- if (breakpoint.mdUp) {
47
- return "100%";
48
- }
49
- })(),
50
- border: (() => {
51
- if (type == "error") {
52
- return "1px solid rgba(161, 34, 32, 0.95)";
53
- }
54
- else if (type == "success") {
55
- return "1px solid rgba(0, 0, 0, 0.95)";
56
- }
57
- else if (type == "alert") {
58
- return "1px solid rgba(204, 51, 0, 0.95)";
59
- }
60
- })(),
61
- backgroundColor: (() => {
62
- if (type == "error") {
63
- return "rgba(161, 34, 32, 0.87)";
64
- }
65
- else if (type == "success") {
66
- return "rgba(0, 0, 0, 0.87)";
67
- }
68
- else if (type == "alert") {
69
- return "rgba(204, 51, 0, 0.87)";
70
- }
71
- })()
72
- }, testID: "flash-notifications-notification" },
73
- React.createElement(View, { style: styles.titleView ||= { marginBottom: 5 }, testID: "notification-title" },
74
- React.createElement(Text, { style: styles.titleText ||= {
63
+ React.createElement(Pressable
64
+ // @ts-expect-error React Native types do not include the web-only dataSet prop.
65
+ , {
66
+ // @ts-expect-error React Native types do not include the web-only dataSet prop.
67
+ dataSet: pressableDataSet, onLayout: this.tt.onLayout, onPress: this.tt.onRemovedClicked, style: breakpoint.styling({
68
+ base: {
69
+ padding: 15,
70
+ borderRadius: 11,
71
+ cursor: "pointer",
72
+ border: (() => {
73
+ if (type == "error") {
74
+ return "1px solid rgba(161, 34, 32, 0.95)";
75
+ }
76
+ else if (type == "success") {
77
+ return "1px solid rgba(0, 0, 0, 0.95)";
78
+ }
79
+ else if (type == "alert") {
80
+ return "1px solid rgba(204, 51, 0, 0.95)";
81
+ }
82
+ return undefined;
83
+ })(),
84
+ backgroundColor: (() => {
85
+ if (type == "error") {
86
+ return "rgba(161, 34, 32, 0.87)";
87
+ }
88
+ else if (type == "success") {
89
+ return "rgba(0, 0, 0, 0.87)";
90
+ }
91
+ else if (type == "alert") {
92
+ return "rgba(204, 51, 0, 0.87)";
93
+ }
94
+ return undefined;
95
+ })()
96
+ },
97
+ smDown: {
98
+ width: "100%"
99
+ },
100
+ mdUp: {
101
+ width: 300,
102
+ maxWidth: "100%"
103
+ }
104
+ }), testID: "flash-notifications-notification" },
105
+ React.createElement(View, { style: viewStyles.titleView ||= { marginBottom: 5 }, testID: "notification-title" },
106
+ React.createElement(Text, { style: textStyles.titleText ||= {
75
107
  color: "#fff",
76
108
  fontWeight: 700
77
109
  }, testID: `flash-notifications/notification-${count}/title` }, title)),
78
- React.createElement(View, { dataSet: dataSets[`notificationMessage-${count}`] ||= { count: `${count}` }, testID: "notification-message" },
79
- React.createElement(Text, { style: styles.messageText ||= { color: "#fff" }, testID: `flash-notifications/notification-${count}/message` }, message)))));
110
+ React.createElement(View
111
+ // @ts-expect-error React Native types do not include the web-only dataSet prop.
112
+ , {
113
+ // @ts-expect-error React Native types do not include the web-only dataSet prop.
114
+ dataSet: dataSets[`notificationMessage-${count}`] ||= { count: `${count}` }, testID: "notification-message" },
115
+ React.createElement(Text, { style: textStyles.messageText ||= { color: "#fff" }, testID: `flash-notifications/notification-${count}/message` }, message)))));
80
116
  }
81
117
  get wrapperStyle() {
82
118
  const { notification } = this.p;
83
- return {
119
+ return /** @type {import("react-native").Animated.WithAnimatedObject<import("react-native").ViewStyle>} */ ({
84
120
  height: notification.measuredHeight ? notification.height : undefined,
85
121
  marginBottom: notification.marginBottom,
86
122
  opacity: notification.opacity,
87
123
  overflow: "hidden"
88
- };
124
+ });
89
125
  }
90
126
  onRemovedClicked = () => this.p.onRemovedClicked(this.p.notification);
127
+ /**
128
+ * @param {import("react-native").LayoutChangeEvent} event
129
+ * @returns {void}
130
+ */
91
131
  onLayout = (event) => {
92
132
  const { notification } = this.p;
93
133
  if (!notification.measuredHeight) {
94
134
  this.p.onMeasured(notification, event.nativeEvent.layout.height);
95
135
  }
96
136
  };
97
- }));
98
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.js","sourceRoot":"/src/","sources":["container/notification.jsx"],"names":[],"mappings":"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","sourcesContent":["import PropTypes from \"prop-types\"\n// @ts-expect-error Package ships no .d.ts files.\nimport PropTypesExact from \"prop-types-exact\"\nimport React, {memo, useMemo} from \"react\"\nimport {Animated, Pressable, Text, View} from \"react-native\"\nimport {shapeComponent, ShapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport {useBreakpoint} from \"responsive-breakpoints\"\n\n/** @type {Record<string, object>} */\nconst dataSets = {}\n/** @type {Record<string, object>} */\nconst styles = {}\n\nexport default memo(shapeComponent(class FlashNotificationsNotification extends ShapeComponent {\n  static propTypes = PropTypesExact({\n    className: PropTypes.string,\n    count: PropTypes.number.isRequired,\n    message: PropTypes.string.isRequired,\n    notification: PropTypes.object.isRequired,\n    onMeasured: PropTypes.func.isRequired,\n    onRemovedClicked: PropTypes.func.isRequired,\n    title: PropTypes.string.isRequired,\n    type: PropTypes.string.isRequired\n  })\n\n  render() {\n    const {count, message, title, type} = this.p\n    const {className} = this.props\n    const breakpoint = useBreakpoint()\n\n    const pressableDataSet = useMemo(\n      () => ({\n        class: className,\n        role: \"dialog\",\n        type\n      }),\n      [className, type]\n    )\n\n    return (\n      <Animated.View style={this.tt.wrapperStyle}>\n        <Pressable\n          dataSet={pressableDataSet}\n          onLayout={this.tt.onLayout}\n          onPress={this.tt.onRemovedClicked}\n          style={styles[`pressable-${type}-${breakpoint.smDown}-${breakpoint.mdUp}`] ||= {\n            padding: 15,\n            borderRadius: 11,\n            cursor: \"pointer\",\n            width: (() => {\n              if (breakpoint.smDown) {\n                return \"100%\"\n              } else if (breakpoint.mdUp) {\n                return 300\n              }\n            })(),\n            maxWidth: (() => {\n              if (breakpoint.mdUp) {\n                return \"100%\"\n              }\n            })(),\n            border: (() => {\n              if (type == \"error\") {\n                return \"1px solid rgba(161, 34, 32, 0.95)\"\n              } else if (type == \"success\") {\n                return \"1px solid rgba(0, 0, 0, 0.95)\"\n              } else if (type == \"alert\") {\n                return \"1px solid rgba(204, 51, 0, 0.95)\"\n              }\n            })(),\n            backgroundColor: (() => {\n              if (type == \"error\") {\n                return \"rgba(161, 34, 32, 0.87)\"\n              } else if (type == \"success\") {\n                return \"rgba(0, 0, 0, 0.87)\"\n              } else if (type == \"alert\") {\n                return \"rgba(204, 51, 0, 0.87)\"\n              }\n            })()\n          }}\n          testID=\"flash-notifications-notification\"\n        >\n          <View\n            style={styles.titleView ||= {marginBottom: 5}}\n            testID=\"notification-title\"\n          >\n            <Text\n              style={styles.titleText ||= {\n                color: \"#fff\",\n                fontWeight: 700\n              }}\n              testID={`flash-notifications/notification-${count}/title`}\n            >\n              {title}\n            </Text>\n          </View>\n          <View\n            dataSet={dataSets[`notificationMessage-${count}`] ||= {count: `${count}`}}\n            testID=\"notification-message\"\n          >\n            <Text\n              style={styles.messageText ||= {color: \"#fff\"}}\n              testID={`flash-notifications/notification-${count}/message`}\n            >\n              {message}\n            </Text>\n          </View>\n        </Pressable>\n      </Animated.View>\n    )\n  }\n\n  get wrapperStyle() {\n    const {notification} = this.p\n\n    return {\n      height: notification.measuredHeight ? notification.height : undefined,\n      marginBottom: notification.marginBottom,\n      opacity: notification.opacity,\n      overflow: \"hidden\"\n    }\n  }\n\n  onRemovedClicked = () => this.p.onRemovedClicked(this.p.notification)\n\n  onLayout = (event) => {\n    const {notification} = this.p\n\n    if (!notification.measuredHeight) {\n      this.p.onMeasured(notification, event.nativeEvent.layout.height)\n    }\n  }\n}))\n"]}
137
+ }
138
+ export default memo(shapeComponent(FlashNotificationsNotification));
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.js","sourceRoot":"/src/","sources":["container/notification.jsx"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport PropTypes from \"prop-types\"\n// @ts-expect-error Package ships no .d.ts files.\nimport PropTypesExact from \"prop-types-exact\"\nimport React, {memo, useMemo} from \"react\"\nimport {Animated, Pressable, Text, View} from \"react-native\"\nimport {shapeComponent, ShapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport {useBreakpoint} from \"responsive-breakpoints\"\n\n/**\n * @typedef {object} StoredNotificationType\n * @property {number} count\n * @property {import(\"react-native\").Animated.Value} height\n * @property {import(\"react-native\").Animated.Value} marginBottom\n * @property {number | undefined} measuredHeight\n * @property {string} message\n * @property {import(\"react-native\").Animated.Value} opacity\n * @property {boolean} removing\n * @property {ReturnType<typeof setTimeout>} timeout\n * @property {string} title\n * @property {string} type\n */\n\n/**\n * @typedef {object} FlashNotificationsNotificationProps\n * @property {string=} className\n * @property {number} count\n * @property {string} message\n * @property {StoredNotificationType} notification\n * @property {(notification: StoredNotificationType, measuredHeight: number) => void} onMeasured\n * @property {(notification: StoredNotificationType) => void} onRemovedClicked\n * @property {string} title\n * @property {string} type\n */\n\n/** @type {Record<string, object>} */\nconst dataSets = {}\n/** @type {Record<string, import(\"react-native\").ViewStyle>} */\nconst viewStyles = {}\n/** @type {Record<string, import(\"react-native\").TextStyle>} */\nconst textStyles = {}\n\n/**\n * @augments {ShapeComponent<FlashNotificationsNotificationProps>}\n */\nclass FlashNotificationsNotification extends ShapeComponent {\n  static propTypes = PropTypesExact({\n    className: PropTypes.string,\n    count: PropTypes.number.isRequired,\n    message: PropTypes.string.isRequired,\n    notification: PropTypes.object.isRequired,\n    onMeasured: PropTypes.func.isRequired,\n    onRemovedClicked: PropTypes.func.isRequired,\n    title: PropTypes.string.isRequired,\n    type: PropTypes.string.isRequired\n  })\n\n  render() {\n    const {count, message, title, type} = this.p\n    const {className} = this.props\n    const breakpoint = useBreakpoint()\n\n    const pressableDataSet = useMemo(\n      () => ({\n        class: className,\n        role: \"dialog\",\n        type\n      }),\n      [className, type]\n    )\n    return (\n      <Animated.View style={this.tt.wrapperStyle}>\n        <Pressable\n          // @ts-expect-error React Native types do not include the web-only dataSet prop.\n          dataSet={pressableDataSet}\n          onLayout={this.tt.onLayout}\n          onPress={this.tt.onRemovedClicked}\n          style={breakpoint.styling({\n            base: {\n              padding: 15,\n              borderRadius: 11,\n              cursor: \"pointer\",\n              border: (() => {\n                if (type == \"error\") {\n                  return \"1px solid rgba(161, 34, 32, 0.95)\"\n                } else if (type == \"success\") {\n                  return \"1px solid rgba(0, 0, 0, 0.95)\"\n                } else if (type == \"alert\") {\n                  return \"1px solid rgba(204, 51, 0, 0.95)\"\n                }\n\n                return undefined\n              })(),\n              backgroundColor: (() => {\n                if (type == \"error\") {\n                  return \"rgba(161, 34, 32, 0.87)\"\n                } else if (type == \"success\") {\n                  return \"rgba(0, 0, 0, 0.87)\"\n                } else if (type == \"alert\") {\n                  return \"rgba(204, 51, 0, 0.87)\"\n                }\n\n                return undefined\n              })()\n            },\n            smDown: {\n              width: \"100%\"\n            },\n            mdUp: {\n              width: 300,\n              maxWidth: \"100%\"\n            }\n          })}\n          testID=\"flash-notifications-notification\"\n        >\n          <View\n            style={viewStyles.titleView ||= {marginBottom: 5}}\n            testID=\"notification-title\"\n          >\n            <Text\n              style={textStyles.titleText ||= {\n                color: \"#fff\",\n                fontWeight: 700\n              }}\n              testID={`flash-notifications/notification-${count}/title`}\n            >\n              {title}\n            </Text>\n          </View>\n          <View\n            // @ts-expect-error React Native types do not include the web-only dataSet prop.\n            dataSet={dataSets[`notificationMessage-${count}`] ||= {count: `${count}`}}\n            testID=\"notification-message\"\n          >\n            <Text\n              style={textStyles.messageText ||= {color: \"#fff\"}}\n              testID={`flash-notifications/notification-${count}/message`}\n            >\n              {message}\n            </Text>\n          </View>\n        </Pressable>\n      </Animated.View>\n    )\n  }\n\n  get wrapperStyle() {\n    const {notification} = this.p\n\n    return /** @type {import(\"react-native\").Animated.WithAnimatedObject<import(\"react-native\").ViewStyle>} */ ({\n      height: notification.measuredHeight ? notification.height : undefined,\n      marginBottom: notification.marginBottom,\n      opacity: notification.opacity,\n      overflow: \"hidden\"\n    })\n  }\n\n  onRemovedClicked = () => this.p.onRemovedClicked(this.p.notification)\n\n  /**\n   * @param {import(\"react-native\").LayoutChangeEvent} event\n   * @returns {void}\n   */\n  onLayout = (event) => {\n    const {notification} = this.p\n\n    if (!notification.measuredHeight) {\n      this.p.onMeasured(notification, event.nativeEvent.layout.height)\n    }\n  }\n}\n\nexport default memo(shapeComponent(FlashNotificationsNotification))\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"flash-notifications.d.ts","sourceRoot":"/src/","sources":["flash-notifications.js"],"names":[],"mappings":"AAOA;IACE;;;OAGG;IACH,sBAHW,MAAM,GACJ,IAAI,CAIhB;IAED;;;OAGG;IACH,sBAHW,MAAM,GACJ,IAAI,CAIhB;IAED;;;OAGG;IACH,4BAHW,OAAO,GACL,IAAI,CA+ChB;IAED;;;OAGG;IACH,wBAHW,MAAM,GACJ,IAAI,CAIhB;IAED;;;;;OAKG;IACH,kBAJG;QAAqB,IAAI,EAAjB,MAAM;QACO,IAAI,EAAjB,MAAM;KACd,GAAU,IAAI,CAoBhB;CACF"}
1
+ {"version":3,"file":"flash-notifications.d.ts","sourceRoot":"/src/","sources":["flash-notifications.js"],"names":[],"mappings":"AAOA;IACE;;;OAGG;IACH,sBAHW,MAAM,GACJ,IAAI,CAIhB;IAED;;;OAGG;IACH,sBAHW,MAAM,GACJ,IAAI,CAIhB;IAED;;;OAGG;IACH,4BAHW,OAAO,GACL,IAAI,CAmDhB;IAED;;;OAGG;IACH,wBAHW,MAAM,GACJ,IAAI,CAIhB;IAED;;;;;OAKG;IACH,kBAJG;QAAqB,IAAI,EAAjB,MAAM;QACO,IAAI,EAAjB,MAAM;KACd,GAAU,IAAI,CAoBhB;CACF"}
@@ -42,8 +42,9 @@ export default class FlashNotifications {
42
42
  }
43
43
  else if (error.apiMakerType == "BaseError") {
44
44
  // @ts-expect-error
45
- if (error.args.response && error.args.response.errors) {
46
- const errors = /** @type {Array<string | {message: string}[]>} */ (digg(error, "args", "response", "errors"));
45
+ const response = error.args && error.args.response;
46
+ const errors = /** @type {Array<string | {message: string}[]> | undefined} */ (response && response.errors);
47
+ if (errors) {
47
48
  const errorMessages = errors.map((error) => {
48
49
  if (typeof error == "string") {
49
50
  return error;
@@ -52,8 +53,11 @@ export default class FlashNotifications {
52
53
  });
53
54
  FlashNotifications.error(errorMessages.join(". "));
54
55
  }
56
+ else if (error.message) {
57
+ FlashNotifications.error(error.message);
58
+ }
55
59
  else {
56
- throw error;
60
+ FlashNotifications.error(configuration.translate("js.shared.something_went_wrong", { defaultValue: "Something went wrong." }));
57
61
  }
58
62
  }
59
63
  else {
@@ -98,4 +102,4 @@ export default class FlashNotifications {
98
102
  });
99
103
  }
100
104
  }
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flash-notifications.js","sourceRoot":"/src/","sources":["flash-notifications.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ,OAAO,EAAC,IAAI,EAAC,MAAM,WAAW,CAAA;AAE9B,OAAO,aAAa,MAAM,oBAAoB,CAAA;AAC9C,OAAO,MAAM,MAAM,aAAa,CAAA;AAEhC,MAAM,CAAC,OAAO,OAAO,kBAAkB;IACrC;;;OAGG;IACH,MAAM,CAAC,KAAK,CAAC,OAAO;QAClB,kBAAkB,CAAC,IAAI,CAAC,EAAC,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAC,CAAC,CAAA;IACzD,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,KAAK,CAAC,OAAO;QAClB,kBAAkB,CAAC,IAAI,CAAC,EAAC,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAC,CAAC,CAAA;IACzD,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,aAAa,CAAC,KAAK;QACxB,IAAI,CAAC,CAAC,KAAK,YAAY,KAAK,CAAC,EAAE,CAAC;YAC9B,kBAAkB,CAAC,KAAK,CAAC,OAAO,KAAK,IAAI,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;YAE1E,OAAM;QACR,CAAC;QAED,mBAAmB;QACnB,IAAI,KAAK,CAAC,YAAY,IAAI,iBAAiB,EAAE,CAAC;YAC5C,mBAAmB;YACnB,IAAI,KAAK,CAAC,kBAAkB,EAAE,EAAE,CAAC;gBAC/B,mBAAmB;gBACnB,MAAM,sBAAsB,GAAG,KAAK,CAAC,kBAAkB,EAAE,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,oBAAoB,EAAE,CAAC,CAAC,IAAI,EAAE,CAAA;gBAEnH,kBAAkB,CAAC,KAAK,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;YAC7D,CAAC;iBAAM,CAAC;gBACN,MAAM,YAAY,GAAG,+CAA+C,CAAA;gBAEpE,kBAAkB,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,CAAC,6DAA6D,EAAE,EAAC,YAAY,EAAC,CAAC,CAAC,CAAA;YAClI,CAAC;YACH,mBAAmB;QACnB,CAAC;aAAM,IAAI,KAAK,CAAC,YAAY,IAAI,WAAW,EAAE,CAAC;YAC7C,mBAAmB;YACnB,IAAI,KAAK,CAAC,IAAI,CAAC,QAAQ,IAAI,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;gBACtD,MAAM,MAAM,GAAG,kDAAkD,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAA;gBAC7G,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;oBACzC,IAAI,OAAO,KAAK,IAAI,QAAQ,EAAE,CAAC;wBAC7B,OAAO,KAAK,CAAA;oBACd,CAAC;oBAED,OAAO,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;gBAC/B,CAAC,CAAC,CAAA;gBAEF,kBAAkB,CAAC,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;YACpD,CAAC;iBAAM,CAAC;gBACN,MAAM,KAAK,CAAA;YACb,CAAC;QACH,CAAC;aAAM,CAAC;YACN,MAAM,eAAe,GAAG,IAAI,CAAC,KAAK,EAAE,aAAa,EAAE,MAAM,CAAC,CAAA;YAC1D,MAAM,mBAAmB,GAAG,aAAa,CAAC,SAAS,CAAC,gCAAgC,EAAE,EAAC,YAAY,EAAE,uBAAuB,EAAC,CAAC,CAAA;YAC9H,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;YAEtC,OAAO,CAAC,KAAK,CAAC,mCAAmC,eAAe,KAAK,OAAO,EAAE,CAAC,CAAA;YAC/E,kBAAkB,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAA;QAC/C,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,OAAO,CAAC,OAAO;QACpB,kBAAkB,CAAC,IAAI,CAAC,EAAC,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAC,CAAC,CAAA;IAC3D,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,IAAI,CAAC,IAAI;QACd,IAAI,KAAK,CAAA;QAET,IAAI,IAAI,CAAC,IAAI,IAAI,OAAO,EAAE,CAAC;YACzB,KAAK,GAAG,aAAa,CAAC,SAAS,CAAC,iBAAiB,EAAE,EAAC,YAAY,EAAE,OAAO,EAAC,CAAC,CAAA;QAC7E,CAAC;aAAM,IAAI,IAAI,CAAC,IAAI,IAAI,OAAO,EAAE,CAAC;YAChC,KAAK,GAAG,aAAa,CAAC,SAAS,CAAC,iBAAiB,EAAE,EAAC,YAAY,EAAE,OAAO,EAAC,CAAC,CAAA;QAC7E,CAAC;aAAM,IAAI,IAAI,CAAC,IAAI,IAAI,SAAS,EAAE,CAAC;YAClC,KAAK,GAAG,aAAa,CAAC,SAAS,CAAC,mBAAmB,EAAE,EAAC,YAAY,EAAE,SAAS,EAAC,CAAC,CAAA;QACjF,CAAC;aAAM,CAAC;YACN,KAAK,GAAG,aAAa,CAAC,SAAS,CAAC,wBAAwB,EAAE,EAAC,YAAY,EAAE,cAAc,EAAC,CAAC,CAAA;QAC3F,CAAC;QAED,MAAM,CAAC,IAAI,CAAC,kBAAkB,EAAE;YAC9B,OAAO,EAAE,IAAI,CAAC,IAAI;YAClB,KAAK;YACL,IAAI,EAAE,IAAI,CAAC,IAAI;SAChB,CAAC,CAAA;IACJ,CAAC;CACF","sourcesContent":["// @ts-check\n\nimport {digg} from \"diggerize\"\n\nimport configuration from \"./configuration.js\"\nimport events from \"./events.js\"\n\nexport default class FlashNotifications {\n  /**\n   * @param {string} message\n   * @returns {void}\n   */\n  static alert(message) {\n    FlashNotifications.show({type: \"alert\", text: message})\n  }\n\n  /**\n   * @param {string} message\n   * @returns {void}\n   */\n  static error(message) {\n    FlashNotifications.show({type: \"error\", text: message})\n  }\n\n  /**\n   * @param {unknown} error\n   * @returns {void}\n   */\n  static errorResponse(error) {\n    if (!(error instanceof Error)) {\n      FlashNotifications.error(typeof error == \"string\" ? error : String(error))\n\n      return\n    }\n\n    // @ts-expect-error\n    if (error.apiMakerType == \"ValidationError\") {\n      // @ts-expect-error\n      if (error.hasUnhandledErrors()) {\n        // @ts-expect-error\n        const unhandledErrorMessages = error.getUnhandledErrors().map((subError) => subError.getFullErrorMessages()).flat()\n\n        FlashNotifications.error(unhandledErrorMessages.join(\". \"))\n      } else {\n        const defaultValue = \"Couldn't submit because of validation errors.\"\n\n        FlashNotifications.alert(configuration.translate(\"js.notification.couldnt_submit_because_of_validation_errors\", {defaultValue}))\n      }\n    // @ts-expect-error\n    } else if (error.apiMakerType == \"BaseError\") {\n      // @ts-expect-error\n      if (error.args.response && error.args.response.errors) {\n        const errors = /** @type {Array<string | {message: string}[]>} */ (digg(error, \"args\", \"response\", \"errors\"))\n        const errorMessages = errors.map((error) => {\n          if (typeof error == \"string\") {\n            return error\n          }\n\n          return digg(error, \"message\")\n        })\n\n        FlashNotifications.error(errorMessages.join(\". \"))\n      } else {\n        throw error\n      }\n    } else {\n      const constructorName = digg(error, \"constructor\", \"name\")\n      const defaultErrorMessage = configuration.translate(\"js.shared.something_went_wrong\", {defaultValue: \"Something went wrong.\"})\n      const message = digg(error, \"message\")\n\n      console.error(`Didnt know what to do with that ${constructorName}: ${message}`)\n      FlashNotifications.error(defaultErrorMessage)\n    }\n  }\n\n  /**\n   * @param {string} message\n   * @returns {void}\n   */\n  static success(message) {\n    FlashNotifications.show({type: \"success\", text: message})\n  }\n\n  /**\n   * @param {object} args\n   * @param {string} args.text\n   * @param {string} args.type\n   * @returns {void}\n   */\n  static show(args) {\n    let title\n\n    if (args.type == \"alert\") {\n      title = configuration.translate(\"js.shared.alert\", {defaultValue: \"Alert\"})\n    } else if (args.type == \"error\") {\n      title = configuration.translate(\"js.shared.error\", {defaultValue: \"Error\"})\n    } else if (args.type == \"success\") {\n      title = configuration.translate(\"js.shared.success\", {defaultValue: \"Success\"})\n    } else {\n      title = configuration.translate(\"js.shared.notification\", {defaultValue: \"Notification\"})\n    }\n\n    events.emit(\"pushNotification\", {\n      message: args.text,\n      title,\n      type: args.type\n    })\n  }\n}\n"]}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flash-notifications.js","sourceRoot":"/src/","sources":["flash-notifications.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {digg} from \"diggerize\"\n\nimport configuration from \"./configuration.js\"\nimport events from \"./events.js\"\n\nexport default class FlashNotifications {\n  /**\n   * @param {string} message\n   * @returns {void}\n   */\n  static alert(message) {\n    FlashNotifications.show({type: \"alert\", text: message})\n  }\n\n  /**\n   * @param {string} message\n   * @returns {void}\n   */\n  static error(message) {\n    FlashNotifications.show({type: \"error\", text: message})\n  }\n\n  /**\n   * @param {unknown} error\n   * @returns {void}\n   */\n  static errorResponse(error) {\n    if (!(error instanceof Error)) {\n      FlashNotifications.error(typeof error == \"string\" ? error : String(error))\n\n      return\n    }\n\n    // @ts-expect-error\n    if (error.apiMakerType == \"ValidationError\") {\n      // @ts-expect-error\n      if (error.hasUnhandledErrors()) {\n        // @ts-expect-error\n        const unhandledErrorMessages = error.getUnhandledErrors().map((subError) => subError.getFullErrorMessages()).flat()\n\n        FlashNotifications.error(unhandledErrorMessages.join(\". \"))\n      } else {\n        const defaultValue = \"Couldn't submit because of validation errors.\"\n\n        FlashNotifications.alert(configuration.translate(\"js.notification.couldnt_submit_because_of_validation_errors\", {defaultValue}))\n      }\n    // @ts-expect-error\n    } else if (error.apiMakerType == \"BaseError\") {\n      // @ts-expect-error\n      const response = error.args && error.args.response\n      const errors = /** @type {Array<string | {message: string}[]> | undefined} */ (response && response.errors)\n\n      if (errors) {\n        const errorMessages = errors.map((error) => {\n          if (typeof error == \"string\") {\n            return error\n          }\n\n          return digg(error, \"message\")\n        })\n\n        FlashNotifications.error(errorMessages.join(\". \"))\n      } else if (error.message) {\n        FlashNotifications.error(error.message)\n      } else {\n        FlashNotifications.error(configuration.translate(\"js.shared.something_went_wrong\", {defaultValue: \"Something went wrong.\"}))\n      }\n    } else {\n      const constructorName = digg(error, \"constructor\", \"name\")\n      const defaultErrorMessage = configuration.translate(\"js.shared.something_went_wrong\", {defaultValue: \"Something went wrong.\"})\n      const message = digg(error, \"message\")\n\n      console.error(`Didnt know what to do with that ${constructorName}: ${message}`)\n      FlashNotifications.error(defaultErrorMessage)\n    }\n  }\n\n  /**\n   * @param {string} message\n   * @returns {void}\n   */\n  static success(message) {\n    FlashNotifications.show({type: \"success\", text: message})\n  }\n\n  /**\n   * @param {object} args\n   * @param {string} args.text\n   * @param {string} args.type\n   * @returns {void}\n   */\n  static show(args) {\n    let title\n\n    if (args.type == \"alert\") {\n      title = configuration.translate(\"js.shared.alert\", {defaultValue: \"Alert\"})\n    } else if (args.type == \"error\") {\n      title = configuration.translate(\"js.shared.error\", {defaultValue: \"Error\"})\n    } else if (args.type == \"success\") {\n      title = configuration.translate(\"js.shared.success\", {defaultValue: \"Success\"})\n    } else {\n      title = configuration.translate(\"js.shared.notification\", {defaultValue: \"Notification\"})\n    }\n\n    events.emit(\"pushNotification\", {\n      message: args.text,\n      title,\n      type: args.type\n    })\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "flash-notifications",
3
- "version": "0.0.41",
3
+ "version": "0.0.44",
4
4
  "description": "My new module",
5
5
  "main": "build/index.js",
6
6
  "types": "build/index.d.ts",
@@ -12,6 +12,7 @@
12
12
  "clean": "expo-module clean",
13
13
  "export:web": "cd example && npm install && cd .. && npm run prepare:dummy && cd example && npx expo export -p web --output-dir dist",
14
14
  "lint": "expo-module lint -- --max-warnings 0",
15
+ "prepare": "npm run build",
15
16
  "prepare:module": "expo-module prepare",
16
17
  "test": "node scripts/velocious-test.js",
17
18
  "typecheck": "expo-module build",
@@ -20,7 +21,7 @@
20
21
  "expo-module": "expo-module",
21
22
  "open:ios": "xed example/ios",
22
23
  "open:android": "open -a \"Android Studio\" example/android",
23
- "release:patch": "npm version patch -m \"Bump version to %s\" && git push --follow-tags && npm whoami || npm login && npm publish"
24
+ "release:patch": "git checkout master && git fetch origin && git merge --ff-only origin/master && npm version patch -m \"Bump version to %s\" && git push --follow-tags && npm whoami || npm login && npm publish"
24
25
  },
25
26
  "keywords": [
26
27
  "react-native",
@@ -42,7 +43,7 @@
42
43
  "eventemitter3": "^5.0.1",
43
44
  "fetching-object": "^1.0.3",
44
45
  "prop-types-exact": "*",
45
- "responsive-breakpoints": "^0.1.3",
46
+ "responsive-breakpoints": "^0.1.5",
46
47
  "ya-use-event-emitter": "^0.1.2"
47
48
  },
48
49
  "devDependencies": {
@@ -55,14 +56,14 @@
55
56
  "globals": "^16.4.0",
56
57
  "react-native": "~0.76.9",
57
58
  "selenium-webdriver": "^4.35.0",
58
- "system-testing": "^1.0.62",
59
+ "system-testing": "^1.0.101",
59
60
  "velocious": "^1.0.183"
60
61
  },
61
62
  "peerDependencies": {
62
63
  "expo": "*",
63
64
  "react": "*",
64
65
  "react-native": "*",
65
- "set-state-compare": ">= 1.0.67"
66
+ "set-state-compare": "^1.0.84"
66
67
  },
67
68
  "packageManager": "yarn@1.22.22+sha512.a6b2f7906b721bba3d67d4aff083df04dad64c399707841b7acf00f6b133b7ac24255f2652fa22ae3534329dc6180534e98d17432037ff6fd140556e2bb3137e"
68
69
  }