Comments (4)
Hey @MarkLyck
I'm afraid I can't replicate this, are you sure your component isn't remounting? Remounting the provider will cause this which I think is reasonable vs re-rendering which doesn't seem to.
Given this example I only see 1 call, even after re-renders:
function MyApp({ Component, pageProps, flagsmithState }: AppProps & {flagsmithState: IState}) {
const [state, setState] = useState<number>(0)
return (
<div>
<button onClick={()=>setState(Date.now())}>re-render</button>
<div>{state}</div>
<FlagsmithProvider
options={{
environmentID,
cacheFlags: true,
identity: "1234",
traits: {
id: 1,
allowed_company_uids: 2,
preferred_username: 3,
},
}}
flagsmith={flagsmith}
>
<Component {...pageProps} />
</FlagsmithProvider>
</div>
);
}
Im assuming that you're wrapping your entire web app with 1 provider?
from flagsmith-js-client.
@kyle-ssg hmmm that's strange.
I'm definitely not unmounting anything (at least on purpose) and yeah I only have 1 Provider wrapping my entire application.
I did try to add a console log in my AppProvider components and I do see that the console log, logs 3 times. But those (to my knowledge) are not unmounting or remounting anything.
my App Provider looks like this:
const AppProvider = ({ children }: ProvidersProps) => {
const { i18n } = useTranslation()
const { theme, user } = useStore((state: any) => ({
theme: state.theme,
user: state.user,
}))
const antDLocale = i18n.language === 'fr-CA' ? frFR : enUS
const SuperProvider = composeWrappers([
({ children }) => (
<QueryClientProvider client={queryClient}>{children}</QueryClientProvider>
),
({ children }) => <CubeProvider>{children}</CubeProvider>,
({ children }) => <BreakpointProvider>{children}</BreakpointProvider>,
({ children }) => <ThemeProvider theme={theme}>{children}</ThemeProvider>,
({ children }) => (
<ConfigProvider locale={antDLocale}>{children}</ConfigProvider>
),
({ children }) => (
<FlagsmithProvider
options={{
environmentID: APP_CONFIG.FLAGSMITH_ENV,
cacheFlags: true,
identity: user.sub,
traits: {
id: user.sub,
allowed_company_uids: user.allowed_company_uids,
preferred_username: user.preferred_username,
},
}}
flagsmith={flagsmith}
>
{children}
</FlagsmithProvider>
),
])
console.log('This logs 3 times')
return (
<SuperProvider>
<>{children}</>
</SuperProvider>
)
}
Where composeWrappers is a small helper function:
// creates a "superProvider" to avoid "WrapperHell"
const composeWrappers = (
wrappers: React.FunctionComponent[]
): React.FunctionComponent =>
wrappers.reduce(
(Acc, Current): React.FunctionComponent => (props) => (
<Current>
<Acc {...props} />
</Current>
)
)
export default composeWrappers
And there's nothing above this, just ReactDOM rendering
const renderApp = () => {
ReactDOM.render(
<AppProvider>
<Routes />
</AppProvider>,
document.getElementById('root')
)
}
the user
is available on first render. (this is using zustand state management)
I don't see how this could end up getting unmounted? My app is client-side only as well. So no server side rendering going on.
from flagsmith-js-client.
I think the best course of action is to get a minimal example repo up that replicates the issue, would you be able to do that?
from flagsmith-js-client.
Closing as stale
from flagsmith-js-client.
Related Issues (20)
- [Bug] - NextJS >= 13.0.0 SSR `useFlagsmith` state not matching the state that is passed to the provider. HOT 16
- flagsmith/react only works in React 18 HOT 3
- [Bug] - TypeError: Cannot read properties of null (reading 'getValue') HOT 5
- Flagsmith's 'useFlags' doesn't return actual cached flags when request failed HOT 2
- Rollup Name for react HOT 5
- Inconsistent license information HOT 2
- Caching with multiple instance doesn't work HOT 6
- Typing issue in react.tsx: 'flagsmith' is possibly 'null' HOT 3
- useFlags() race condition HOT 8
- Different environments not working HOT 5
- Localstorage cache is not being wiped out in some edge cases HOT 3
- Support `getValue` fallback without `json` flag HOT 2
- useFlags not updating values in react18/Nextjs App Router
- 3.23.0 seems to have broken something HOT 4
- Intermittent Flakiness in Feature Flags on Safari/MacOS HOT 2
- Flags are null when the cacheFlags option is true HOT 3
- Typescript compiler errror `Cannot find name 'F'.` when compiling flagsmith in Angular project HOT 3
- Bundle ES(flagsmith-es) and combine with standard CJS module (flagsmith)
- Identifier/trait confusion when using `cacheOptions: { skipAPI: true } ` HOT 3
- Add a devtools option HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from flagsmith-js-client.