Post

Replies

Boosts

Views

Activity

What's the purpose of Vstack when we actually don't need it ??
https://www.swift.org/getting-started/swiftui/ This training page let you understand the Vstack purpose but if you look at my own way of doing it I Made it disappear ??? is this a new release from Swift ? import SwiftUI struct ContentView: View { var body: some View { Text("Why not try…") .font(.largeTitle.bold()) Spacer() Circle() .fill(.blue) .padding() .overlay( Image(systemName: "figure.archery") .font(.system(size: 144)) .foregroundColor(.white) ) Text("Archery!") .font(.title) Spacer() } } #Preview { ContentView() }
4
0
535
Feb ’24
explanation of the following code step by step
Hi all, could you please explain extreme detail what this code is doing exactly, because it's working on my APP but not very certain of this Tupple ForEach(Array(filteredNonTECOProjects.enumerated()), id: \.offset) { (row, project) in TimeKeyInRow(id: project.id, project: project, isSet: $isSet[row]) when.I look at the documentation of swift is seems like I'm using the TUPPLE within another tupple... I I'm lost hahahaha
8
0
808
Feb ’24
Changing my code to reset all IsSetButton (not only one Row) to False once (save or delete) is clicked
Since I included comment in my code I will send few post with all relevant detail here are my question for this SWfit file you place the projects = Modeldata().projectswhile I was trying to do it under modelData.swift file because when I add it into Project.swift file it's not Parse since not in my JSON. should I also add into the JSON ? to make the code cleaner I use a SetTimeKeyInView that I will share in next post creation of date and date range for my new datepickrange buttons @State var isSet: [Bool] = [false, false, false, false, false,false,false,false] is not needed @State private var hideTeco = false is not needed I have also remove it isTECO means Technically close project meaning I don't need to work on it but keep them as reference if one day I want to go and see location, customer and other info remove and change name for more clarity on code and like to point 2 I don't use it in here anymore Datepicker I will dedicate another threat POST as manyquestion I'm facing as you can see I don;t use the code .onAppear() { // <<-- Added for (row, project) in filteredNonTECOProjects.enumerated() { isSet[row] = !project.isTeco } } so I'm not sure what is the code doing and I don't see the link with isTeco import SwiftUI struct TimeKeyinList: View, Observable { @Environment(ModelData.self) var modelData @Environment(TimesheetCalculation.self) var timesheetCalculation //MARK: - Variable & Constants // let projects = ModelData().projects // Now need a State var to be able to modify later I did not do that need to check with Claude var listofpossibleHourstext = TimesheetCalculation().listOfPossibleHoursText @State var isSet = ModelData().isSet // I think the code from claude is what I'm trying to do here // @State var projects = [Project] () //CLAUDEADD Now need a State var to be able to modify @State var date = TimesheetCalculation().date @State var dateRange = TimesheetCalculation().dateRange // @State var isSet: [Bool] = [false, false, false, false, false,false,false,false] // explain to claude that I I ahve more proejct in future and I don't increare this list then the app crash ... not very sure why but i believe it's due to the number of row link with the number of project dispaly //CLAUDE SAY Not the correct var to keep hours for each project. @State var isSet: [Bool] = [true, false, false, true] //Alreadydeleted @State private var hideTeco = false // What's the purpose of this ? Not used in code // I remove the on appear as the code don't need it //@State var filteredProjects: [Project] = [] /* { Init will be done in onAppear // removeTECO project projects.filter { project in !project.isTeco } }*/ //MARK: - Body var body: some View { @Bindable var timesheetCalculation = timesheetCalculation VStack { HStack { Text("TIME KEY_IN") .font(.title) .multilineTextAlignment(.leading) .bold() Spacer() Button { print(TimesheetCalculation().date) } label: { Label("SAVE", systemImage: "square.and.arrow.down") .foregroundStyle(.blue ) .scaleEffect(1.2) } Spacer() //findtheocde to remove intRemaining hours keep the full string into a flooting point and tronacte teh string to only 3character let IntremainingHour = Int(timesheetCalculation.remainingHour) Text("\(IntremainingHour)h") .font(.title) .multilineTextAlignment(.leading) .bold() }.padding() Spacer() VStack(spacing: 5){ HStack(alignment: .top) { Text(" Project Name") .multilineTextAlignment(.center) .lineLimit(2) .frame(width: 120.0) // <<-- To get proper alignment //use the TimekeyinRow listofPossibleHour ForEach((listofpossibleHourstext),id: \.self) { hour in Text("\(hour)h") } Text("Time Left") .multilineTextAlignment(.trailing) .lineLimit(2) .frame(width: 50) }.environment(\.sizeCategory, .extraExtraExtraLarge) SetTimeKeyInView() } HStack { DatePickerStyle().environment(\.sizeCategory, .extraExtraExtraLarge) Button { //I need to clean the cache for //clean all button // remove all of date cvs //remaining hour = 8 $timesheetCalculation.remainingHour } label: { Label("CLEAN", systemImage: "arrow.up.trash") .labelStyle(.iconOnly) .foregroundStyle(.blue ) .scaleEffect(1.2) } } Spacer() // .onAppear() { // // <<-- Added // for (row, project) in filteredNonTECOProjects.enumerated() { // isSet[row] = !project.isTeco // } // } let _ = print(modelData.isSet) Spacer() } } } struct TimeKeyinList_Previews2: PreviewProvider { static var previews: some View { //#Preview TimeKeyinList() .environment(ModelData()) .environment(TimesheetCalculation()) } }
5
0
815
Feb ’24
Saving a project swift UI WITH Xcode and playing again
Hi Team, sounds simple but maybe there is a better way than what I’m doing today. issues : I‘m tired of messing up my project when doing to much modification and can’t make it work again because of to much change in the same time. temporary fix: save the full xcode folder into a new project question:: is there a more professional way to keep change a project structur, code, line, func , or whatever but having all the modifications highlighted . something similar to GIT but without git ?
3
0
802
Feb ’24
Frame following different size of iPhone starting from Xr, 11-15
Hi DevForum team, I'm struggling with some code around designing with proper frame size for Text which give issues with different iPhone size, below full code working perfectly on iPhone 15-14, but not iPhone 14Pro &amp; Xr crash happen ( when I try to understand the crash ... try lol , read between lines) it's all about frame and size so I believe it's about the phone size and the pixel taken from the .frame of the Text one more weird thing happen when I look at the code I share below directly thru preview of TimekeyinList the rendering is very nice, but when I look at it from the contentViewtab View I get this ****** finish any idea why ? import SwiftUI struct TimeKeyinList: View { @Environment(ModelData.self) var modelData let projects = ModelData().projects @State var isSet: [Bool] = [false, false, false, false, false,false,false,false] var filteredNonTECOProjects: [Project] { // removeTECO project modelData.projects.filter { project in !project.isTeco }} var body: some View { VStack { HStack { Text("TIME KEY_IN") .font(.title) .multilineTextAlignment(.leading) .bold() Spacer() Text("8h") .font(.title) .multilineTextAlignment(.leading) .bold() }.padding() Spacer() VStack(spacing: 5){ HStack(alignment: .top) { Text(" Project Name") .multilineTextAlignment(.leading) .lineLimit(2) .frame(width: 120.0) // &lt;&lt;-- To get proper alignment Text(".5h") Text("1h") Text("2h") Text("3h") Text("4h") Text("8h") Text("Time Left") .multilineTextAlignment(.trailing) .lineLimit(2) .frame(width: 50) } VStack(spacing: 20) { BlankKeyInRow() ForEach(Array(filteredNonTECOProjects.enumerated()), id: \.offset) { (row, project) in if project .isSpecific { BlankKeyInRow() BlankKeyInRow() TimeKeyInRow(id: project.shortname, project: project, isSet: $isSet[row]) } else { TimeKeyInRow(id: project.shortname, project: project, isSet: $isSet[row]) } } } .listStyle(.inset) DatePicker(selection: /*@START_MENU_TOKEN@*/.constant(Date())/*@END_MENU_TOKEN@*/, label: { /*@START_MENU_TOKEN@*/Text("Date")/*@END_MENU_TOKEN@*/ }) } .environment(\.sizeCategory, .extraExtraExtraLarge) .labelsHidden() Spacer() .onAppear() { // &lt;&lt;-- Added for (row, project) in filteredNonTECOProjects.enumerated() { isSet[row] = !project.isTeco } } Spacer() } } } struct TimeKeyinList_Previews2: PreviewProvider { static var previews: some View { //#Preview TimeKeyinList().environment(ModelData()) } } second file import SwiftUI struct TimeKeyInRow: View,Identifiable { var id: String var project: Project @Binding var isSet: Bool let listOfPossibleHours: [Double] = [0.5,1,2,3,4,8] var body: some View { HStack { Text(project.shortname.paddedToWidth(10)) // Text(projects[1].shortname) .font(.custom("Menlo", size: 16)) .frame(width: 120.0) // &lt;&lt;-- To get proper alignment Spacer() ForEach(listOfPossibleHours, id: \.self) { hour in HourButton(id: "\(project.shortname)", isSet: isSet, value: hour) } Text("\(project.leftPMtime)") .font(.custom("Menlo", size: 16)) .multilineTextAlignment(.leading) .frame(width: 45) // &lt;&lt;-- To get proper alignment } } } struct TimeKeyInRow_Previews: PreviewProvider { static var previews: some View { //#Preview { let projects = ModelData().projects TimeKeyInRow(id: "test", project: projects[2], isSet: .constant(true)) } } extension String { // To align text func paddedToWidth(_ width: Int) -&gt; String { let length = self.count guard length &lt; width else { return self } let spaces = Array&lt;Character&gt;.init(repeating: " ", count: width - length) return self + spaces } } struct BlankKeyInRow: View { var body: some View { HStack { Text("") // Text(projects[1].shortname) } } } and the starting button point import SwiftUI struct HourButton: View,Identifiable { var id: String = "hour" @State var isSet: Bool var value: Double var body: some View { HStack { Button { isSet.toggle() print("clic on Project : \(id) an turn to : \(isSet) for \(value)h") if isSet == true { print("true is \(isSet)") } else { print("false is\(isSet)") } } label: { Label("8h", systemImage: isSet ? "circle.fill" : "circle") .labelStyle(.iconOnly) .foregroundStyle(isSet ? .blue : .gray) }.id(id) } } } struct HourButton_Previews: PreviewProvider { static var previews: some View { //#Preview { HourButton(id: "MORN", isSet: true, value: 3) } }
0
0
457
Feb ’24
Issues with implementing the logical code for my timesheetKeyin
Hi DevForum team, I'm struggling with the logic to create behind my nice code: as you can see in my ButtonHour (last page) I have if isSet == true { print("true is \(isSet)") } else { print("false is\(isSet)") } the things is that I cannot place anything in between this lines beside Print( ) which is useless for me, Target was for me to be able to Bind & @state this with the following logic & the swift file I want to link it with @Observable class TimesheetCalculation { let maxHourPerDay: Double = 8 var hourchoosen: Double = 0 var totalhourbooked: Double = 0 var remainingHour: Double = 8 var cvsrecordedtrackingcodek: String = "id,value,shortprojectName,day" func checkRemainingHours() -> Double { return remainingHour } ````` // Logic to create, every single button has an ID and a value //first is to collect all the clicked button and make sure he cannot clic more than 8 hours //but first it to link the variable in TimesheetCalculation class, which is not working so far //once I manage to connect this the following logic will apply //maxHourPerDay = 8h //hourchoosen = value of clic button //totalhourbooked = value + value + value - value (if click false) //remainingHour = maxHourPerDay - totalhourbooked //cvsrecordedtrackingcodek will be to keep track of previous day, converted in cvs for future excel export //checkRemainingHours function to automaticly calcuation each time the button has been clic , normlay once the logic will be set I will just put this checkRemainingHours into the action button . // the is also anothe logic that I need to put in place. //if remainingHour - new Value being click is less than 0 then the button will not be able to toggle, meaning that he will not be able to key-more than 8h ````` } struct TimeKeyinList: View { @Environment(ModelData.self) var modelData let projects = ModelData().projects @State var isSet: [Bool] = [false, false, false, false, false,false,false,false] var filteredNonTECOProjects: [Project] { // removeTECO project modelData.projects.filter { project in !project.isTeco }} var body: some View { VStack { HStack { Text("TIME KEY_IN") Spacer() Text("8h") } Spacer() VStack(spacing: 5){ HStack(alignment: .top) { Text(" Project Name") .multilineTextAlignment(.leading) .lineLimit(2) .frame(width: 120.0) // <<-- To get proper alignment Text(".5h") Text("1h") Text("2h") Text("3h") Text("4h") Text("8h") Text("Time Left") } VStack(spacing: 20) { BlankKeyInRow() ForEach(Array(filteredNonTECOProjects.enumerated()), id: \.offset) { (row, project) in if project .isSpecific { BlankKeyInRow() BlankKeyInRow() TimeKeyInRow(id: project.shortname, project: project, isSet: $isSet[row]) } else { TimeKeyInRow(id: project.shortname, project: project, isSet: $isSet[row]) } } } .listStyle(.inset) DatePicker(selection: /*@START_MENU_TOKEN@*/.constant(Date())/*@END_MENU_TOKEN@*/, label: { /*@START_MENU_TOKEN@*/Text("Date")/*@END_MENU_TOKEN@*/ }) }.environment(\.sizeCategory, .extraExtraExtraLarge) .labelsHidden() Spacer() .onAppear() { // <<-- Added for (row, project) in filteredNonTECOProjects.enumerated() { isSet[row] = !project.isTeco } } Spacer() } } } struct TimeKeyinList_Previews2: PreviewProvider { static var previews: some View { TimeKeyinList().environment(ModelData()) } } second file struct TimeKeyInRow: View,Identifiable { var id: String var project: Project @Binding var isSet: Bool let listOfPossibleHours: [Double] = [0.5,1,2,3,4,8] var body: some View { HStack { Text(project.shortname.paddedToWidth(10)) // Text(projects[1].shortname) .font(.custom("Menlo", size: 16)) .frame(width: 120.0) // <<-- To get proper alignment Spacer() ForEach(listOfPossibleHours, id: \.self) { hour in HourButton(id: "\(project.shortname)", isSet: isSet, value: hour) } Text("\(project.leftPMtime)") } } } struct TimeKeyInRow_Previews: PreviewProvider { static var previews: some View { let projects = ModelData().projects TimeKeyInRow(id: "test", project: projects[2], isSet: .constant(true)) } } extension String { // To align text func paddedToWidth(_ width: Int) -> String { let length = self.count guard length < width else { return self } let spaces = Array<Character>.init(repeating: " ", count: width - length) return self + spaces } } struct BlankKeyInRow: View { var body: some View { HStack { Text("") // Text(projects[1].shortname) } } } and the starting button point import SwiftUI struct HourButton: View,Identifiable { var id: String = "hour" @State var isSet: Bool var value: Double var body: some View { HStack { Button { isSet.toggle() print("clic on Project : \(id) an turn to : \(isSet) for \(value)h") if isSet == true { print("true is \(isSet)") } else { print("false is\(isSet)") } } label: { Label("8h", systemImage: isSet ? "circle.fill" : "circle") .labelStyle(.iconOnly) .foregroundStyle(isSet ? .blue : .gray) }.id(id) } } } struct HourButton_Previews: PreviewProvider { static var previews: some View { //#Preview { HourButton(id: "MORN", isSet: true, value: 3) } }
2
0
443
Feb ’24
Creating an Array/Button with specific ID everybutiton regardless of projectName or Hours
hi all, I'm writing to DevForum after few days of struggle 13-15h everyday trying to dig many forum for solution ( try Github for: do to list and many other app built in to switch between toggle and button to see if the issues was coming from here My App idea seems simple actually very complex to build for me, I have manage to build the solution for one row and it's working but when it goes to adding the row into a list I'm giving up.... I do not understand why in my TimeKeyInRow structure it's working I can clic and get feedback of every single hours but when I add row to a list even if I have already created an ID it's still taking the all row as one isSet import SwiftUI struct HourButton: View,Identifiable { var id: String = "hour" @State var isSet: Bool var value: Double = 1 var body: some View { HStack { Button { isSet.toggle() print("clic already \(isSet) \(id)h & \(value) has Value") } label: { Label("8h", systemImage: isSet ? "circle.fill" : "circle") .labelStyle(.iconOnly) .foregroundStyle(isSet ? .blue : .gray) }.id(id) } } } struct HourButton_Previews: PreviewProvider { static var previews: some View { //#Preview { HourButton(id: "MORN", isSet: true, value: 3) } } This is the Row Part which is working fine import SwiftUI struct TimeKeyInRow: View,Identifiable { var id: String var project: Project @Binding var isSet: Bool let listOfPossibleHours: [Double] = [0.5,1,2,3,4,8] var body: some View { HStack { Text(project.shortname) Spacer() HourButton(id: "\(project.shortname)\(0)", isSet: true, value: listOfPossibleHours[0]) HourButton(id: "\(project.shortname)\(1)", isSet: true, value: listOfPossibleHours[1]) HourButton(id: "\(project.shortname)\(2)", isSet: true, value: listOfPossibleHours[2]) HourButton(id: "\(project.shortname)\(3)", isSet: true, value: listOfPossibleHours[3]) HourButton(id: "\(project.shortname)\(4)", isSet: true, value: listOfPossibleHours[4]) Text("\(project.leftPMtime)") } } } struct TimeKeyInRow_Previews: PreviewProvider { static var previews: some View { //#Preview { let projects = ModelData().projects TimeKeyInRow(id: "test", project: projects[2], isSet: .constant(true)) } } Then the part were the issues is coming import SwiftUI struct TimeKeyinList: View, Identifiable{ var id: String @Environment(ModelData.self) var modelData let projects = ModelData().projects @State var isSet: Bool @State private var hideTeco = false var filteredProjects: [Project] { // removeTECO project modelData.projects.filter { project in !project.isTeco }} var body: some View { VStack { HStack { Text("TIME KEY_IN") .font(.title) .multilineTextAlignment(.leading) .bold() Spacer() Text("8h") .font(.title) .multilineTextAlignment(.leading) .bold() }.padding() List { HStack(alignment: .top) { Text("Project Name") .frame(width: 80, height: 25) .font(.caption) .multilineTextAlignment(.center) .lineLimit(8) .allowsTightening(/*@START_MENU_TOKEN@*/true/*@END_MENU_TOKEN@*/) .multilineTextAlignment(.center) .bold() Spacer(minLength:30) Text("0.5h") .font(.footnote) Text("1h") .font(.footnote) .padding(/*@START_MENU_TOKEN@*/EdgeInsets()/*@END_MENU_TOKEN@*/) Text("2h") .font(.footnote) .padding(/*@START_MENU_TOKEN@*/EdgeInsets()/*@END_MENU_TOKEN@*/) Text("3h") .font(.footnote) .padding(/*@START_MENU_TOKEN@*/EdgeInsets()/*@END_MENU_TOKEN@*/) Text("4h") .font(.footnote) .padding(/*@START_MENU_TOKEN@*/EdgeInsets()/*@END_MENU_TOKEN@*/) Text("Time Left") .frame(width: 60, height: 25) .font(.caption) .multilineTextAlignment(.center) .lineLimit(8) .allowsTightening(/*@START_MENU_TOKEN@*/true/*@END_MENU_TOKEN@*/) .multilineTextAlignment(.center) .bold() } ForEach (filteredProjects) { project in TimeKeyInRow(id: project.shortname, project: project, isSet: $isSet) } Divider() // TimeKeyInRow(project: "TRAINING", isSet: $isSet) // TimeKeyInRow(isSet: $isSet, projectshortname: "MEETING", timeleft: 0) // TimeKeyInRow(isSet: $isSet, projectshortname: "NON ALLOCATED", timeleft:0) // TimeKeyInRow(isSet: $isSet, projectshortname: "HOLIDAY", timeleft:0) // // } // .listStyle(.inset) // DatePicker(selection: /*@START_MENU_TOKEN@*/.constant(Date())/*@END_MENU_TOKEN@*/, label: { /*@START_MENU_TOKEN@*/Text("Date")/*@END_MENU_TOKEN@*/ }) }.labelsHidden() } } } struct TimeKeyinList_Previews: PreviewProvider { static var previews: some View { //#Preview { TimeKeyinList(id: "test", isSet: true).environment(ModelData()) } }
12
0
857
Feb ’24
Having fun project to build
Hi All, if anyone is keen to help me build this interface i would like to build it in 4 swift file 1- Logictimekeyin : this will be the model data of 8h per day time calculation 2-TimekeyinRow this will represent one row 3-ListOfchoice this will be a combination of the project 4-timekeyinView it will be the list of choice a divider and other non project waisted time during the day + the setting around the view including the logic to calculate the total time ;) have fun helping me , I believe I will finish my project within this week , if anyone wanna help and see which will be the best code will deserve a solving and thumb up happy development guys
7
0
629
Feb ’24
IOs simulator Vs my personal iPhone
hi everyone does anyone understand this issues below ? What to do or change in my code when this appear my code is over more than 20 swift file I don't know which one to share lol dyld[1060]: Symbol not found: _$s21DeveloperToolsSupport17UVPreviewRegistryCMn Referenced from: /private/var/containers/Bundle/Application/ACD0F0D4-CAF4-4101-BFC0-3990E29F316E/MyPmV1.app/MyPmV1 Expected in: /System/Library/Frameworks/DeveloperToolsSupport.framework/DeveloperToolsSupport
3
0
631
Feb ’24
Combining condition to show something,
Hi Team, I would like to combine or mix and match two filter here is the code but seems like I cannot do what I want... I want to be able to show only what the filter is made for so if TECO and favorite is active then I would only see favourite and not TECO project , and if TECO is not active but favourite is active then it will only show all favourite project and if TECO is active it will only show all project which are not TECO regardless if they are favortie import SwiftUI struct ProjectList: View { @State private var showTecoOnly = false @State private var showFavoriteOnly = false var filteredTECOProjects: [Project] { projects.filter { project in (!showTecoOnly || !project.isTeco) } } var filteredProjects: [Project] { projects.filter { project in (!showFavoriteOnly || project.isFavorite) } } var body: some View { NavigationSplitView { List { Toggle(isOn: $showTecoOnly) { Text("Hide TECO") } Toggle(isOn: $showFavoriteOnly) { Text("Show Favorite") } ForEach (filteredTECOProjects ) && ForEach (filteredProjects ) { project in NavigationLink { ProjectDetail(project: project) } label: { ProjectRow(project: project) } } Divider() } .animation(.default, value: filteredTECOProjects) .navigationTitle("PROJECTS") } detail: { Text("Select a project") } } } #Preview { ProjectList() }
1
0
490
Feb ’24
support need for old swift Vs new swift
I 'm. struggling with the following code "import SwiftUI struct ContentView: View { var pictures = [String]() var body: some View { let fm = FileManager.default let path = Bundle.main.resourcePath! let items = try! fm.contentsOfDirectory(atPath: path) for item in items { if let item = item.hasPrefix("nssl") { pictures.append(item) } } print(pictures) } } while before it was : class ViewController: UIViewController { var pictures = [String] "() override func viewDidLoad() { super.viewDidLoad() let fm = FileManager.default let path = Bundle.main.resourcePath! let items = try! fm.contentsOfDirectory(atPath: path) and it was working
5
0
633
Feb ’24
Can't find keyplane that supports type ...
Hi All, After long hours trying to find appropriate answer on google and other website, I have decided to post the question here where APPLE developer could help. How to remove this issues as it's not appearing on simulator only but on real device too. I have two simple UItextfield, programatically ask for a num.pad and I get the following error : Can't find keyplane that supports type 11 for keyboard iPhone-PortraitTruffle-NumberPad; using 25764PortraitTruffleiPhone-Simple-Pad_Default
1
0
662
Sep ’20