How to Build a Clean Architecture CRUD Note App Using KMM (Android + iOS)

Поділитися
Вставка
  • Опубліковано 25 лип 2024
  • KMM (Kotlin Multiplatform Mobile) allows us to create cross-platform apps using Kotlin. A major part of our apps logic is shared Kotlin code - only the platform specific things need to be implemented in native code. So, we effectively get 2 native apps while sharing a lot of Kotlin code.
    💻 Let me be your mentor and become an industry-ready Android developer in 10 weeks:
    pl-coding.com/drop-table-ment...
    Learn how to setup a KMM project in Android Studio:
    • Creating Your First He...
    Get the initial source code for this video here:
    github.com/philipplackner/Not...
    Get the final source code for this video here:
    github.com/philipplackner/Not...

КОМЕНТАРІ • 163

  • @francismwangi9752
    @francismwangi9752 Рік тому +5

    Hello Phillip.Your ability to simplify complex concepts and explain them in a clear and concise manner is truly commendable. Your step-by-step approach to teaching makes it seem easy and achievable, even for beginners.
    Looking forward to learning more about Firebase, CRUD operations, and authentication. If you have time for a UA-cam tutorial on these topics, I'd love to watch it. Thanks for sharing your expertise.

  • @hinocenciopaulo
    @hinocenciopaulo Рік тому +24

    I could see that you put a lot of effort into this project and still released it for free. Thank you very much.

    • @nijuyonkadesu
      @nijuyonkadesu Рік тому +1

      yess 💌 only while doing I can realize how complex it can get !

  • @kinggeorges625
    @kinggeorges625 Рік тому +19

    Thanks Phillip for this great video were waiting impatiently 🤩
    Next time please consider doing a *News KMM app* with API requests 🙏

  • @breensrobert
    @breensrobert Рік тому

    Wow finally finished this, great explanation and looking forward to building more apps on KMM.

  • @shareefummer2564
    @shareefummer2564 Рік тому +3

    I was eagerly waiting for your KMM video. Thanks brother . Love from India😍

  • @miracleukaka4085
    @miracleukaka4085 Рік тому

    Thank you so much for this. I can't wait to get my Mac so I can start applying these KMM concepts.

  • @theophilus494
    @theophilus494 Рік тому +1

    Thanks sooooooo much Philipp... I'm personally grateful for this... 🙏🙌

  • @ericlekwa4573
    @ericlekwa4573 Рік тому

    Thank you Philipp I have been keeping an eye for this tutorial. this is an dream come through for me 🥳

  • @andresfgarcia86
    @andresfgarcia86 Рік тому

    Great tutorial, can't wait to see more KMM & iOS

  • @sanjaybatak3549
    @sanjaybatak3549 Рік тому +1

    Thanks a million Phillip Lacker 🎉 U r our hero.

  • @joeymarley
    @joeymarley Рік тому

    Another Great tutorial!! Thanks for sharing your knowledge and for making those awesome tutorials

  • @edbienes
    @edbienes Рік тому

    very timely content!! 🥳👍🏻👍🏻 thank youuu

  • @mattisovereighteen
    @mattisovereighteen 11 місяців тому +2

    This is better than most paid courses, thank you so much!

  • @jisunski02
    @jisunski02 Рік тому

    Will try this later. Great dude!

  • @KIRILLINGUSS21
    @KIRILLINGUSS21 Рік тому

    awesome video!!! we're waiting for more about KMM :))😀😃

  • @dutyman5533
    @dutyman5533 Рік тому

    Thank you very much for the time that you spent for tutorial.

  • @hcaltay
    @hcaltay Рік тому

    You are a legend. Thanks for the video!

  • @chimezieorji-unegbu7110
    @chimezieorji-unegbu7110 Рік тому

    I have liked even before starting to watch knowing it's great already.

  • @elelan
    @elelan Рік тому +5

    Finally finished watching this and learned a lot
    I think it's time you start making IOS and swift tutorials along with KMM
    We would love that very much😍😍😍

  • @gofudgeyourselves9024
    @gofudgeyourselves9024 Рік тому

    Absolutely brilliant

  • @elelan
    @elelan Рік тому +2

    Thank you
    Looking forward to learn a lot about KMM 🤩

  • @dbug18
    @dbug18 Рік тому +12

    Another tip from an iOS dev hehehe: you don't need to set optional variables to nil. The default value is already nil. Thanks for the video!

  • @stephentellez5718
    @stephentellez5718 Рік тому

    thank you soo much for your magnificent work

  • @gofudgeyourselves9024
    @gofudgeyourselves9024 Рік тому

    This man is incredible

  • @chandershekhar9251
    @chandershekhar9251 Рік тому

    thank you very much sir for the tutorial

  • @hachoumkabboudi8125
    @hachoumkabboudi8125 Рік тому

    great job, some seperate iOS tutorials would be awesome too

  • @dess4099
    @dess4099 Рік тому +2

    I wish there was that great content in Flutter like this! I'm not learning kotlin but it really helps in my stack anyway

    • @coldwolf5050
      @coldwolf5050 Рік тому

      Check out Mitch Koko on youtube

    • @karansoni3798
      @karansoni3798 Рік тому

      Bro you never heard of resocoder 😂..even a simple flutter keyword will index some of his videos

    • @dess4099
      @dess4099 Рік тому

      @@karansoni3798 ofc, but reso doesn't build apps like this

  • @PhilippLackner
    @PhilippLackner  Рік тому +1

    I just launched a really in-depth KMM course in which you learn to build a professionally designed translator app that supports 28 languages. Get it here:
    pl-coding.com/building-industry-level-multiplatform-apps-with-kmm

  • @celik_m
    @celik_m Рік тому

    Nicely done. Small suggestion would be to record natural approach to development in terms of showing decision making process and at least part of the struggles.

  • @tikayz
    @tikayz Рік тому

    Thanks for such an intuitive tutorial.
    I've not finish watching but I've already liked it.
    I really love you man for impacting so much knowledge on us.
    Can't wait to get a MacBook to try my hands on this
    :)

    • @smart1hashi
      @smart1hashi Рік тому

      Do you think we can use kotlin in ios as well in the future?

  • @jiwomdf8244
    @jiwomdf8244 Рік тому

    just finish it, you are the best philipp, help me a lot, thank you so much

  • @user-eo9gb1qq7n
    @user-eo9gb1qq7n Рік тому

    Hi Philipp, thank you for your lessons , can you tell, what android studio theme do you use?

  • @unclerukuss
    @unclerukuss Рік тому

    thanks Philipp !

  • @rahmathidayat4797
    @rahmathidayat4797 Рік тому

    Beautiful course master Philip

    • @PhilippLackner
      @PhilippLackner  Рік тому

      Thanks, happy to help!

    • @chhatrapatikumar7311
      @chhatrapatikumar7311 Рік тому

      @@PhilippLacknerplease make a video on kotlin + node js + mongodb full stack clone App like people made clone app in flutter.

  • @Aditprayogo18
    @Aditprayogo18 Рік тому

    Nice explanation, may I know what theme did you use on the android studio? thank you

  • @alexeysimchenko7494
    @alexeysimchenko7494 7 місяців тому

    on 22:10 I several times listened what did you say, and I could understand it only when I switched on subtitles.
    That word was - parameter)) You put emphasis on the last syllable, although it should be on the second. It's not big deal while you have good subtitles

  • @John-qt6qk
    @John-qt6qk Рік тому

    Awesome!!

  • @KapilSaini-bt7gq
    @KapilSaini-bt7gq Рік тому +1

    Hi Philipp, Please use time stamps in your videos. Thanks for your videos it helps alot.

  • @khemmahato8420
    @khemmahato8420 Рік тому

    you are great bro so much good content

  • @xakaler2638
    @xakaler2638 Рік тому

    Thnq philipp for your amazing content always.
    ...
    Can we start learning KMM, what is the future of KMM.

  • @adrianpionka6329
    @adrianpionka6329 Рік тому

    Hello. Good job. Great knowledge. Maybe next time you show how implement navigation drawer? :)

  • @Cubdadure
    @Cubdadure Рік тому

    Amazing 🤩, thx !! It just need to add paging (for projects with lota of records) and you will have the perfect start kmm app 💪🥳

    • @PhilippLackner
      @PhilippLackner  Рік тому +2

      that's your homework

    • @Cubdadure
      @Cubdadure Рік тому

      I’ll try again, it’s one of the reason I don’t use kmm for the moment, paging is a pain in kmm for the moment for me 😝

  • @saifalnuaimi204
    @saifalnuaimi204 2 місяці тому

    Thanks man

  • @smartapps8770
    @smartapps8770 Рік тому

    Good project🎉, i’m a fan of sharing viewModel instead 😂

  • @rafiulhassan4027
    @rafiulhassan4027 Рік тому

    Thanks a ton!!
    @ 44:22
    Why did you use "lowercase()" in both title & query instead of "ignorecase = true" inside contains?
    Isn't it more convenient?

  • @michaberkowicz8239
    @michaberkowicz8239 Рік тому

    Perfect for boring sunday

  • @abmhdidev
    @abmhdidev Рік тому

    Thank you so much for this video

    • @PhilippLackner
      @PhilippLackner  Рік тому +1

      Most welcome 😊

    • @abmhdidev
      @abmhdidev Рік тому

      @@PhilippLackner Thank you. I really enjoyed watching this video today and I have recommended this video to my developer friends.

  • @josephplayspickleball
    @josephplayspickleball Рік тому +2

    Phillip, I really appreciate this as I'm building a KMM app right now! These videos are helping to fill the gaps in my knowledge!
    One thing I'm struggling to find help with is OAUTH2 verification for users of my app. I need them to send google Sheet requests to write data. I've only been trying in android, but I can't find any good video resources, and I'm struggling to find anything else online. Any good walkthroughs? If not, I guess I'll have to wait for a video of yours to drop one day. Thank you Phillip for all you do for us!

  • @amirraza2790
    @amirraza2790 Рік тому

    Hey man! you are amazing.
    Well I have some confusions here, please make it clear to me If you get time.
    - How can we achieve DI in shared module? please exclude koin or kodein
    - As far as I get the KMM, It has a very limited scope that codebase can be shareable as there are much to be implemented in platform-specific package. Am I right? If yes, Why KMM can be chosen?
    - How can we manage the build variants for Android and iOS in KMM?
    - How can we add projects as sub-modules?
    Thankyou!

  • @zimbaldinho
    @zimbaldinho Рік тому

    Excelent video!
    Has anyone noticed that, on the ios app, when you click in any note, goes back and try to create a new note the content of that note is still there? or did I miss something? on mine it happens like this

  • @arunrajkumard5238
    @arunrajkumard5238 Рік тому

    Thank you

  • @yhqu3464
    @yhqu3464 Рік тому

    Wonderful! Thank you!

  • @Bluckyism
    @Bluckyism Рік тому

    Thank you......

  • @gori_maheswari8994
    @gori_maheswari8994 Рік тому

    Good nice amazing😍

  • @Rekubot
    @Rekubot Рік тому

    Amazing content, thank you! Does anyone know how to enable the sticky scrolling headers in Xcode seen at 2:09:54? I couldn't find a way to enable them in preferences.
    Edit: nvm, it's an Xcode 14 feature

  • @anudeepananth
    @anudeepananth Рік тому

    Does jetpack compose lazy column support sql delight? It only supports room 3 to my knowledge...

  • @JohanMosqueraVlog
    @JohanMosqueraVlog Рік тому

    Thank you Philipp . Sos un crack!
    I’m sorry about the spanglish, but it sounds better to me 😅.

  • @eczema59
    @eczema59 Рік тому +2

    Android Studio cannto find SQLDelight plugin, what I need to do?

    • @PhilippLackner
      @PhilippLackner  Рік тому +1

      You can manually download it from the jetbrains website, simply Google for it and then open the zip in android studio in the plug in settings tab

  • @alonshlider4881
    @alonshlider4881 Рік тому

    Why do you use savedStateHandle for process death and not the rememberSaveable { } block?

  • @ngolian
    @ngolian Рік тому

    About 7 minutes in I noticed some references to iosX64. Does that exist just so that the app can be tested on a simulator on an Intel Mac? Is it safe to remove these references if you're using an Apple Silicon Mac?

  • @nguyencodervn
    @nguyencodervn Рік тому

    Thank !!!!!!!

  • @surendramaran
    @surendramaran Рік тому

    Amazing as always. Would you mind making a video on CameraX?

  • @denisrudenko9937
    @denisrudenko9937 Рік тому

    Thanks

  • @codingjack
    @codingjack Рік тому

    Highly appreciate the contents you are providing.

  • @monoromrin8177
    @monoromrin8177 Рік тому

    Hello anyone, can you tell me how to redraw the view in fragment when configuration change (UImode) in Fragment Activity?

  • @user-kv8th4ls1y
    @user-kv8th4ls1y Рік тому

    Hi! I can't figure out how to do the migration correctly. In the file "note.sq" I create an "insert into ...". The record is saved in the database, everything is ok. I create a file "1.sqm" after I insert line "update table ...". The record has been updated for the current user, but when installing from scratch, I see the old value. Do I really need to change the values ​​in two places?

  • @musfickjamil2831
    @musfickjamil2831 Рік тому

    Wow 🤯🤯🤯🤯

  • @smreha
    @smreha Рік тому

    My man 🙂

  • @raymondmichael4987
    @raymondmichael4987 Рік тому

    Would like if you can add mongodb realm into the mix, as apart two.
    Thanks buddy

  • @coldwolf5050
    @coldwolf5050 Рік тому

    Any chance for an oauth 2.0 with compose video? I spend so much time looking and nothing works...

  • @safionweb
    @safionweb Рік тому

    🔥

  • @sukanyasadasivan5632
    @sukanyasadasivan5632 Рік тому

    Hi, could you please do a video on Compose multi-platform?

  • @androidmaster9869
    @androidmaster9869 Рік тому

    I was expecting a video like this , also navigation with decompose library , but it seems you didn't use decompose . I will watch this video after I complete my current project. anyway thanks a lot .

    • @karansoni3798
      @karansoni3798 Рік тому

      Hey are you contributing for kmm on a open source project or a private project?

  • @zeynepduyenli
    @zeynepduyenli Рік тому

    In Android, search bar doesn't except any keyboard input. I tried both in my physical device & emulator.

  • @davesari6345
    @davesari6345 7 місяців тому

    Stuck at share folder . . . it seems not to be found/seen on mac end

  • @alonshlider4881
    @alonshlider4881 Рік тому

    2:09:10 you can use if let id2 = id{ null safe code } else { execute code if it is null}
    Replace id2 with a more relevant name

    • @ngolian
      @ngolian Рік тому

      You can also shadow the argument name: if let id = id ... and/or use a guard statement instead: guard let id = id else { return }

  • @bitwisedevs469
    @bitwisedevs469 Рік тому

    Finally

  • @kingcoder7654
    @kingcoder7654 Рік тому

    ❤️❤️

  • @larkes3364
    @larkes3364 Рік тому

    I can't find sqldelight plugin in my android studio

  • @thumbthrasher
    @thumbthrasher Рік тому

    Thank you for a great tutorial
    The initial source code seems to be the final version though?

    • @PhilippLackner
      @PhilippLackner  Рік тому

      Uhm no? 🤔

    • @thumbthrasher
      @thumbthrasher Рік тому

      @Philipp Lackner it's no bother, I just wanted to follow along as I'm still a newbie.
      Separately:
      How could I add an extra feature such as a checkbox for a shopping list, for example?
      Thanks again

  • @fatmafakhfakh9997
    @fatmafakhfakh9997 Рік тому

    Thanks for this video .
    I have some issue in other need ; the issue is i have list of item and on Click of Item I open a dialog for detail of current item ;
    the problem is if I click quickly and successive on a first item then on the second item --> the dialog show the details of the second one with the size of the first one

  • @avc8484
    @avc8484 Рік тому

    why use combine at 1:01:27 instead can use merge isn't it?

  • @Alex-ve4wr
    @Alex-ve4wr Рік тому

    Do you have to do something specific for the project to start with Compose for Android ? Mine started with xml

    • @ArturoDevA
      @ArturoDevA Рік тому

      xml is better, you can use databinding with xml > compose

  • @ashrafkm5916
    @ashrafkm5916 Рік тому

    Hi all. A question to everyone. I am backend developer. I am going to start work on front end mobile app. I am little bit confused on choosing flutter vs kotlin+jetpack compose.
    Can you guys suggest please.
    I want app to be working smoother like for example how Instagram works.

  • @frostyfreezemovies
    @frostyfreezemovies 10 місяців тому

    Plz add this to playlist

  • @myselferbumba
    @myselferbumba Рік тому

    Thanks a lot!
    What about Compose Multiplatform!
    Is it interested for KMM projects ?
    Will you talk about this ?

    • @PhilippLackner
      @PhilippLackner  Рік тому +1

      I will once it's stable enough to not run into a million Gradle conflicts

  • @ArturoDevA
    @ArturoDevA Рік тому

    other video with api rest please

  • @user-cq6dt3vp4i
    @user-cq6dt3vp4i Рік тому

    Why do you use types from presentation layer in domain layer? It is a mistake. 28:00

  • @deviantstudio
    @deviantstudio Рік тому

    why you didn't use koin for di? it's multiplatform

  • @rasoolmohamed4788
    @rasoolmohamed4788 Рік тому

    Wow Wow Wow, The most awaited tutorial😍😍😍 Thank You, @Philipp Lackner

    • @PhilippLackner
      @PhilippLackner  Рік тому

      You're welcome 😊

    • @rasoolmohamed4788
      @rasoolmohamed4788 Рік тому

      @@PhilippLackner Can we have an API call video with error handling in KMM + Clean Architecture?

  • @guidoferri8683
    @guidoferri8683 Рік тому +1

    Do you ever use UI design tools like Figma?

  • @devanshgarg6298
    @devanshgarg6298 8 місяців тому

    My sql file is not getting recognised, do anybody else also have the same problem?

  • @dmytroberezhnyi717
    @dmytroberezhnyi717 Рік тому +2

    Jetpack compose for iOS?

    • @ChrisAthanas
      @ChrisAthanas Рік тому +2

      One can hope and im sure its in the pipeline.

  • @sridharannatarajan5324
    @sridharannatarajan5324 Рік тому

    First comment and like

  • @ChrisAthanas
    @ChrisAthanas Рік тому +1

    I'm seeing a runtime error when the android app is put into the background that causes the app to crash:
    java.lang.RuntimeException: Parcel: unable to marshal value Note(id=2, title=zoom, content=, colorHex=4286701290, created=2022-10-11T01:34:44.331)
    Is anyone else getting this error when the app is put in the background?
    It seems that the Note class needs to use the "Serializable" interface to be used as a Parcelable, but since thats a Java-only feature, i cant add it to the Note class.
    Any suggestions?

    • @ChrisAthanas
      @ChrisAthanas Рік тому +1

      I figured it out, and whoa what a pain. The documentation on this is extremely lacking!
      My answer and sample code at sta ckov erflo w dhat c om slash a slash 74050344/2857200
      (remove the spaces and change the dhat to a . and the slash to / - YT doesnt let you post links)

    • @ChrisAthanas
      @ChrisAthanas Рік тому +2

      I had to add custom annotations and TypeParceler, and it was not very straightforward

    • @MrWiseguy818
      @MrWiseguy818 Рік тому +1

      Weird that the Phillip doesn't seem to address this. The bug is caused because the notelistviewmodel is trying to get saved into a parcel when the app goes into the background, but the Note data class is not parcelable and doesn't have the code to do so.
      Difficult to fix this issue if you dont understand it.
      The Solution is to use the kotlin Parcelize annotation
      Add id "kotlin-parcelize" to the module build.gradle, at the top inside the plugins object.
      Then, add @Parcelize annotation to the Note class, and all the subclasses if needed
      make sure the note data class also implements the Parcelable interface, with Note: Parcelable
      It should work just fine after that

  • @zoentach166
    @zoentach166 Рік тому

    You're handsome and amazing lackner. I love your content so much

  • @petrapeltauer
    @petrapeltauer Рік тому

    How does the stateIn at ua-cam.com/video/1w-LTUm_iDE/v-deo.html actually works. Will the resulting StateFlow change only if the object changes structurally? Or will it also change if there is different object but structurally same as the old object which is being replaced?

  • @AliouneDupuy
    @AliouneDupuy Рік тому

    That is so unfortunate that you have to use a mac to follow. But Great video as usual.

  • @micah1995
    @micah1995 Рік тому

    I picked up an issue on the IOS app. When you select a note from the list and click back and than click on the add icon I get the same note. My expectation is that I should see a screen with only the hints.

    • @micah1995
      @micah1995 Рік тому +2

      I found the issue on line 34 of the NoteListScreen you should pass noteId as nil and not selectedNoteId because the NoteListScreen still keeps the same reference of the selectedNoteId

    • @andrefilgueiras
      @andrefilgueiras Рік тому

      @@micah1995 Nice catch and thanks for sharing

  • @pierre.vieira
    @pierre.vieira Рік тому

    1:11:21 Probably, for the purpose of the video being something more summarized, he doesn't care much about clean. In this case, the ideal would be to pass a string to the composable that already has the formattedDate field calculated. That string could be in a ui model that is passed to NoteItem composable. In this case, as he created a single Note data class, this model needs to be shared between data, domain and presentation, which is not ideal.