Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Account Settings Cleanup - Support / FAQ / Email (2U) #198

Merged
merged 18 commits into from
Dec 18, 2023

Conversation

eyatsenkoperpetio
Copy link
Contributor

@eyatsenkoperpetio eyatsenkoperpetio commented Dec 12, 2023

Support info - Contact support #118
FAQ #119
Support info - Terms of Service / Privacy Policies #120
Open Account links inside app

Configuration flags:

FEEDBACK_EMAIL_ADDRESS: '[email protected]'
FAQ_URL: 'link'

AGREEMENT_URLS:
PRIVACY_POLICY_URL: 'link'
TOS_URL: 'link'
COOKIE_POLICY_URL: 'link'
DATA_SELL_CONSENT_URL: 'link'

Simulator Screenshot - iPhone 15 - 2023-12-13 at 13 06 08

@rnr rnr linked an issue Dec 13, 2023 that may be closed by this pull request
Copy link
Contributor

@saeedbashir saeedbashir left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  • It would be nice if you could add a loader while loading the URLs of Privacy, TOS, etc.

}

private func completePath(url: String) -> String {
let langCode = String(Locale.preferredLanguages.first?.prefix(2) ?? "")
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hardcoding the prefix isn't a good option. I guess you can use the following code to get the desired code

let langCode: String
        if #available(iOS 16, *) {
            langCode = Locale.current.language.languageCode?.identifier ?? ""
        } else {
            langCode = Locale.current.languageCode ?? ""
        }

Comment on lines 43 to 61
if let supportedLanguages = supportedLanguages,
!supportedLanguages.contains(langCode) {
return url
}

let URL = URL(string: url)
let host = URL?.host ?? ""
let components = url.components(separatedBy: host)

if components.count != 2 {
return url
}

if let firstComponent = components.first, let lastComponent = components.last {
return "\(firstComponent)\(host)/\(langCode)\(lastComponent)"
}

return url
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please correct the indentation.

Comment on lines 79 to 81
XCTAssertEqual(config.agreement.cookiePolicyURL, URL(string: "https://www.example.com/cookie"))
XCTAssertEqual(config.agreement.dataSellContentURL, URL(string: "https://www.example.com/sell"))
XCTAssertEqual(config.agreement.supportedLanguages, ["es"])
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

How about moving the AgreementConfig tests to a different file, like to AgreementConfigTests? Thoughts?

private func button(linkViewModel: LinkViewModel, isEmailSupport: Bool = false) -> some View {
Button {
if isEmailSupport { viewModel.trackEmailSupportClicked() }
UIApplication.shared.open(linkViewModel.url)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Before opening the URL can you please check whether the link is openable or not? If not it would be nice if you could show an error/info message.

Comment on lines 52 to 86
private func terms(url: URL) -> some View {
navigationLink(
viewModel: .init(
url: url,
title: ProfileLocalization.terms
)
)
}

private func privacy(url: URL) -> some View {
navigationLink(
viewModel: .init(
url: url,
title: ProfileLocalization.privacy
)
)
}

private func cookiePolicy(url: URL) -> some View {
navigationLink(
viewModel: .init(
url: url,
title: ProfileLocalization.cookiePolicy
)
)
}

private func dataSellContent(url: URL) -> some View {
navigationLink(
viewModel: .init(
url: url,
title: ProfileLocalization.doNotSellInformation
)
)
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

All these functions are doing the same thing; I guess you can pass the title as parameter as well with the URL.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This methods for mapping -> viewModel.contactSupport().map(supportInfo)

)
}

private func faq(url: URL) -> some View {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I guess supportInfo(.... and faq( .... can also use a common named method. Thoughts?

Comment on lines 18 to 20
public static let cookiePolicy = ProfileLocalization.tr("Localizable", "COOKIE_POLICY", fallback: "Cookie Policy")
/// Do Not Sell my Personal Information
public static let doNotSellInformation = ProfileLocalization.tr("Localizable", "DO_NOT_SELL_INFORMATION", fallback: "Do Not Sell my Personal Information")
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure but you might need to follow the screen pattern for labels. So you need to use only the first character in caps in the whole text.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@saeedbashir we are trying to follow current app as mentioned here #117
Do we need to change this string @moiz994 ?
Thank you

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@rnr we have discussed and I changed

@moiz994
Copy link

moiz994 commented Dec 14, 2023

@rnr This was an inconsistency in the prod app so would be good if we fixed it now. Thank you.
@saeedbashir thanks for highlighting.

saeedbashir
saeedbashir previously approved these changes Dec 14, 2023
Copy link
Contributor

@saeedbashir saeedbashir left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM 👍

@volodymyr-chekyrta volodymyr-chekyrta merged commit e58a7cd into openedx:develop Dec 18, 2023
3 checks passed
saeedbashir pushed a commit to saeedbashir/openedx-app-ios that referenced this pull request Jan 5, 2024
* chore: add faq, open in browser screen

* chore: merge develop to branch

* chore: add new links Cookie Policy,  Do Not Sell my Personal Information and refactor

* chore: add folder subviews to profile

* chore: add support language to support urls

* chore: add create button

* chore: add tests

* chore: fix language local

* chore: changes PR feedback

* chore: change strings

* chore: change strings

* chore: changes from PR feedback

* chore:  add progress to web browser

* chore: show always progress when web page loading

* chore: add show progress param to web browser
@forgotvas forgotvas deleted the feat/support_faq_120 branch June 20, 2024 14:42
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
5 participants