Proyectos de Subversion Iphone Microlearning - Nuevo Interface

Rev

Rev 8 | Rev 17 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 1
//
2
//  MyCapsuleListingView.swift
3
//  twogetskills
4
//
5
//  Created by Efrain Yanez Recanatini on 7/27/22.
6
//
7
 
8
import Foundation
9
import SwiftUI
10
import HTMLEntities
11
 
12
struct MyCapsuleListItemView: View {
13
    @EnvironmentObject var appNavigation : AppNavigation
11 efrain 14
    private let appDao = AppDao.sharedInstance
1 efrain 15
 
16
    private var viewModel : MyCapsulesListingItemView = MyCapsulesListingItemView()
17
    private let capsuleName : String
18
    private let capsuleDescription : String
8 efrain 19
 
1 efrain 20
 
21
    init (capsuleUuid : String) {
11 efrain 22
        let appData = appDao.selectOne()
1 efrain 23
        self.viewModel.fetch(capsuleUuid: capsuleUuid, userUuid: appData.userUuid)
24
 
25
 
26
        if self.viewModel.capsule.name.count > Constants.MYCAPSULE_TITLE_MAX_LENGTH {
27
            self.capsuleName =  String(Array(self.viewModel.capsule.name)[0...Constants.MYCAPSULE_TITLE_MAX_LENGTH]) + "..."
28
        } else {
29
            self.capsuleName = self.viewModel.capsule.name
30
        }
31
 
32
        let textHtml = self.viewModel.capsule.description.htmlUnescape()
33
 
34
 
35
 
36
        let regex = "<.*?>"
37
        let repl = ""
38
        let s = textHtml.replacingOccurrences(of: regex, with: repl, options: [.regularExpression])
39
        if s.count > Constants.MYCAPSULE_DESCRIPTION_MAX_LENGTH {
40
            self.capsuleDescription =  String(Array(s)[0...Constants.MYCAPSULE_DESCRIPTION_MAX_LENGTH]) + "..."
41
        } else {
42
            self.capsuleDescription = s
43
        }
44
 
45
    }
46
 
47
 
48
 
49
    var body: some View {
50
        VStack(spacing: 0 ) {
51
        Group {
52
            HStack {
53
                Group {
54
 
55
                    if self.viewModel.capsule.image.isEmpty {
56
 
57
 
58
                    Image(uiImage: UIImage(named: "logo") ?? UIImage())
59
                        .resizable()
60
                        .resizable()
61
                        .aspectRatio(contentMode: .fit)
62
 
63
 
64
 
65
                } else {
66
                    CustomAsyncImage(
67
                        url: URL(string: self.viewModel.capsule.image)!,
68
                        placeholder: { Text(Config.LANG_COMMON_LOADING).font(.footnote).foregroundColor(.black)},
69
                        image: {
70
                            Image(uiImage: $0).resizable()
71
 
72
 
73
                        }
74
                    )
75
                }
76
                } .frame(width: 64, height:97, alignment:  .center)
77
 
78
 
79
 
80
                VStack(spacing: 0)
81
                {
82
                    HStack {
83
                        Text(self.capsuleName)
84
                            .font(Font.custom(Config.FONT_NAME_BOLD, size: 14))
85
                            .foregroundColor(Color("color_capsule_list_item_title_foreground"))
86
 
87
                        Spacer()
88
 
89
                        Button(action: {
90
 
11 efrain 91
                            var appData = appDao.selectOne()
1 efrain 92
                            appData.topicUuidActive = self.viewModel.capsule.topicUuid
93
                            appData.capsuleUuidActive = self.viewModel.capsule.uuid
94
                            appData.slideUuidActive = ""
95
 
11 efrain 96
                            print("update query : 14")
97
                            appDao.update(model: appData)
98
 
99
                            appNavigation.subPageSource = .mycapsules
100
 
1 efrain 101
                            withAnimation {
8 efrain 102
                                appNavigation.subpageActive = .slides
1 efrain 103
                            }
104
 
105
 
106
                        }, label: {
107
                            Image(systemName: "arrowtriangle.right.fill")
108
                                .resizable()
109
                                .aspectRatio(contentMode: /*@START_MENU_TOKEN@*/.fill/*@END_MENU_TOKEN@*/)
110
                                .frame(width: 16, height: 16, alignment: /*@START_MENU_TOKEN@*/.center/*@END_MENU_TOKEN@*/)
111
                        }).padding(.trailing, 10)
112
                        .foregroundColor(Color("color_capsule_list_item_title_foreground"))
113
                    }
114
                    HStack {
115
                        Text(self.capsuleDescription)
116
                            .font(Font.custom(Config.FONT_NAME_REGULAR, size: 16))
117
                            .foregroundColor(Color("color_capsule_list_item_description_foreground"))
118
 
119
 
120
                        Spacer()
121
                    }.padding(.top, 3)
122
 
123
 
124
                    HStack {
8 efrain 125
                        Text("\(self.viewModel.capsule.viewSlides)/\(self.viewModel.capsule.totalSlides)  \(Config.LANG_COMMON_SLIDES)")
1 efrain 126
                            .font(Font.custom(Config.FONT_NAME_REGULAR, size: 12))
127
                            .foregroundColor(Color("color_capsule_list_item_description_foreground"))
128
 
129
                        Spacer()
130
 
131
 
132
                    }.padding(.top, 3)
133
 
134
 
135
                    Button(action: {
8 efrain 136
 
11 efrain 137
                        var appData = appDao.selectOne()
8 efrain 138
                        appData.topicUuidActive = self.viewModel.capsule.topicUuid
139
                        appData.capsuleUuidActive = self.viewModel.capsule.uuid
140
                        appData.slideUuidActive = ""
141
 
11 efrain 142
                        print("update query : 15")
143
                        appDao.update(model: appData)
144
 
145
                        appNavigation.subPageSource = .mycapsules
1 efrain 146
                        appNavigation.subpageActive = .commentsandrating
147
 
148
                    }, label: {
149
 
150
                    HStack {
151
                        FiveStarView(rating: self.viewModel.capsule.totalRating, color: Color("color_capsule_list_item_star_foreground"), backgroundColor: Color("color_capsule_list_item_star_background"))               .frame(width: /*@START_MENU_TOKEN@*/100/*@END_MENU_TOKEN@*/, height: 16, alignment: /*@START_MENU_TOKEN@*/.center/*@END_MENU_TOKEN@*/)
152
                            .padding(.leading, 8)
153
 
154
                        Spacer()
155
 
156
                        Text("\(self.viewModel.capsule.totalComments)")
157
                            .font(Font.custom(Config.FONT_NAME_REGULAR, size: 16))
158
                            .foregroundColor(Color("color_capsule_list_item_description_foreground"))
159
 
160
                        Image(systemName: "message")
161
                            .resizable()
162
                            .aspectRatio(contentMode: .fill)
163
                            .frame(width: 16, height: 16, alignment: /*@START_MENU_TOKEN@*/.center/*@END_MENU_TOKEN@*/)
164
                            .padding(.trailing, 16)
165
                            .foregroundColor(Color("color_capsule_list_item_description_foreground"))
166
                    }
167
                    }).padding(.top, 3)
168
 
169
 
170
                }
171
 
172
 
173
            }
174
 
175
        }
176
 
177
 
178
        Divider()
179
        } .background(Color("color_capsule_list_item_background"))
180
        .padding(.leading, 5)
181
        .padding(.trailing, 5)
182
 
183
    }
184
}
185
 
186
struct MyCapsuleListItemView_Previews: PreviewProvider {
187
 
188
 
189
 
190
 
191
    static var previews: some View {
192
        MyCapsuleListItemView(capsuleUuid : "C123")
193
    }
194
}