Skip to content

Commit

Permalink
Add Rectangle Widget to TestApp
Browse files Browse the repository at this point in the history
  • Loading branch information
underscoretang committed Oct 3, 2023
1 parent 585821a commit 795c290
Show file tree
Hide file tree
Showing 8 changed files with 128 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import android.view.View
import android.widget.Button as ButtonWidget
import android.widget.TextView
import com.example.redwood.testing.widget.Button
import com.example.redwood.testing.widget.Rectangle
import com.example.redwood.testing.widget.TestSchemaWidgetFactory
import com.example.redwood.testing.widget.Text

Expand All @@ -32,4 +33,5 @@ class AndroidTestSchemaWidgetFactory(
override fun Button(): Button<View> = ViewButton(ButtonWidget(context))
override fun Button2() = TODO()
override fun TextInput() = TODO()
override fun Rectangle(): Rectangle<View> = ViewRectangle(context)
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
/*
* Copyright (C) 2023 Square, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.example.redwood.testing.android.views

import android.content.Context
import android.graphics.drawable.GradientDrawable
import android.view.View
import app.cash.redwood.Modifier
import app.cash.redwood.ui.Density
import app.cash.redwood.ui.Dp
import com.example.redwood.testing.widget.Rectangle

internal class ViewRectangle(
context: Context,
) : Rectangle<View> {

private val density = Density(context.resources)

val background = GradientDrawable()
override val value = View(context)

override var modifier: Modifier = Modifier
init {
value.background = background
}
override fun backgroundColor(backgroundColor: UInt?) {
if (backgroundColor != null) {
background.setColor(backgroundColor.toInt())
}
}

override fun cornerRadius(cornerRadius: Float?) {
if (cornerRadius != null) {
background.cornerRadius = with(density) { Dp(cornerRadius.toDouble()).toPx() }.toFloat()
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
package com.example.redwood.testing.browser

import com.example.redwood.testing.widget.Button
import com.example.redwood.testing.widget.Rectangle
import com.example.redwood.testing.widget.TestSchemaWidgetFactory
import com.example.redwood.testing.widget.Text
import org.w3c.dom.Document
Expand All @@ -37,6 +38,9 @@ class HtmlWidgetFactory(
}

override fun TextInput() = TODO()

override fun Rectangle() = TODO()

override fun Button2() = TODO()

override fun ScopedTestRow() = throw UnsupportedOperationException()
Expand Down
4 changes: 4 additions & 0 deletions test-app/ios-uikit/TestApp.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
635661DA21F12B7E00DD7240 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 635661D821F12B7E00DD7240 /* Main.storyboard */; };
635661DC21F12B8000DD7240 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 635661DB21F12B8000DD7240 /* Assets.xcassets */; };
635661DF21F12B8000DD7240 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 635661DD21F12B8000DD7240 /* LaunchScreen.storyboard */; };
96C741A32ACCAB13007C41FE /* RectangleBinding.swift in Sources */ = {isa = PBXBuildFile; fileRef = 96C741A22ACCAB13007C41FE /* RectangleBinding.swift */; };
CB85C0B725AFE61A007A2CC7 /* TestAppViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = CB85C0B625AFE61A007A2CC7 /* TestAppViewController.swift */; };
CB9E3E822AB379C4007A87CD /* ButtonBinding.swift in Sources */ = {isa = PBXBuildFile; fileRef = CB9E3E812AB379C4007A87CD /* ButtonBinding.swift */; };
CB9F76562810A8A8008CF457 /* IosHostApi.swift in Sources */ = {isa = PBXBuildFile; fileRef = CB9F76552810A8A8008CF457 /* IosHostApi.swift */; };
Expand All @@ -28,6 +29,7 @@
635661DE21F12B8000DD7240 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; };
635661E021F12B8000DD7240 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
63E90CF521FEBBB700449E04 /* main.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = main.framework; path = "../ios-shared/build/xcode-frameworks/main.framework"; sourceTree = "<group>"; };
96C741A22ACCAB13007C41FE /* RectangleBinding.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = RectangleBinding.swift; sourceTree = "<group>"; };
CB85C0B625AFE61A007A2CC7 /* TestAppViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = TestAppViewController.swift; sourceTree = "<group>"; };
CB9E3E812AB379C4007A87CD /* ButtonBinding.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ButtonBinding.swift; sourceTree = "<group>"; };
CB9F76552810A8A8008CF457 /* IosHostApi.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = IosHostApi.swift; sourceTree = "<group>"; };
Expand Down Expand Up @@ -74,6 +76,7 @@
10AA3D4B28C03D32006F125E /* IosTestSchemaWidgetFactory.swift */,
10AA3D4D28C0EA40006F125E /* TextBinding.swift */,
CB9E3E812AB379C4007A87CD /* ButtonBinding.swift */,
96C741A22ACCAB13007C41FE /* RectangleBinding.swift */,
);
path = TestApp;
sourceTree = "<group>";
Expand Down Expand Up @@ -173,6 +176,7 @@
files = (
10AA3D4C28C03D32006F125E /* IosTestSchemaWidgetFactory.swift in Sources */,
CB9E3E822AB379C4007A87CD /* ButtonBinding.swift in Sources */,
96C741A32ACCAB13007C41FE /* RectangleBinding.swift in Sources */,
CB85C0B725AFE61A007A2CC7 /* TestAppViewController.swift in Sources */,
10AA3D4E28C0EA40006F125E /* TextBinding.swift in Sources */,
635661D521F12B7E00DD7240 /* AppDelegate.swift in Sources */,
Expand Down
10 changes: 7 additions & 3 deletions test-app/ios-uikit/TestApp/IosTestSchemaWidgetFactory.swift
Original file line number Diff line number Diff line change
Expand Up @@ -31,15 +31,19 @@ class IosTestSchemaWidgetFactory: TestSchemaWidgetFactory {
func Button() -> Button {
return ButtonBinding()
}

func Button2() -> Button2 {
fatalError()
}


func Rectangle() -> Rectangle {
return RectangleBinding()
}

func ScopedTestRow() -> ScopedTestRow {
fatalError()
}

func TestRow() -> TestRow {
fatalError()
}
Expand Down
53 changes: 53 additions & 0 deletions test-app/ios-uikit/TestApp/RectangleBinding.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
/*
* Copyright (C) 2023 Square, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

import Foundation
import TestAppKt
import UIKit

class RectangleBinding: Rectangle {

private let root: UIView = {
let view = UIView()
return view
}()

var modifier: Modifier = ExposedKt.modifier()
var value: Any { root }

func backgroundColor(backgroundColor: KotlinUInt?) {
if let backgroundColor {
root.backgroundColor = UIColor(argb: backgroundColor.uintValue)
}
}

func cornerRadius(cornerRadius: KotlinFloat?) {
if let cornerRadius {
root.layer.cornerRadius = CGFloat(cornerRadius.floatValue)
}
}
}

private extension UIColor {
convenience init(argb: UInt) {
let alpha = CGFloat((argb >> 24) & 0xFF) / 255.0
let red = CGFloat((argb >> 16) & 0xFF) / 255.0
let green = CGFloat((argb >> 8) & 0xFF) / 255.0
let blue = CGFloat(argb & 0xFF) / 255.0

self.init(red: red, green: green, blue: blue, alpha: alpha)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ import app.cash.redwood.layout.compose.Column
import app.cash.redwood.ui.Margin
import app.cash.redwood.ui.dp
import com.example.redwood.testing.compose.Button
import com.example.redwood.testing.compose.Rectangle
import com.example.redwood.testing.compose.Text

private val screens = buildMap<String, @Composable TestContext.() -> Unit> {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ import kotlin.time.Duration
Button::class,
Button2::class,
TextInput::class,
Rectangle::class,
],
dependencies = [
Dependency(1, RedwoodLayout::class),
Expand Down Expand Up @@ -95,6 +96,12 @@ public data class TextInput(
@Property(5) val maxLength: Int,
)

@Widget(8)
public data class Rectangle(
@Property(1) val backgroundColor: UInt?,
@Property(2) val cornerRadius: Float?,
)

public object TestScope

public object SecondaryTestScope
Expand Down

0 comments on commit 795c290

Please sign in to comment.