global: add developedByRebus label, ios: fix bugs

This commit is contained in:
Emin 2024-10-10 16:06:33 +05:00
parent fff086dcf4
commit de69678a96
13 changed files with 87 additions and 9 deletions

View file

@ -2,6 +2,7 @@ package app.tourism.ui.screens.auth.sign_in
import PasswordEditText
import androidx.compose.foundation.Image
import androidx.compose.foundation.clickable
import androidx.compose.foundation.layout.Box
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.fillMaxSize
@ -23,12 +24,14 @@ import androidx.compose.ui.platform.LocalFocusManager
import androidx.compose.ui.res.painterResource
import androidx.compose.ui.res.stringResource
import androidx.compose.ui.text.input.ImeAction
import androidx.compose.ui.text.style.TextAlign
import androidx.compose.ui.unit.dp
import androidx.hilt.navigation.compose.hiltViewModel
import app.organicmaps.R
import app.tourism.BASE_URL
import app.tourism.Constants
import app.tourism.domain.models.resource.Resource
import app.tourism.drawOverlayForTextBehind
import app.tourism.ui.ObserveAsEvents
import app.tourism.ui.common.VerticalSpace
import app.tourism.ui.common.buttons.PrimaryButton
@ -138,6 +141,19 @@ fun SignInScreen(
}
}
}
Text(
modifier = Modifier
.fillMaxWidth()
.align(Alignment.BottomStart)
.drawOverlayForTextBehind()
.padding(Constants.SCREEN_PADDING)
.clickable { openUrlInBrowser(context = context, url = "https://rebus.tj") },
text = stringResource(id = R.string.developed_by_label),
textAlign = TextAlign.End,
color = Color.White,
style = TextStyles.h4.copy()
)
}
}

View file

@ -3,6 +3,7 @@ package app.tourism.ui.screens.auth.sign_up
import PasswordEditText
import android.view.LayoutInflater
import androidx.compose.foundation.Image
import androidx.compose.foundation.clickable
import androidx.compose.foundation.layout.Box
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.fillMaxSize
@ -24,12 +25,14 @@ import androidx.compose.ui.platform.LocalFocusManager
import androidx.compose.ui.res.painterResource
import androidx.compose.ui.res.stringResource
import androidx.compose.ui.text.input.ImeAction
import androidx.compose.ui.text.style.TextAlign
import androidx.compose.ui.unit.dp
import androidx.compose.ui.viewinterop.AndroidView
import androidx.hilt.navigation.compose.hiltViewModel
import app.organicmaps.R
import app.tourism.Constants
import app.tourism.domain.models.resource.Resource
import app.tourism.drawOverlayForTextBehind
import app.tourism.ui.ObserveAsEvents
import app.tourism.ui.common.VerticalSpace
import app.tourism.ui.common.buttons.PrimaryButton
@ -38,6 +41,7 @@ import app.tourism.ui.common.textfields.AuthEditText
import app.tourism.ui.screens.auth.navigateToMainActivity
import app.tourism.ui.theme.TextStyles
import app.tourism.ui.utils.showToast
import app.tourism.utils.openUrlInBrowser
import com.hbb20.CountryCodePicker
@Composable
@ -174,6 +178,19 @@ fun SignUpScreen(
}
}
}
Text(
modifier = Modifier
.fillMaxWidth()
.align(Alignment.BottomStart)
.drawOverlayForTextBehind()
.padding(Constants.SCREEN_PADDING)
.clickable { openUrlInBrowser(context = context, url = "https://rebus.tj") },
text = stringResource(id = R.string.developed_by_label),
textAlign = TextAlign.End,
color = Color.White,
style = TextStyles.h4.copy()
)
}
}

View file

@ -2163,6 +2163,7 @@
<string name="smth_went_wrong">Упс, что-то пошло не так</string>
<string name="wait_tjk_map_downloading">Пожалуйста, подождите, идет загрузка карты Таджикистана.</string>
<string name="welcome_to_tjk">Добро пожаловать в Таджикистан</string>
<string name="developed_by_label">Developed by Rebus LLC</string>
<string name="sign_in">Войти</string>
<string name="sign_up">Регистрация</string>
<string name="sign_in_title">Вход</string>

View file

@ -2205,6 +2205,7 @@
<string name="smth_went_wrong">Error </string>
<string name="wait_tjk_map_downloading">Please wait, the map of Tajikistan is loading</string>
<string name="welcome_to_tjk">Welcome to Tajikistan</string>
<string name="developed_by_label">Developed by Rebus LLC</string>
<string name="sign_in">Log in</string>
<string name="sign_up">Registration</string>
<string name="sign_in_title">Entry</string>

View file

@ -3943,6 +3943,8 @@
"organization_name" = "Committee for Tourism Development under the Government of the Republic of Tajikistan ";
"developed_by_label" = "Developed by Rebus LLC";
"smth_went_wrong" = "Error";
"error" = "Error";

View file

@ -3943,6 +3943,8 @@
"organization_name" = "Committee for Tourism Development under the Government of the Republic of Tajikistan ";
"developed_by_label" = "Developed by Rebus LLC";
"smth_went_wrong" = "Error";
"error" = "Error";

View file

@ -3943,6 +3943,8 @@
"organization_name" = "Комитет по развитию туризма при Правительстве Республики Таджикистан ";
"developed_by_label" = "Developed by Rebus LLC";
"smth_went_wrong" = "Упс, что-то пошло не так";
"server_error" = "Ошибка сервера, попробуйте позже";

View file

