flash-notifications 0.0.38 → 0.0.40
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.
- package/README.md +66 -1
- package/build/container/index.d.ts +12 -0
- package/build/container/index.d.ts.map +1 -1
- package/build/container/index.js +50 -8
- package/build/container/notification.d.ts.map +1 -1
- package/build/container/notification.js +5 -2
- package/build/flash-notifications.d.ts +2 -2
- package/build/flash-notifications.d.ts.map +1 -1
- package/build/flash-notifications.js +11 -4
- package/build/listener.d.ts.map +1 -1
- package/package.json +17 -10
- package/.eslintrc.js +0 -12
- package/AGENTS.md +0 -3
- package/CHANGELOG.md +0 -10
- package/android/build.gradle +0 -43
- package/android/src/main/AndroidManifest.xml +0 -2
- package/android/src/main/java/expo/modules/flashnotifications/FlashNotificationsModule.kt +0 -50
- package/android/src/main/java/expo/modules/flashnotifications/FlashNotificationsView.kt +0 -30
- package/expo-module.config.json +0 -17
- package/ios/FlashNotifications.podspec +0 -29
- package/ios/FlashNotificationsModule.swift +0 -48
- package/ios/FlashNotificationsView.swift +0 -38
- package/peak_flow.yml +0 -5
- package/scripts/velocious-test.js +0 -186
- package/spec/flash-notifications-spec.js +0 -46
- package/spec/support/dummy-http-server.js +0 -52
- package/spec/support/system-test-helper.js +0 -99
- package/src/configuration.js +0 -10
- package/src/container/index.jsx +0 -214
- package/src/container/notification.jsx +0 -130
- package/src/debug.js +0 -13
- package/src/events.js +0 -7
- package/src/flash-notifications.js +0 -99
- package/src/index.js +0 -15
- package/src/listener.js +0 -56
- package/tsconfig.json +0 -15
package/README.md
CHANGED
|
@@ -12,7 +12,7 @@ For managed Expo projects, ensure your Expo SDK supports this module and follow
|
|
|
12
12
|
|
|
13
13
|
## Setup
|
|
14
14
|
|
|
15
|
-
Render the notification container once near the root of your app.
|
|
15
|
+
Render the notification container once near the root of your app so it can listen for events globally.
|
|
16
16
|
|
|
17
17
|
```jsx
|
|
18
18
|
import React from "react"
|
|
@@ -34,6 +34,17 @@ export default function App() {
|
|
|
34
34
|
}
|
|
35
35
|
```
|
|
36
36
|
|
|
37
|
+
If you are not using safe-area insets, render the container directly:
|
|
38
|
+
|
|
39
|
+
```jsx
|
|
40
|
+
import React from "react"
|
|
41
|
+
import {Container} from "flash-notifications"
|
|
42
|
+
|
|
43
|
+
export default function App() {
|
|
44
|
+
return <Container />
|
|
45
|
+
}
|
|
46
|
+
```
|
|
47
|
+
|
|
37
48
|
## Usage
|
|
38
49
|
|
|
39
50
|
Trigger notifications anywhere in your app with the static helpers.
|
|
@@ -54,6 +65,49 @@ import {FlashNotifications} from "flash-notifications"
|
|
|
54
65
|
FlashNotifications.show({type: "info", text: "Heads up!"})
|
|
55
66
|
```
|
|
56
67
|
|
|
68
|
+
## API
|
|
69
|
+
|
|
70
|
+
### FlashNotifications
|
|
71
|
+
|
|
72
|
+
`FlashNotifications.alert(message)`
|
|
73
|
+
Shows an alert notification with a localized "Alert" title.
|
|
74
|
+
|
|
75
|
+
`FlashNotifications.error(message)`
|
|
76
|
+
Shows an error notification with a localized "Error" title.
|
|
77
|
+
|
|
78
|
+
`FlashNotifications.success(message)`
|
|
79
|
+
Shows a success notification with a localized "Success" title.
|
|
80
|
+
|
|
81
|
+
`FlashNotifications.show({type, text})`
|
|
82
|
+
Shows a notification with a localized title based on `type`. Unknown types fall back to the localized "Notification" title.
|
|
83
|
+
|
|
84
|
+
`FlashNotifications.errorResponse(error)`
|
|
85
|
+
Handles Api Maker validation and base errors, converting them into notifications. Unknown errors are logged and rethrown.
|
|
86
|
+
|
|
87
|
+
Notifications auto-dismiss after 4 seconds and can be dismissed immediately by pressing them.
|
|
88
|
+
|
|
89
|
+
### Container
|
|
90
|
+
|
|
91
|
+
`<Container insets={insets} />`
|
|
92
|
+
Optional `insets` should be an object with `top`, `right`, and `left` values (for example, from `react-native-safe-area-context`). The container positions itself near the top-right on larger screens and spans the width on small screens.
|
|
93
|
+
|
|
94
|
+
## Configuration
|
|
95
|
+
|
|
96
|
+
`configuration.debug`
|
|
97
|
+
When `true`, logs lifecycle events such as add/remove, timeout, measurement, and animation events.
|
|
98
|
+
|
|
99
|
+
`configuration.translate(msgId, {defaultValue})`
|
|
100
|
+
Controls localized titles for built-in types. The default implementation returns `defaultValue` or `msgId`.
|
|
101
|
+
|
|
102
|
+
You can override configuration by mutating the exported object or setting a global before imports:
|
|
103
|
+
|
|
104
|
+
```js
|
|
105
|
+
globalThis.flashNotificationsConfiguration = {
|
|
106
|
+
debug: false,
|
|
107
|
+
translate: (msgId, args) => args?.defaultValue || msgId
|
|
108
|
+
}
|
|
109
|
+
```
|
|
110
|
+
|
|
57
111
|
## Debug mode
|
|
58
112
|
|
|
59
113
|
Enable debug logging by setting the configuration flag at startup.
|
|
@@ -73,5 +127,16 @@ When enabled, the library logs lifecycle events such as notification creation, p
|
|
|
73
127
|
|
|
74
128
|
## Contributing
|
|
75
129
|
|
|
130
|
+
If you need to refresh Expo module generated files locally, run `npm run prepare:module`. Regular `npm install` no longer runs that step automatically.
|
|
131
|
+
|
|
132
|
+
Before opening or updating a PR, run:
|
|
133
|
+
|
|
134
|
+
```sh
|
|
135
|
+
npm run lint
|
|
136
|
+
npm run typecheck
|
|
137
|
+
```
|
|
138
|
+
|
|
139
|
+
The repo's flat ESLint config relies on `react/jsx-uses-vars` so React Native JSX imports are treated as used. If JSX imports such as `View` or `Pressable` start failing `no-unused-vars`, fix the ESLint config rather than rewriting the component render tree.
|
|
140
|
+
|
|
76
141
|
Contributions are welcome. Please refer to the Expo contributing guide:
|
|
77
142
|
https://github.com/expo/expo#contributing
|
|
@@ -6,5 +6,17 @@ export type NotificationObjectType = {
|
|
|
6
6
|
title: string;
|
|
7
7
|
type: string;
|
|
8
8
|
};
|
|
9
|
+
export type StoredNotificationType = {
|
|
10
|
+
count: number;
|
|
11
|
+
height: import("react-native").Animated.Value;
|
|
12
|
+
marginBottom: import("react-native").Animated.Value;
|
|
13
|
+
measuredHeight: number | undefined;
|
|
14
|
+
message: string;
|
|
15
|
+
opacity: import("react-native").Animated.Value;
|
|
16
|
+
removing: boolean;
|
|
17
|
+
timeout: ReturnType<typeof setTimeout>;
|
|
18
|
+
title: string;
|
|
19
|
+
type: string;
|
|
20
|
+
};
|
|
9
21
|
import React from "react";
|
|
10
22
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"/src/","sources":["container/index.jsx"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"/src/","sources":["container/index.jsx"],"names":[],"mappings":";;;WAoBc,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;;kBA/B0B,OAAO"}
|
package/build/container/index.js
CHANGED
|
@@ -1,16 +1,18 @@
|
|
|
1
1
|
// @ts-check
|
|
2
2
|
import { digg } from "diggerize";
|
|
3
3
|
import PropTypes from "prop-types";
|
|
4
|
+
// @ts-expect-error Package ships no .d.ts files.
|
|
4
5
|
import propTypesExact from "prop-types-exact";
|
|
5
6
|
import React, { memo, useEffect, useMemo } from "react";
|
|
6
7
|
import { shapeComponent, ShapeComponent } from "set-state-compare/build/shape-component.js";
|
|
7
|
-
import useBreakpoint from "
|
|
8
|
-
|
|
8
|
+
import { useBreakpoint } from "responsive-breakpoints";
|
|
9
|
+
// @ts-expect-error No published types for this package.
|
|
10
|
+
import useEventEmitter from "ya-use-event-emitter";
|
|
9
11
|
import useEnvSense from "env-sense/build/use-env-sense.js";
|
|
10
12
|
import { Animated, View } from "react-native";
|
|
11
13
|
import debugLog from "../debug.js";
|
|
12
14
|
import events from "../events.js";
|
|
13
|
-
import
|
|
15
|
+
import FlashNotification from "./notification";
|
|
14
16
|
/**
|
|
15
17
|
* @typedef {object} NotificationObjectType
|
|
16
18
|
* @property {number} count
|
|
@@ -18,6 +20,19 @@ import Notification from "./notification";
|
|
|
18
20
|
* @property {string} title
|
|
19
21
|
* @property {string} type
|
|
20
22
|
*/
|
|
23
|
+
/**
|
|
24
|
+
* @typedef {object} StoredNotificationType
|
|
25
|
+
* @property {number} count
|
|
26
|
+
* @property {import("react-native").Animated.Value} height
|
|
27
|
+
* @property {import("react-native").Animated.Value} marginBottom
|
|
28
|
+
* @property {number | undefined} measuredHeight
|
|
29
|
+
* @property {string} message
|
|
30
|
+
* @property {import("react-native").Animated.Value} opacity
|
|
31
|
+
* @property {boolean} removing
|
|
32
|
+
* @property {ReturnType<typeof setTimeout>} timeout
|
|
33
|
+
* @property {string} title
|
|
34
|
+
* @property {string} type
|
|
35
|
+
*/
|
|
21
36
|
export default memo(shapeComponent(class FlashNotificationsContainer extends ShapeComponent {
|
|
22
37
|
static propTypes = propTypesExact({
|
|
23
38
|
insets: PropTypes.object
|
|
@@ -28,6 +43,7 @@ export default memo(shapeComponent(class FlashNotificationsContainer extends Sha
|
|
|
28
43
|
setup() {
|
|
29
44
|
this.useStates({
|
|
30
45
|
count: 0,
|
|
46
|
+
/** @type {StoredNotificationType[]} */
|
|
31
47
|
notifications: []
|
|
32
48
|
});
|
|
33
49
|
useEventEmitter(events, "pushNotification", this.onPushNotification);
|
|
@@ -75,8 +91,10 @@ export default memo(shapeComponent(class FlashNotificationsContainer extends Sha
|
|
|
75
91
|
, {
|
|
76
92
|
// @ts-expect-error
|
|
77
93
|
dataSet: this.rootViewDataSet ||= { component: "flash-notifications-container" },
|
|
78
|
-
// @ts-expect-error
|
|
79
|
-
style: viewStyle, testID: "flash-notificaitons/container" }, notifications.map(
|
|
94
|
+
// @ts-expect-error React Native types do not include the web-only "fixed" position.
|
|
95
|
+
style: viewStyle, testID: "flash-notificaitons/container" }, notifications.map(
|
|
96
|
+
/** @param {StoredNotificationType} notification */
|
|
97
|
+
(notification) => React.createElement(FlashNotification, { count: notification.count, key: `notification-${notification.count}`, message: notification.message, notification: notification, onMeasured: this.onNotificationMeasured, onRemovedClicked: this.onRemovedClicked, title: notification.title, type: notification.type }))));
|
|
80
98
|
}
|
|
81
99
|
/**
|
|
82
100
|
* @param {NotificationObjectType} detail
|
|
@@ -89,6 +107,7 @@ export default memo(shapeComponent(class FlashNotificationsContainer extends Sha
|
|
|
89
107
|
this.dismissNotificationByCount(count, "timeout");
|
|
90
108
|
}, 4000);
|
|
91
109
|
this.timeouts.push(timeout);
|
|
110
|
+
/** @type {StoredNotificationType} */
|
|
92
111
|
const notification = {
|
|
93
112
|
count,
|
|
94
113
|
height: new Animated.Value(0),
|
|
@@ -108,10 +127,19 @@ export default memo(shapeComponent(class FlashNotificationsContainer extends Sha
|
|
|
108
127
|
});
|
|
109
128
|
this.setState({ count, notifications: this.s.notifications.concat([notification]) });
|
|
110
129
|
};
|
|
130
|
+
/**
|
|
131
|
+
* @param {StoredNotificationType} notification
|
|
132
|
+
* @returns {void}
|
|
133
|
+
*/
|
|
111
134
|
onRemovedClicked = (notification) => {
|
|
112
135
|
debugLog("FlashNotifications: notification pressed", { id: notification.count });
|
|
113
136
|
this.dismissNotification(notification, "press");
|
|
114
137
|
};
|
|
138
|
+
/**
|
|
139
|
+
* @param {StoredNotificationType} notification
|
|
140
|
+
* @param {number} measuredHeight
|
|
141
|
+
* @returns {void}
|
|
142
|
+
*/
|
|
115
143
|
onNotificationMeasured = (notification, measuredHeight) => {
|
|
116
144
|
if (notification.measuredHeight)
|
|
117
145
|
return;
|
|
@@ -120,14 +148,26 @@ export default memo(shapeComponent(class FlashNotificationsContainer extends Sha
|
|
|
120
148
|
notification.height.setValue(measuredHeight);
|
|
121
149
|
this.setState({ notifications: [...this.s.notifications] });
|
|
122
150
|
};
|
|
151
|
+
/**
|
|
152
|
+
* @param {number} count
|
|
153
|
+
* @param {string} [reason]
|
|
154
|
+
* @returns {void}
|
|
155
|
+
*/
|
|
123
156
|
dismissNotificationByCount = (count, reason = "unknown") => {
|
|
124
|
-
const notification = this.s.notifications.find(
|
|
157
|
+
const notification = /** @type {StoredNotificationType | undefined} */ (this.s.notifications.find(
|
|
158
|
+
/** @param {StoredNotificationType} item */
|
|
159
|
+
(item) => item.count == count));
|
|
125
160
|
if (!notification) {
|
|
126
161
|
debugLog("FlashNotifications: notification not found", { id: count, reason });
|
|
127
162
|
return;
|
|
128
163
|
}
|
|
129
164
|
this.dismissNotification(notification, reason);
|
|
130
165
|
};
|
|
166
|
+
/**
|
|
167
|
+
* @param {StoredNotificationType} notification
|
|
168
|
+
* @param {string} [reason]
|
|
169
|
+
* @returns {void}
|
|
170
|
+
*/
|
|
131
171
|
dismissNotification = (notification, reason = "unknown") => {
|
|
132
172
|
if (notification.removing) {
|
|
133
173
|
debugLog("FlashNotifications: notification already removing", { id: notification.count, reason });
|
|
@@ -161,10 +201,12 @@ export default memo(shapeComponent(class FlashNotificationsContainer extends Sha
|
|
|
161
201
|
});
|
|
162
202
|
debugLog("FlashNotifications: fade animation end", { id: notification.count, reason });
|
|
163
203
|
this.setState({
|
|
164
|
-
notifications: this.s.notifications.filter(
|
|
204
|
+
notifications: this.s.notifications.filter(
|
|
205
|
+
/** @param {StoredNotificationType} item */
|
|
206
|
+
(item) => item.count != notification.count)
|
|
165
207
|
});
|
|
166
208
|
debugLog("FlashNotifications: notification removed", { id: notification.count, reason });
|
|
167
209
|
});
|
|
168
210
|
};
|
|
169
211
|
}));
|
|
170
|
-
//# 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\"\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 \"@kaspernj/api-maker/build/use-breakpoint.js\"\nimport useEventEmitter from \"@kaspernj/api-maker/build/use-event-emitter.js\"\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 Notification 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\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      notifications: []\n    })\n\n    useEventEmitter(events, \"pushNotification\", this.onPushNotification)\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\n        style={viewStyle}\n        testID=\"flash-notificaitons/container\"\n      >\n        {notifications.map((notification) =>\n          <Notification\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 {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    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  onRemovedClicked = (notification) => {\n    debugLog(\"FlashNotifications: notification pressed\", {id: notification.count})\n    this.dismissNotification(notification, \"press\")\n  }\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  dismissNotificationByCount = (count, reason = \"unknown\") => {\n    const notification = this.s.notifications.find((item) => item.count == count)\n    if (!notification) {\n      debugLog(\"FlashNotifications: notification not found\", {id: count, reason})\n      return\n    }\n\n    this.dismissNotification(notification, reason)\n  }\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((item) => item.count != notification.count)\n      })\n\n      debugLog(\"FlashNotifications: notification removed\", {id: notification.count, reason})\n    })\n  }\n}))\n"]}
|
|
212
|
+
//# 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\"\n// @ts-expect-error No published types for this package.\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.onPushNotification)\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 {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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"notification.d.ts","sourceRoot":"/src/","sources":["container/notification.jsx"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"notification.d.ts","sourceRoot":"/src/","sources":["container/notification.jsx"],"names":[],"mappings":";;kBAGmC,OAAO"}
|
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
import PropTypes from "prop-types";
|
|
2
|
+
// @ts-expect-error Package ships no .d.ts files.
|
|
2
3
|
import PropTypesExact from "prop-types-exact";
|
|
3
4
|
import React, { memo, useMemo } from "react";
|
|
4
5
|
import { Animated, Pressable, Text, View } from "react-native";
|
|
5
6
|
import { shapeComponent, ShapeComponent } from "set-state-compare/build/shape-component.js";
|
|
6
|
-
import useBreakpoint from "
|
|
7
|
+
import { useBreakpoint } from "responsive-breakpoints";
|
|
8
|
+
/** @type {Record<string, object>} */
|
|
7
9
|
const dataSets = {};
|
|
10
|
+
/** @type {Record<string, object>} */
|
|
8
11
|
const styles = {};
|
|
9
12
|
export default memo(shapeComponent(class FlashNotificationsNotification extends ShapeComponent {
|
|
10
13
|
static propTypes = PropTypesExact({
|
|
@@ -92,4 +95,4 @@ export default memo(shapeComponent(class FlashNotificationsNotification extends
|
|
|
92
95
|
}
|
|
93
96
|
};
|
|
94
97
|
}));
|
|
95
|
-
//# 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\"\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 \"@kaspernj/api-maker/build/use-breakpoint.js\"\n\nconst dataSets = {}\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"]}
|
|
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"]}
|
|
@@ -10,10 +10,10 @@ export default class FlashNotifications {
|
|
|
10
10
|
*/
|
|
11
11
|
static error(message: string): void;
|
|
12
12
|
/**
|
|
13
|
-
* @param {
|
|
13
|
+
* @param {unknown} error
|
|
14
14
|
* @returns {void}
|
|
15
15
|
*/
|
|
16
|
-
static errorResponse(error:
|
|
16
|
+
static errorResponse(error: unknown): void;
|
|
17
17
|
/**
|
|
18
18
|
* @param {string} message
|
|
19
19
|
* @returns {void}
|
|
@@ -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,
|
|
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"}
|
|
@@ -18,10 +18,14 @@ export default class FlashNotifications {
|
|
|
18
18
|
FlashNotifications.show({ type: "error", text: message });
|
|
19
19
|
}
|
|
20
20
|
/**
|
|
21
|
-
* @param {
|
|
21
|
+
* @param {unknown} error
|
|
22
22
|
* @returns {void}
|
|
23
23
|
*/
|
|
24
24
|
static errorResponse(error) {
|
|
25
|
+
if (!(error instanceof Error)) {
|
|
26
|
+
FlashNotifications.error(typeof error == "string" ? error : String(error));
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
25
29
|
// @ts-expect-error
|
|
26
30
|
if (error.apiMakerType == "ValidationError") {
|
|
27
31
|
// @ts-expect-error
|
|
@@ -53,8 +57,11 @@ export default class FlashNotifications {
|
|
|
53
57
|
}
|
|
54
58
|
}
|
|
55
59
|
else {
|
|
56
|
-
|
|
57
|
-
|
|
60
|
+
const constructorName = digg(error, "constructor", "name");
|
|
61
|
+
const defaultErrorMessage = configuration.translate("js.shared.something_went_wrong", { defaultValue: "Something went wrong." });
|
|
62
|
+
const message = digg(error, "message");
|
|
63
|
+
console.error(`Didnt know what to do with that ${constructorName}: ${message}`);
|
|
64
|
+
FlashNotifications.error(defaultErrorMessage);
|
|
58
65
|
}
|
|
59
66
|
}
|
|
60
67
|
/**
|
|
@@ -91,4 +98,4 @@ export default class FlashNotifications {
|
|
|
91
98
|
});
|
|
92
99
|
}
|
|
93
100
|
}
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# 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      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"]}
|
package/build/listener.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"listener.d.ts","sourceRoot":"/src/","sources":["listener.js"],"names":[],"mappings":"AAEA;IAGE,sBAQC;IAVD,qBAAkB;IAYlB,2BAEC;IAED,+BA+BC;IAED,
|
|
1
|
+
{"version":3,"file":"listener.d.ts","sourceRoot":"/src/","sources":["listener.js"],"names":[],"mappings":"AAEA;IAGE,sBAQC;IAVD,qBAAkB;IAYlB,2BAEC;IAED,+BA+BC;IAED,qBAAsB,iBAAY,UAEjC;CACF"}
|
package/package.json
CHANGED
|
@@ -1,18 +1,22 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "flash-notifications",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.40",
|
|
4
4
|
"description": "My new module",
|
|
5
5
|
"main": "build/index.js",
|
|
6
6
|
"types": "build/index.d.ts",
|
|
7
|
+
"files": [
|
|
8
|
+
"build"
|
|
9
|
+
],
|
|
7
10
|
"scripts": {
|
|
8
11
|
"build": "expo-module build",
|
|
9
12
|
"clean": "expo-module clean",
|
|
10
13
|
"export:web": "cd example && npm install && cd .. && npm run prepare:dummy && cd example && npx expo export -p web --output-dir dist",
|
|
11
14
|
"lint": "expo-module lint -- --max-warnings 0",
|
|
15
|
+
"prepare:module": "expo-module prepare",
|
|
12
16
|
"test": "node scripts/velocious-test.js",
|
|
13
|
-
"
|
|
17
|
+
"typecheck": "expo-module build",
|
|
14
18
|
"prepare:dummy": "npm run build && rm -rf example/node_modules/flash-notifications && mkdir -p example/node_modules/flash-notifications && cp -r build package.json example/node_modules/flash-notifications/",
|
|
15
|
-
"prepublishOnly": "expo-module prepublishOnly",
|
|
19
|
+
"prepublishOnly": "npm run prepare:module && expo-module prepublishOnly",
|
|
16
20
|
"expo-module": "expo-module",
|
|
17
21
|
"open:ios": "xed example/ios",
|
|
18
22
|
"open:android": "open -a \"Android Studio\" example/android",
|
|
@@ -37,21 +41,24 @@
|
|
|
37
41
|
"env-sense": "^1.0.2",
|
|
38
42
|
"eventemitter3": "^5.0.1",
|
|
39
43
|
"fetching-object": "^1.0.3",
|
|
40
|
-
"prop-types-exact": "*"
|
|
44
|
+
"prop-types-exact": "*",
|
|
45
|
+
"responsive-breakpoints": "^0.1.3",
|
|
46
|
+
"ya-use-event-emitter": "^0.1.1"
|
|
41
47
|
},
|
|
42
48
|
"devDependencies": {
|
|
49
|
+
"@eslint/js": "^9.39.4",
|
|
43
50
|
"@types/react": "~18.3.12",
|
|
44
|
-
"eslint": "^
|
|
45
|
-
"eslint-
|
|
46
|
-
"expo": "~
|
|
51
|
+
"eslint": "^9.39.1",
|
|
52
|
+
"eslint-plugin-react": "^7.37.5",
|
|
53
|
+
"expo": "~55.0.5",
|
|
47
54
|
"expo-module-scripts": "^4.0.2",
|
|
55
|
+
"globals": "^16.4.0",
|
|
48
56
|
"react-native": "~0.76.9",
|
|
49
57
|
"selenium-webdriver": "^4.35.0",
|
|
50
|
-
"system-testing": "^1.0.
|
|
51
|
-
"velocious": "^1.0.
|
|
58
|
+
"system-testing": "^1.0.62",
|
|
59
|
+
"velocious": "^1.0.183"
|
|
52
60
|
},
|
|
53
61
|
"peerDependencies": {
|
|
54
|
-
"@kaspernj/api-maker": ">= 1.0.2058",
|
|
55
62
|
"expo": "*",
|
|
56
63
|
"react": "*",
|
|
57
64
|
"react-native": "*",
|
package/.eslintrc.js
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
module.exports = {
|
|
2
|
-
root: true,
|
|
3
|
-
extends: ['universe/native', 'universe/web'],
|
|
4
|
-
ignorePatterns: ['build'],
|
|
5
|
-
rules: {
|
|
6
|
-
"eqeqeq": "off",
|
|
7
|
-
"no-return-assign": "off",
|
|
8
|
-
"prettier/prettier": "off",
|
|
9
|
-
"react-hooks/rules-of-hooks": "off",
|
|
10
|
-
"import/order": "off"
|
|
11
|
-
}
|
|
12
|
-
}
|
package/AGENTS.md
DELETED
package/CHANGELOG.md
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
# Changelog
|
|
2
|
-
|
|
3
|
-
## Unreleased
|
|
4
|
-
- Add optional debug logging for notification lifecycle events.
|
|
5
|
-
- Speed up dismiss animations when notifications are pressed.
|
|
6
|
-
- Add notification count dataSet to message container for test hooks.
|
|
7
|
-
- Replace StyleSheet usage with inline style objects for notifications.
|
|
8
|
-
- Cache inline notification style objects and use numeric font weights.
|
|
9
|
-
- Inline cached style assignments directly in notification JSX.
|
|
10
|
-
- Build pressable styles with a single cached inline object.
|
package/android/build.gradle
DELETED
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
apply plugin: 'com.android.library'
|
|
2
|
-
|
|
3
|
-
group = 'expo.modules.flashnotifications'
|
|
4
|
-
version = '0.1.0'
|
|
5
|
-
|
|
6
|
-
def expoModulesCorePlugin = new File(project(":expo-modules-core").projectDir.absolutePath, "ExpoModulesCorePlugin.gradle")
|
|
7
|
-
apply from: expoModulesCorePlugin
|
|
8
|
-
applyKotlinExpoModulesCorePlugin()
|
|
9
|
-
useCoreDependencies()
|
|
10
|
-
useExpoPublishing()
|
|
11
|
-
|
|
12
|
-
// If you want to use the managed Android SDK versions from expo-modules-core, set this to true.
|
|
13
|
-
// The Android SDK versions will be bumped from time to time in SDK releases and may introduce breaking changes in your module code.
|
|
14
|
-
// Most of the time, you may like to manage the Android SDK versions yourself.
|
|
15
|
-
def useManagedAndroidSdkVersions = false
|
|
16
|
-
if (useManagedAndroidSdkVersions) {
|
|
17
|
-
useDefaultAndroidSdkVersions()
|
|
18
|
-
} else {
|
|
19
|
-
buildscript {
|
|
20
|
-
// Simple helper that allows the root project to override versions declared by this library.
|
|
21
|
-
ext.safeExtGet = { prop, fallback ->
|
|
22
|
-
rootProject.ext.has(prop) ? rootProject.ext.get(prop) : fallback
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
project.android {
|
|
26
|
-
compileSdkVersion safeExtGet("compileSdkVersion", 34)
|
|
27
|
-
defaultConfig {
|
|
28
|
-
minSdkVersion safeExtGet("minSdkVersion", 21)
|
|
29
|
-
targetSdkVersion safeExtGet("targetSdkVersion", 34)
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
android {
|
|
35
|
-
namespace "expo.modules.flashnotifications"
|
|
36
|
-
defaultConfig {
|
|
37
|
-
versionCode 1
|
|
38
|
-
versionName "0.1.0"
|
|
39
|
-
}
|
|
40
|
-
lintOptions {
|
|
41
|
-
abortOnError false
|
|
42
|
-
}
|
|
43
|
-
}
|