bpurinton

bpurinton

Hotwire Native for Rails Developers: Collected Errata from our class at the University of Chicago

Title: Hotwire Native For Rails Developers

Collected Errata from our class at the University of Chicago

Great book, Joe!

We have collected a number of sticking points and snags from our class of 25 students that all finished going through the book yesterday.

I’m just putting these all in one collected thread, rather than several threads:

Chapter 1

Android Emulator Version Mismatch

When I ran my app the first time in Android Studio, I got an error on the phone emulator screen: “Error loading screen”. If you see this, it may be because the phone emulator is running a lower version of the API SDK than the version you were told to set in the build.gradle.kts file in the book (version 35). If you see an “Error loading screen” error when you first run your app in Android Studio, you should go to “Device Manager” on the right side of the screen, delete the existing device (you will likely see “API XX” in the name, where XX is the version number of the API SDK that the emulator is running), then, once you delete that device, use the plus icon to create a new device. You can select “medium phone” and then download one of the images that it provides you with to install a version greater than or equal to the version you set in the build.gradle.kts file.

Chapter 4

Removing “Story Board Name” In Xcode

This may have just been some step I missed in a previous section, but: After setting up the Tab Model and Controller, my app wouldn’t start in Xcode, and just showed a blank screen. I had to navigate to the App/Resrouces/Info.plist file and use the - icon to remove the Storyboard Name key:

Using guard let ... in scene function

In addition, and I saw many other students requiring this, I had to use the following code in the scene function in my SceneDelegate.swift file:

  func scene(
        _ scene: UIScene,
        willConnectTo session: UISceneSession,
        options connectionOptions: UIScene.ConnectionOptions
    ) {
        guard let windowScene = scene as? UIWindowScene else { return }
        let window = UIWindow(windowScene: windowScene)
        window.rootViewController = tabBarController
        self.window = window
        window.makeKeyAndVisible()
    }

Without the guard let ... block at the bottom of the function there (which is not in the book), the app would build in Xcode, but just show a blank screen on simulator launch.

A small note about Likes tab

On page 84, the book mentions that you can add additional tabs to the tab bar, using Likes as an example. A number of our students got stuck here, since /likes are not actually an exposed route in the Rails app. We know what you meant, but a note here (e.g. “this is just an example, and this tab won’t work if you don’t expose a likes route in your Rails app”) would alleviate some confusion.

Manually update AndroidManifest.xml after reorganizing

On page 85, where the book says to drag MainActivity.kt into the new activities package in Android Studio, that move didn’t update the resource in the manifest/AndroidManifest.xml file. I had to manually update the android:name line to point to ".activities.MainActivity":

<!-- manifest/AndroidManifest.xml -->
<!-- ... -->
        <activity
            android:name=".activities.MainActivity"

Typo in onCreate in MainActivity

On page 96, the book did not change:

findViewById<View>(R.id.main_nav_host).applyDefaultImeWindowInsets()

The main_nav_host in that line to:

findViewById<View>(R.id.hikes_nav_host).applyDefaultImeWindowInsets()

hikes_nav_host, within the onCreate function in the MainActivity.kt file.

Chapter 7

Missing d-hotwire-native-class on link

On page 166-167, in the ch07_17 codeblock, there is a missing d-hotwire-native-block class in the link_to "Add a hike". This missing class appears in other codeblocks as well. Without it, the “Add” button won’t appear in the native apps.

Chapter 9

Registering your Mac to upload an archive

On pages 205-206 of the book, when trying to archive and upload a build in Xcode, I noticed this error message that prevented me from doing so:

The book doesn’t mention of this.

To fix the issue: first, I went to Sign In - Apple, and clicked on “Devices” in the “Certificates, IDs & Profiles” section.

Then, I clicked the blue plus icon to get to Sign In - Apple.

On that screen, I filled in the form like so:

I got my device’s “Unique Device Identifier (UUID)” by going into my laptop “Settings”, then clicking “General”, then clicking the “System Report” button to bring up a window where I found my device’s UUID to copy into the form in the browser.

Once I filled in the form with my laptop information, and clicked the “Continue” and “Register” buttons on the next screens, back in Xcode in the “Signing & Capabilities” section, I was able to “Try again” and get the error message to go away. Then, I could proceed as the book says to select “Product > Archive” in the Xcode menu bar.

Version updates for Play store uploads

Unlike Xcode / Apple, Android Studio / Play do not allow re-uploading code without version changes in the metadata. If you see an error like this in the Play store when creating an internal release after uploading the app-release.aab file:

Then, you know you need to update the versionCode and versionName in the App (second one in the list) build.gradle.kts file. Find these lines:

        versionCode = 1
        versionName = "1.0"

And increment them:

        versionCode = 2
        versionName = "1.1"

Then you’ll be able to “Build > Generate Signed App Bundle / APK”, and upload that new file to create a version incremented release in the Play store.

Chapter 10

Sandbox for APN key

On page 238, when registering a new key, to “Continue” after giving the key a name and checking the “Apple Push Notifications service (APNs)” service, I had to also click “Configure” next to the “Apple Push Notifications service (APNs)” service. You can select “Sandbox” (the defaults) on the next screens, and “Register”. Once you do that, you’ll be returned to the new key screen, and you can click “Continue”.

A word about this and some description of the Sandbox vs. Production configuration might be beneficial.

Small typo in credentials code

On page 258, in the codeblock (unnamed) at the bottom of the page in the example credentials file, fcm: should outdented one level, instead of indented as shown in the book.

Easy to miss removal of HotwireWebFragment

On page 264 of the book, I originally missed the step shown in the ch10_58 codeblock, where we remove these two lines from the HikingJournalApplication.kt application subclass:

import dev.hotwire.navigation.fragments.HotwireWebFragment

and

HotwireWebFragment::class,

without removing those, the app doesn’t function correctly. Maybe just some call-out text highlighting this removal just above or below the codeblock would be helpful.

Where Next?

Popular Pragmatic Bookshelf topics Top

yulkin
your book suggests to use Image.toByteData() to convert image to bytes, however I get the following error: "the getter ‘toByteData’ isn’t...
New
simonpeter
When I try the command to create a pair of migration files I get an error. user=&gt; (create-migration "guestbook") Execution error (Ill...
New
Mmm
Hi, build fails on: bracket-lib = “~0.8.1” when running on Mac Mini M1 Rust version 1.5.0: Compiling winit v0.22.2 error[E0308]: mi...
New
JohnS
I can’t setup the Rails source code. This happens in a working directory containing multiple (postgres) Rails apps. With: ruby-3.0.0 s...
New
HarryDeveloper
Hi @venkats, It has been mentioned in the description of ‘Supervisory Job’ title that 2 things as mentioned below result in the same eff...
New
joepstender
The generated iex result below should list products instead of product for the metadata. (page 67) iex&gt; product = %Product{} %Pento....
New
gilesdotcodes
In case this helps anyone, I’ve had issues setting up the rails source code. Here were the solutions: In Gemfile, change gem 'rails' t...
New
Chrichton
Dear Sophie. I tried to do the “Authorization” exercise and have two questions: When trying to plug in an email-service, I found the ...
New
taguniversalmachine
Hi, I am getting an error I cannot figure out on my test. I have what I think is the exact code from the book, other than I changed “us...
New
Henrai
Hi, I’m working on the Chapter 8 of the book. After I add add the point_offset, I’m still able to see acne: In the image above, I re...
New

Other popular topics Top

Exadra37
Please tell us what is your preferred monitor setup for programming(not gaming) and why you have chosen it. Does your monitor have eye p...
New
AstonJ
poll poll Be sure to check out @Dusty’s article posted here: An Introduction to Alternative Keyboard Layouts It’s one of the best write-...
New
AstonJ
This looks like a stunning keycap set :orange_heart: A LEGENDARY KEYBOARD LIVES ON When you bought an Apple Macintosh computer in the e...
New
Exadra37
I am asking for any distro that only has the bare-bones to be able to get a shell in the server and then just install the packages as we ...
New
PragmaticBookshelf
Create efficient, elegant software tests in pytest, Python's most powerful testing framework. Brian Okken @brianokken Edited by Kat...
New
Maartz
Hi folks, I don’t know if I saw this here but, here’s a new programming language, called Roc Reminds me a bit of Elm and thus Haskell. ...
New
mafinar
This is going to be a long an frequently posted thread. While talking to a friend of mine who has taken data structure and algorithm cou...
New
AstonJ
We’ve talked about his book briefly here but it is quickly becoming obsolete - so he’s decided to create a series of 7 podcasts, the firs...
New
AstonJ
If you want a quick and easy way to block any website on your Mac using Little Snitch simply… File &gt; New Rule: And select Deny, O...
New
First poster: AstonJ
Jan | Rethink the Computer. Jan turns your computer into an AI machine by running LLMs locally on your computer. It’s a privacy-focus, l...
New

Sub Categories: