Skip to content

Commit

Permalink
chore: Add SwiftUI custom input view and update ContentView
Browse files Browse the repository at this point in the history
  • Loading branch information
yostane committed Jun 27, 2024
1 parent 5664165 commit d2ed81c
Show file tree
Hide file tree
Showing 4 changed files with 147 additions and 0 deletions.
41 changes: 41 additions & 0 deletions corrections/SwiftUI-00.swiftpm/ContentView.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
import SwiftUI

struct ContentView: View {
@State var toggle = false
@State var textFieldContent = ""
@State var isEmailValid = false
var body: some View {
VStack {
CustomInputView(text: "Custom Component", isValidEmail: $isEmailValid) { value in
print(value)
}
TextField("Please enter something",
text: $textFieldContent)
.border(.secondary)
.padding()
.onSubmit {
print("submitted", textFieldContent)
}
Text("text field content: \(textFieldContent)")
Text("Hello SwiftUI")
.font(.largeTitle)
.foregroundColor(isEmailValid ? .red : .green)
.padding()
Button(action: {
toggle = !toggle
print(isEmailValid)
}) {
HStack {
Image(systemName: "suit.heart.fill")
.foregroundColor(.red)
Text("I am a button")
.font(.headline)
.foregroundColor(.white)
}
.padding(12)
.background(toggle ? Color.orange : Color.blue)
.cornerRadius(8)
}
}
}
}
53 changes: 53 additions & 0 deletions corrections/SwiftUI-00.swiftpm/CustomInputView.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
//
// CustomInputView.swift
// SwiftUI-00
//
// Created by Yassine Benabbas on 27/06/2024.
//

import SwiftUI

struct CustomInputView: View {
var text = "Hello World"
@State private var textFieldContent = ""
@Binding var isValidEmail: Bool
let onSpecialEvent : (String) -> Void

var body: some View {
VStack {
Text(text)
TextField("Please enter something",
text: $textFieldContent)
.border(.secondary)
.padding()
.onSubmit {
isValidEmail = textFieldContent.contains("@")
}
.onChange(of: textFieldContent, perform: { newValue in
if textFieldContent.hasSuffix(".com") {
onSpecialEvent(textFieldContent)
}
})
Text("text field content: \(textFieldContent)")
}
.border(.secondary)
.padding()
}
}


//struct MyView_Previews: PreviewProvider {
// static var previews: some View {
// @State var isValidEmail = false
// CustomInputView(isValidEmail: $isValidEmail)
// }
//}
//
//#Preview {
// MyView_Previews()
//}

//#Preview("Custom view preiew 2") {
// @State var isValidEmail = false
// _ = CustomInputView(text: "Other preview", isValidEmail: $isValidEmail)
//}
10 changes: 10 additions & 0 deletions corrections/SwiftUI-00.swiftpm/MyApp.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
import SwiftUI

@main
struct MyApp: App {
var body: some Scene {
WindowGroup {
ContentView()
}
}
}
43 changes: 43 additions & 0 deletions corrections/SwiftUI-00.swiftpm/Package.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
// swift-tools-version: 5.8

// WARNING:
// This file is automatically generated.
// Do not edit it by hand because the contents will be replaced.

import PackageDescription
import AppleProductTypes

let package = Package(
name: "SwiftUI-00",
platforms: [
.iOS("16.0")
],
products: [
.iOSApplication(
name: "SwiftUI-00",
targets: ["AppModule"],
bundleIdentifier: "wl.iostraining.SwiftUI-00",
teamIdentifier: "",
displayVersion: "1.0",
bundleVersion: "1",
appIcon: .placeholder(icon: .calculator),
accentColor: .presetColor(.yellow),
supportedDeviceFamilies: [
.pad,
.phone
],
supportedInterfaceOrientations: [
.portrait,
.landscapeRight,
.landscapeLeft,
.portraitUpsideDown(.when(deviceFamilies: [.pad]))
]
)
],
targets: [
.executableTarget(
name: "AppModule",
path: "."
)
]
)

0 comments on commit d2ed81c

Please sign in to comment.