@ -15,7 +15,7 @@
<BuildableReference
BuildableIdentifier = "primary"
BlueprintIdentifier = "6741A93D1BF340DE002C974C"
BuildableName = "Organic Maps (Debug).app"
BuildableName = "Tourism (Debug).app"
BlueprintName = "OMaps"
ReferencedContainer = "container:Maps.xcodeproj">
</BuildableReference>
@ -70,7 +70,7 @@
<BuildableReference
BuildableIdentifier = "primary"
BlueprintIdentifier = "6741A93D1BF340DE002C974C"
BuildableName = "Organic Maps (Debug).app"
BuildableName = "Tourism (Debug).app"
BlueprintName = "OMaps"
ReferencedContainer = "container:Maps.xcodeproj">
</BuildableReference>
@ -87,7 +87,7 @@
<BuildableReference
BuildableIdentifier = "primary"
BlueprintIdentifier = "6741A93D1BF340DE002C974C"
BuildableName = "Organic Maps (Debug).app"
BuildableName = "Tourism (Debug).app"
BlueprintName = "OMaps"
ReferencedContainer = "container:Maps.xcodeproj">
</BuildableReference>

View file

@ -65,7 +65,7 @@ class SignInViewController: UIViewController {
}()
private let signInButton: AppButton = {
let button = AppButton(label: L("sign_in"), isPrimary: true, target: SignInViewController.self, action: #selector(signInTapped))
let button = AppButton(label: L("sign_in"), isPrimary: true, target: self, action: #selector(signInTapped))
return button
}()
@ -77,15 +77,39 @@ class SignInViewController: UIViewController {
return button
}()
private let developedByLabel: UILabel = {
let label = UILabel()
label.text = L("developed_by_label")
label.textColor = .white
UIKitFont.applyStyle(to: label, style: UIKitFont.h4)
applyWrapContent(label: label)
label.translatesAutoresizingMaskIntoConstraints = false
return label
}()
override func viewDidLoad() {
super.viewDidLoad()
setupViews()
}
private func setupViews() {
let gradientView = UIView(frame: CGRect(x: 0, y: view.height - 100, width: view.width, height: 100))
let tapGesture = UITapGestureRecognizer(target: self, action: #selector(developedByLabelTapped))
gradientView.addGestureRecognizer(tapGesture)
gradientView.isUserInteractionEnabled = true
let gradient = CAGradientLayer()
gradient.frame = gradientView.bounds
gradient.colors = [UIColor.clear.cgColor, UIColor.black.cgColor]
gradientView.layer.insertSublayer(gradient, at: 0)
view.addSubview(backgroundImageView)
view.addSubview(backButton)
view.addSubview(containerView)
view.addSubview(gradientView)
view.addSubview(developedByLabel)
containerView.addSubview(blurView)
containerView.addSubview(titleLabel)
@ -139,7 +163,10 @@ class SignInViewController: UIViewController {
// Forgot Password Button
forgotPasswordButton.topAnchor.constraint(equalTo: signInButton.bottomAnchor, constant: 20),
forgotPasswordButton.leadingAnchor.constraint(equalTo: containerView.leadingAnchor, constant: 32),
forgotPasswordButton.bottomAnchor.constraint(equalTo: containerView.bottomAnchor, constant: -32)
forgotPasswordButton.bottomAnchor.constraint(equalTo: containerView.bottomAnchor, constant: -32),
developedByLabel.trailingAnchor.constraint(equalTo: view.trailingAnchor, constant: -16),
developedByLabel.bottomAnchor.constraint(equalTo: view.bottomAnchor, constant: -32)
])
backButton.addTarget(self, action: #selector(backButtonTapped), for: .touchUpInside)
@ -174,6 +201,13 @@ class SignInViewController: UIViewController {
self.navigationController?.popViewController(animated: false)
}
@objc func developedByLabelTapped() {
print("developedByLabelTapped")
if let url = URL(string: "https://rebus.tj") {
UIApplication.shared.open(url)
}
}
// MARK: - other functions
private func showError(message: String) {
signInButton.isLoading = false

View file

@ -93,7 +93,7 @@ class SignUpViewController: UIViewController {
}()
private let signUpButton: AppButton = {
let button = AppButton(label: L("sign_up"), isPrimary: true, target: SignUpViewController.self, action: #selector(signUpClicked))
let button = AppButton(label: L("sign_up"), isPrimary: true, target: self, action: #selector(signUpClicked))
return button
}()

View file

@ -43,7 +43,7 @@ class WelcomeViewController: UIViewController {
let button = AppButton(
label: L("sign_in"),
isPrimary: true,
target: WelcomeViewController.self,
target: self,
action: #selector(signInClicked)
)
return button
@ -53,7 +53,7 @@ class WelcomeViewController: UIViewController {
let button = AppButton(
label: L("sign_up"),
isPrimary: true,
target: WelcomeViewController.self,
target: self,
action: #selector(signUpClicked)
)
return button

View file

@ -9,7 +9,7 @@ class PasswordTextField: AuthTextField {
button.setImage(eyeSlashImg, for: .normal)
button.setImage(eyeImage, for: .selected)
button.tintColor = .white
button.addTarget(PasswordTextField.self, action: #selector(togglePasswordVisibility), for: .touchUpInside)
button.addTarget(self, action: #selector(togglePasswordVisibility), for: .touchUpInside)
button.translatesAutoresizingMaskIntoConstraints = false
return button
}()

View file

@ -113,6 +113,9 @@ class ProfileViewModel: ObservableObject {
}
private func updatePersonalDataInMemory(personalData: PersonalData) {
if let pfpUrl = personalData.pfpUrl {
self.pfpFromRemote = URL(string: pfpUrl)
}
self.fullName = personalData.fullName
self.email = personalData.email
self.countryCodeName = personalData.country