// // Copyright 2019 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only // import SafariServices import SignalServiceKit import SignalUI import UIKit class ProvisioningSplashViewController: ProvisioningBaseViewController { var prefersNavigationBarHidden: Bool { true } override func viewDidLoad() { super.viewDidLoad() navigationItem.hidesBackButton = true let modeSwitchButton = UIButton( configuration: .plain(), primaryAction: UIAction { [weak self] _ in guard let self else { return } self.provisioningController.provisioningSplashRequestedModeSwitch(viewController: self) }, ) modeSwitchButton.configuration?.image = .linkSlash modeSwitchButton.tintColor = .ows_gray25 view.addSubview(modeSwitchButton) modeSwitchButton.translatesAutoresizingMaskIntoConstraints = false NSLayoutConstraint.activate([ modeSwitchButton.widthAnchor.constraint(equalToConstant: 40), modeSwitchButton.heightAnchor.constraint(equalToConstant: 40), modeSwitchButton.trailingAnchor.constraint(equalTo: contentLayoutGuide.trailingAnchor), modeSwitchButton.topAnchor.constraint(equalTo: contentLayoutGuide.topAnchor), ]) // Image at the top. let imageView = UIImageView(image: .onboardingSplashHero) imageView.contentMode = .scaleAspectFit imageView.layer.minificationFilter = .trilinear imageView.layer.magnificationFilter = .trilinear imageView.setCompressionResistanceLow() imageView.setContentHuggingVerticalLow() let heroImageContainer = UIView.container() heroImageContainer.addSubview(imageView) imageView.translatesAutoresizingMaskIntoConstraints = false // Center image vertically in the available space above title text. NSLayoutConstraint.activate([ imageView.centerXAnchor.constraint(equalTo: heroImageContainer.centerXAnchor), imageView.widthAnchor.constraint(equalTo: heroImageContainer.widthAnchor), imageView.centerYAnchor.constraint(equalTo: heroImageContainer.centerYAnchor), imageView.heightAnchor.constraint(equalTo: heroImageContainer.heightAnchor, constant: 0.8), ]) let titleText = { if TSConstants.isUsingProductionService { return OWSLocalizedString( "ONBOARDING_SPLASH_TITLE", comment: "Title of the 'onboarding splash' view.", ) } else { return "Internal Staging Build\n\(AppVersionImpl.shared.currentAppVersion)" } }() let titleLabel = UILabel.titleLabelForRegistration(text: titleText) titleLabel.accessibilityIdentifier = "onboarding.splash." + "titleLabel" // Terms of service and privacy policy. let tosPPButton = UIButton( configuration: .smallBorderless(title: OWSLocalizedString( "ONBOARDING_SPLASH_TERM_AND_PRIVACY_POLICY", comment: "Link to the 'terms and privacy policy' in the 'onboarding splash' view.", )), primaryAction: UIAction { [weak self] _ in self?.present(SFSafariViewController(url: TSConstants.legalTermsUrl), animated: true) }, ) tosPPButton.configuration?.baseForegroundColor = .Signal.secondaryLabel tosPPButton.enableMultilineLabel() tosPPButton.accessibilityIdentifier = "onboarding.splash.explanationLabel" let continueButton = UIButton( configuration: .largePrimary(title: CommonStrings.continueButton), primaryAction: UIAction { [weak self] _ in guard let self else { return } Task { @MainActor in await self.provisioningController.provisioningSplashDidComplete(viewController: self) } }, ) continueButton.accessibilityIdentifier = "onboarding.splash.continueButton" let stackView = addStaticContentStackView(arrangedSubviews: [ heroImageContainer, titleLabel, tosPPButton, continueButton.enclosedInVerticalStackView(isFullWidthButton: true), ]) stackView.setCustomSpacing(44, after: imageView) stackView.setCustomSpacing(82, after: tosPPButton) view.bringSubviewToFront(modeSwitchButton) } }