Fork me on GitHub
#reagent
<
2021-11-17
>
West03:11:27

You could just use (:latin-name x) or (:common-name x) as a key, since they're unique.

macrobartfast03:11:34

Well… that’s my worry… that I may not have unique values there.

macrobartfast03:11:21

What about those things concatenated with the product of gensym or the equivalent?

p-himik07:11:46

Don't use gensym at all, even if concatenated with something. If you know that some data is unique, use it. If not, try to find or create one. E.g. in this case, since you control the data, you can just assign a unique ID for each entry yourself. A plain int from 0 and up would suffice. Not during rendering but in advance - it should come from the source. When you can't do that, just don't use sequences for children - for creates such a sequence here. You could wrap it with e.g. (into [:<>] ...).

macrobartfast01:11:56

Sounds solid. I’ll add unique values to each record (that will be the case anyway soon once I move beyond the placeholder data).

macrobartfast02:11:33

I’ve just been informed gensym is not a good approach.

macrobartfast02:11:30

Unrelated observations totally welcome as well.

Dharmendra18:11:14

Hi, I am trying to resolve one issue which I am currently facing. I am following below steps 1. Created a project using `lein new re-frame appname +10x`. Then I installed mui5(CSS framework) https://mui.com/getting-started/installation/ 2. Then I just modified views.cljs like below

(ns demo.views
  (:require
   ["@mui/material/styles" :refer [ThemeProvider, StyledEngineProvider]]
   ["@sphere/component-library" :refer [themeV2]]
   ["@sphere/component-library/build/components/v3/Dummy/Dummy" :default Dummy]
   ["@mui/material/Button" :default Button]
   ["@mui/material/CssBaseline" :default CssBaseline]))

(defn test-component []
  [:<>
   [:> Button {:variant "contained"} "MUI Button"]
   [:> Dummy]])
   

(defn main-panel []
  [:> StyledEngineProvider {:injectFirst true}
     [:> ThemeProvider {:theme themeV2}
      [:> CssBaseline]
      [test-component]]])
     Note: Here `["@sphere/component-library/build/components/v3/Dummy/Dummy" :default Dummy]` is a UI library written in JS react and https://mui.com/getting-started/installation/ only used there I am getting below error in screenshots:

Dharmendra18:11:54

If I do the same in `create-react-app` it works fine without any problem. Here is the code in screenshot:

Dharmendra05:11:49

Actually we are already using reagent/reframe and I am already following those thing which you can see in example piece of code. Problem only coming now if I try upgrading mui version to 5 in reagent project. MUI 4 works well. So I am wondering if need some extra configuration. Also: 1. I am able to use mui components directly without any issue. 2. Problem comes if I try to use a UI component library written in React JS. If component in component library is using MUI5 then only error is coming and if it is not using then there is no issue.

thheller06:11:58

thats why I linked you the section about fuinction components. read it. that is the cause of your problem as the error in the console is telling you.

thheller06:11:24

you are not following that info. I don't see any :f>

thheller06:11:34

but the error is pointing to a env.cljs?

thheller06:11:53

oh nevermind thats from shadow 😛

thheller06:11:24

on second thought this is much more likely to be a dependency conflict?

thheller06:11:45

you are mixing libraries. so I'm guessing the @sphere stuff maybe is meant for an older MUI?

Dharmendra07:11:35

@sphere/component-library is React JS component library which is using the same MUI 5 version.

Dharmendra07:11:56

Is it related to reagent version? But I already tried to upgrade and it doesn't solve the problem. This is the package.json and shadow-cljs.end deps

{
	"name": "demo",
	"scripts": {
		"ancient": "clojure -Sdeps '{:deps {com.github.liquidz/antq {:mvn/version \"RELEASE\"}}}' -m antq.core",
		"watch": "npx shadow-cljs watch app browser-test karma-test",
		"release": "npx shadow-cljs release app",
		"build-report": "npx shadow-cljs run shadow.cljs.build-report app target/build-report.html",
		"link:local": "yarn link @sphere/component-library && yarn link react && yarn link @mui/styles  && yarn link @mui/material"
	},
	"dependencies": {
		"@emotion/react": "^11.5.0",
		"@emotion/styled": "^11.3.0",
		"@mui/icons-material": "^5.1.0",
		"@mui/lab": "^5.0.0-alpha.54",
		"@mui/material": "^5.1.0",
		"@mui/styles": "^5.1.0",
		"highlight.js": "11.1.0",
		"@sphere/component-library": "v0.1.208",
		"react": "17.0.2",
		"react-dom": "17.0.2"
	},
	"devDependencies": {
		"shadow-cljs": "^2.15.10"
	}
}
shadow-cljs.edn
{:nrepl {:port 8777}

 

 :source-paths ["src" "test"]

 :dependencies
 [[reagent "1.1.0"]
  [re-frame "1.2.0"]
  [day8.re-frame/tracing "0.6.2"]

  [binaryage/devtools "1.0.3"]
  [day8.re-frame/re-frame-10x "1.2.0"]]

 :dev-http
 {8280 "resources/public"
  8290 "target/browser-test"}

 :builds
 {:app
  {:target     :browser
   :output-dir "resources/public/js/compiled"
   :asset-path "/js/compiled"
   :modules
   {:app {:init-fn demo.core/init}}
   :devtools
   {:preloads [day8.re-frame-10x.preload]}
   :dev
   {:compiler-options
    {:closure-defines
     { re-frame.trace.trace-enabled? true
      day8.re-frame.tracing.trace-enabled? true}}}
   :release
   {:build-options
    {:ns-aliases
     {day8.re-frame.tracing day8.re-frame.tracing-stubs}}}}}}

thheller07:11:12

this isn't related to anything CLJS as far as I can tell

thheller07:11:19

the stacktrace is deep on some JS code

thheller07:11:27

somewhere in useTheme it seems

thheller07:11:45

I don't know what any of this does so I can't tell exactly but I'd start looking at the theme related code

Dharmendra09:11:40

Thanks thheller, Actually I am able to use that UI library in create-react-app so I don't think any problem in JS component side.

Dharmendra11:11:57

Hi thheller, thanks for your help and time. We identified the problem is in local linking library and nothing with codes.