protected override ModalEditViewController CreateModalEditViewController(UIViewController parent) { var scrollView = new UIScrollView() { // Note that only height matters, the width values will be overwritten Frame = new CoreGraphics.CGRect(0, 0, 0, 340) }; var stackView = new UIStackView() { TranslatesAutoresizingMaskIntoConstraints = false, Axis = UILayoutConstraintAxis.Vertical }; scrollView.AddSubview(stackView); stackView.ConfigureForVerticalScrolling(scrollView, top: 8, bottom: 16); _switches = new Tuple <DayOfWeek, BareUISwitch> [7]; DayOfWeek day = DayOfWeek.Monday; for (int i = 0; i < _switches.Length; i++, day = (DayOfWeek)(((int)day + 1) % 7)) { var daySwitch = new BareUISwitch() { TranslatesAutoresizingMaskIntoConstraints = false, Header = DateTools.ToLocalizedString(day) }; _switches[i] = new Tuple <DayOfWeek, BareUISwitch>(day, daySwitch); stackView.AddArrangedSubview(daySwitch); daySwitch.StretchWidth(stackView); daySwitch.SetHeight(44); if (i != _switches.Length - 1) { stackView.AddDivider(); } } return(new ModalEditViewController(scrollView, HeaderText, parent)); }
public override void OnViewModelLoadedOverride() { Title = ViewModel.State == AddHomeworkViewModel.OperationState.Adding ? ViewModel.Type == AddHomeworkViewModel.ItemType.Homework ? "Add Task" : "Add Event" : ViewModel.Type == AddHomeworkViewModel.ItemType.Homework ? "Edit Task" : "Edit Event"; AddTopSectionDivider(); AddTextField(new UITextField() { Placeholder = "Name", ReturnKeyType = UIReturnKeyType.Done, EnablesReturnKeyAutomatically = true }, nameof(ViewModel.Name), firstResponder: ViewModel.State == AddHomeworkViewModel.OperationState.Adding); AddDivider(); var dateContainer = new UIStackView() { Axis = UILayoutConstraintAxis.Vertical }; { var datePicker = new BareUIInlineDatePicker(this, left: 16, right: 16) { TranslatesAutoresizingMaskIntoConstraints = false }; BindingHost.SetDateBinding(datePicker, nameof(ViewModel.Date)); dateContainer.AddArrangedSubview(datePicker); datePicker.StretchWidth(dateContainer); datePicker.SetHeight(44); AddDivider(dateContainer); } AddUnderVisiblity(dateContainer, nameof(ViewModel.IsDatePickerVisible)); var classContainer = new UIStackView() { Axis = UILayoutConstraintAxis.Vertical }; { var pickerClass = new BareUIInlinePickerView(this, left: 16, right: 16) { TranslatesAutoresizingMaskIntoConstraints = false, HeaderText = "Class", ItemToViewConverter = ConvertClassToInlineView }; BindingHost.SetItemsSourceBinding(pickerClass, nameof(ViewModel.Classes)); BindingHost.SetSelectedItemBinding(pickerClass, nameof(ViewModel.Class)); classContainer.AddArrangedSubview(pickerClass); pickerClass.StretchWidth(classContainer); pickerClass.SetHeight(44); AddDivider(classContainer); } AddUnderVisiblity(classContainer, nameof(ViewModel.IsClassPickerVisible)); var gradeWeightContainer = new UIStackView() { Axis = UILayoutConstraintAxis.Vertical }; { var pickerGradeWeight = new BareUIInlinePickerView(this, left: 16, right: 16) { TranslatesAutoresizingMaskIntoConstraints = false, HeaderText = "Grade Category" }; BindingHost.SetItemsSourceBinding(pickerGradeWeight, nameof(ViewModel.WeightCategories)); BindingHost.SetSelectedItemBinding(pickerGradeWeight, nameof(ViewModel.SelectedWeightCategory)); gradeWeightContainer.AddArrangedSubview(pickerGradeWeight); pickerGradeWeight.StretchWidth(gradeWeightContainer); pickerGradeWeight.SetHeight(44); AddDivider(gradeWeightContainer); } AddUnderVisiblity(gradeWeightContainer, nameof(ViewModel.IsWeightCategoryPickerVisible)); var pickerTime = new BareUIInlinePickerView(this, left: 16, right: 16) { TranslatesAutoresizingMaskIntoConstraints = false, HeaderText = "Time" }; BindingHost.SetItemsSourceBinding(pickerTime, nameof(ViewModel.TimeOptions)); BindingHost.SetSelectedItemBinding(pickerTime, nameof(ViewModel.SelectedTimeOption)); StackView.AddArrangedSubview(pickerTime); pickerTime.StretchWidth(StackView); pickerTime.SetHeight(44); var stackViewPickerCustomTime = new UIStackView() { Axis = UILayoutConstraintAxis.Vertical }; AddDivider(stackViewPickerCustomTime); if (ViewModel.Type == AddHomeworkViewModel.ItemType.Homework) { var pickerDueTime = new BareUIInlineTimePicker(this, left: 16, right: 16) { TranslatesAutoresizingMaskIntoConstraints = false, HeaderText = "Due Time" }; BindingHost.SetTimeBinding(pickerDueTime, nameof(ViewModel.StartTime)); stackViewPickerCustomTime.AddArrangedSubview(pickerDueTime); pickerDueTime.StretchWidth(stackViewPickerCustomTime); pickerDueTime.SetHeight(44); } else { var pickerStartTime = new BareUIInlineTimePicker(this, left: 16, right: 16) { TranslatesAutoresizingMaskIntoConstraints = false, HeaderText = "Start Time" }; BindingHost.SetTimeBinding(pickerStartTime, nameof(ViewModel.StartTime)); stackViewPickerCustomTime.AddArrangedSubview(pickerStartTime); pickerStartTime.StretchWidth(stackViewPickerCustomTime); pickerStartTime.SetHeight(44); AddDivider(stackViewPickerCustomTime); var pickerEndTime = new BareUIInlineTimePicker(this, left: 16, right: 16) { TranslatesAutoresizingMaskIntoConstraints = false, HeaderText = "End Time" }; BindingHost.SetTimeBinding(pickerEndTime, nameof(ViewModel.EndTime)); stackViewPickerCustomTime.AddArrangedSubview(pickerEndTime); pickerEndTime.StretchWidth(stackViewPickerCustomTime); pickerEndTime.SetHeight(44); } var pickerCustomTimeContainer = new BareUIVisibilityContainer() { Child = stackViewPickerCustomTime }; BindingHost.SetVisibilityBinding(pickerCustomTimeContainer, nameof(ViewModel.IsStartTimePickerVisible)); StackView.AddArrangedSubview(pickerCustomTimeContainer); pickerCustomTimeContainer.StretchWidth(StackView); AddSectionDivider(); var detailsView = new BareUITextView() { TranslatesAutoresizingMaskIntoConstraints = false, Placeholder = "Details" }; BindingHost.SetTextViewTextBinding(detailsView.TextView, nameof(ViewModel.Details)); StackView.AddArrangedSubview(detailsView); detailsView.StretchWidth(StackView); detailsView.SetHeight(130); if (ViewModel.IsRepeatsVisible) { AddSectionDivider(); var switchRepeats = new BareUISwitch() { TranslatesAutoresizingMaskIntoConstraints = false, Header = PowerPlannerResources.GetString("RepeatingEntry_CheckBoxRepeats.Content") }; BindingHost.SetSwitchBinding(switchRepeats, nameof(ViewModel.Repeats)); StackView.AddArrangedSubview(switchRepeats); switchRepeats.StretchWidth(StackView); switchRepeats.SetHeight(44); StackView.AddUnderLazyVisibility(BindingHost, nameof(ViewModel.Repeats), delegate { var recurrenceContainer = new UIStackView() { Axis = UILayoutConstraintAxis.Vertical }; { recurrenceContainer.AddDivider(); var tryForFreeContainer = new UIStackView() { Axis = UILayoutConstraintAxis.Vertical }; { tryForFreeContainer.AddSpacing(16); var tryForFreeLabel = new UILabel() { TranslatesAutoresizingMaskIntoConstraints = false, Text = PowerPlannerResources.GetString("RepeatingEntry_TextBlockTryForFree.Text"), Font = UIFont.PreferredCaption1, TextColor = UIColor.Red, Lines = 0 }; tryForFreeContainer.AddArrangedSubview(tryForFreeLabel); tryForFreeLabel.StretchWidth(tryForFreeContainer, left: 16, right: 16); tryForFreeContainer.AddSpacing(16); tryForFreeContainer.AddDivider(); } recurrenceContainer.AddUnderVisiblity(tryForFreeContainer, BindingHost, nameof(ViewModel.ShowRepeatingPremiumTrial)); var mustUpgradeContainer = new UIStackView() { Axis = UILayoutConstraintAxis.Vertical }; { mustUpgradeContainer.AddSpacing(16); var mustUpgradeLabel = new UILabel() { TranslatesAutoresizingMaskIntoConstraints = false, Text = PowerPlannerResources.GetString("RepeatingEntry_TextBlockMustUpgrade.Text"), Font = UIFont.PreferredCaption1, TextColor = UIColor.Red, Lines = 0 }; mustUpgradeContainer.AddArrangedSubview(mustUpgradeLabel); mustUpgradeLabel.StretchWidth(mustUpgradeContainer, left: 16, right: 16); mustUpgradeContainer.AddSpacing(8); var buttonUpgrade = PowerPlannerUIHelper.CreatePowerPlannerBlueButton(PowerPlannerResources.GetString("Settings_UpgradeToPremium_ButtonUpgrade.Content")); buttonUpgrade.TranslatesAutoresizingMaskIntoConstraints = false; buttonUpgrade.TouchUpInside += new WeakEventHandler <EventArgs>(delegate { ViewModel.UpgradeToPremiumForRepeating(); }).Handler; mustUpgradeContainer.AddArrangedSubview(buttonUpgrade); buttonUpgrade.StretchWidth(mustUpgradeContainer, left: 16, right: 16); mustUpgradeContainer.AddSpacing(16); mustUpgradeContainer.AddDivider(); } recurrenceContainer.AddUnderVisiblity(mustUpgradeContainer, BindingHost, nameof(ViewModel.ShowRepeatingMustUpgradeToPremium)); var recurrenceView = new UIRecurrenceView(this) { TranslatesAutoresizingMaskIntoConstraints = false, ViewModel = ViewModel.RecurrenceControlViewModel }; BindingHost.SetIsEnabledBinding(recurrenceView, nameof(ViewModel.IsRepeatingEntryEnabled)); recurrenceContainer.AddArrangedSubview(recurrenceView); recurrenceView.StretchWidth(recurrenceContainer); recurrenceContainer.AddDivider(); recurrenceContainer.AddSpacing(16); var labelNoteCannotBulkEdit = new UILabel() { TranslatesAutoresizingMaskIntoConstraints = false, Text = PowerPlannerResources.GetString("RepeatingEntry_TextBlockNoteCannotBulkEdit.Text"), Font = UIFont.PreferredCaption1, TextColor = UIColor.LightGray, Lines = 0 }; recurrenceContainer.AddArrangedSubview(labelNoteCannotBulkEdit); labelNoteCannotBulkEdit.StretchWidth(recurrenceContainer, left: 16, right: 16); recurrenceContainer.AddSpacing(16); } return(recurrenceContainer); }); } AddBottomSectionDivider(); BackButtonText = "Cancel"; PositiveNavBarButton = new PopupRightNavBarButtonItem("Save", delegate { Save(); }); base.OnViewModelLoadedOverride(); }
public static void AddBottomSectionDivider(this UIStackView stackView) { stackView.AddDivider(fullWidth: true); AddSectionDividerWithoutBorder(stackView); }
private void InitializeViews() { // [pickerRepeatsEvery] // 1 - 364 uint[] intervalNumberRange = GenerateNumberSequence(1, 364); var pickerIntervalAndType = new BareUIInlinePickerView(_viewController, left: 16, right: 16) { TranslatesAutoresizingMaskIntoConstraints = false, HeaderText = PowerPlannerResources.GetString("RepeatingEntry_TextBlockRepeatEvery.Text"), Components = new IEnumerable[] { intervalNumberRange, ViewModel.RepeatOptionsAsStrings }, SelectedItem = new object[] { ViewModel.GetRepeatIntervalAsNumber(), ViewModel.SelectedRepeatOptionAsString } }; pickerIntervalAndType.SelectionChanged += PickerIntervalAndType_SelectionChanged; this.AddArrangedSubview(pickerIntervalAndType); pickerIntervalAndType.StretchWidth(this); pickerIntervalAndType.SetHeight(44); var repeatOnContainer = new UIStackView() { Axis = UILayoutConstraintAxis.Vertical }; { repeatOnContainer.AddDivider(); _pickerRepeatOn = new UIInlineMultiDayPickerView(_viewController, left: 16, right: 16) { TranslatesAutoresizingMaskIntoConstraints = false, HeaderText = PowerPlannerResources.GetString("RepeatingEntry_TextBlockRepeatOn.Text"), SelectedDays = ViewModel.DayCheckBoxes.Where(i => i.IsChecked).Select(i => i.DayOfWeek).ToArray() }; _pickerRepeatOn.SelectionsChanged += PickerRepeatOn_SelectionsChanged; repeatOnContainer.AddArrangedSubview(_pickerRepeatOn); _pickerRepeatOn.StretchWidth(repeatOnContainer); _pickerRepeatOn.SetHeight(44); } this.AddUnderVisiblity(repeatOnContainer, _bindingHost, nameof(ViewModel.AreDayCheckBoxesVisible)); this.AddDivider(); var pickerEndType = new BareUIInlinePickerView(_viewController, left: 16, right: 16) { TranslatesAutoresizingMaskIntoConstraints = false, HeaderText = PowerPlannerResources.GetString("RepeatingEntry_TextBlockEnds.Text"), ItemsSource = new string[] { PowerPlannerResources.GetString("RepeatingEntry_RadioButtonEndsOn.Content"), PowerPlannerResources.GetString("RepeatingEntry_RadioButtonEndsAfter.Content") } }; if (ViewModel.SelectedEndOption == RecurrenceControlViewModel.EndOptions.Date) { pickerEndType.SelectedItem = pickerEndType.ItemsSource.OfType <object>().First(); } else { pickerEndType.SelectedItem = pickerEndType.ItemsSource.OfType <object>().Last(); } pickerEndType.SelectionChanged += PickerEndType_SelectionChanged; this.AddArrangedSubview(pickerEndType); pickerEndType.StretchWidth(this); pickerEndType.SetHeight(44); var endDateContainer = new UIStackView() { Axis = UILayoutConstraintAxis.Vertical }; { endDateContainer.AddDivider(); var endDatePicker = new BareUIInlineDatePicker(_viewController, left: 16, right: 16) { TranslatesAutoresizingMaskIntoConstraints = false, HeaderText = PowerPlannerResources.GetString("EditHomeworkPage_DatePickerDate.Header"), // "Date" Date = ViewModel.EndDate }; endDatePicker.DateChanged += EndDatePicker_DateChanged; endDateContainer.AddArrangedSubview(endDatePicker); endDatePicker.StretchWidth(endDateContainer); endDatePicker.SetHeight(44); } this.AddUnderVisiblity(endDateContainer, _bindingHost, nameof(ViewModel.IsEndDateChecked)); var endOccurrencesContainer = new UIStackView() { Axis = UILayoutConstraintAxis.Vertical }; { endOccurrencesContainer.AddDivider(); var endOccurrencesPicker = new BareUIInlinePickerView(_viewController, left: 16, right: 16) { TranslatesAutoresizingMaskIntoConstraints = false, HeaderText = PowerPlannerResources.GetCapitalizedString("RepeatingEntry_TextBlockOccurrences.Text"), ItemsSource = GenerateNumberSequence(2, 50), SelectedItem = ViewModel.GetEndOccurrencesAsNumber() }; endOccurrencesPicker.SelectionChanged += EndOccurrencesPicker_SelectionChanged; endOccurrencesContainer.AddArrangedSubview(endOccurrencesPicker); endOccurrencesPicker.StretchWidth(endOccurrencesContainer); endOccurrencesPicker.SetHeight(44); } this.AddUnderVisiblity(endOccurrencesContainer, _bindingHost, nameof(ViewModel.IsEndOccurrencesChecked)); }
protected static void AddDivider(UIStackView stackView, bool fullWidth = false) { stackView.AddDivider(fullWidth); }
public override void OnViewModelLoadedOverride() { base.OnViewModelLoadedOverride(); AddTopSectionDivider(); _errorContainer = new BareUIVisibilityContainer() { TranslatesAutoresizingMaskIntoConstraints = false, IsVisible = false }; { var stackViewIncorrect = new UIStackView() { Axis = UILayoutConstraintAxis.Vertical }; stackViewIncorrect.AddArrangedSubview(new UIView() { TranslatesAutoresizingMaskIntoConstraints = false }.SetHeight(8)); _labelError = new UILabel() { TranslatesAutoresizingMaskIntoConstraints = false, Text = "Error", Lines = 0, TextColor = UIColor.Red }; stackViewIncorrect.AddArrangedSubview(_labelError); _labelError.StretchWidth(stackViewIncorrect, left: 16, right: 16); stackViewIncorrect.AddArrangedSubview(new UIView() { TranslatesAutoresizingMaskIntoConstraints = false }.SetHeight(8)); AddDivider(stackViewIncorrect); _errorContainer.Child = stackViewIncorrect; } StackView.AddArrangedSubview(_errorContainer); _errorContainer.StretchWidth(StackView); var textField = new UITextField() { Placeholder = "Provide your email", AutocapitalizationType = UITextAutocapitalizationType.None, AutocorrectionType = UITextAutocorrectionType.Yes, KeyboardType = UIKeyboardType.EmailAddress, ReturnKeyType = UIReturnKeyType.Done }; textField.AddTarget(new WeakEventHandler <EventArgs>(delegate { _errorContainer.IsVisible = false; }).Handler, UIControlEvent.EditingChanged); AddTextField(textField, nameof(ViewModel.Email), firstResponder: true); AddSectionDivider(); var buttonConvert = new UIButton(UIButtonType.System) { TranslatesAutoresizingMaskIntoConstraints = false }; buttonConvert.TouchUpInside += new WeakEventHandler <EventArgs>(async delegate { ShowLoadingOverlay(); await ViewModel.CreateOnlineAccountAsync(); HideLoadingOverlay(); }).Handler; buttonConvert.SetTitle("Convert to Online Account", UIControlState.Normal); StackView.AddArrangedSubview(buttonConvert); buttonConvert.StretchWidth(StackView); buttonConvert.SetHeight(44); var mergeExistingContainer = new UIStackView() { Axis = UILayoutConstraintAxis.Vertical }; { mergeExistingContainer.AddSectionDivider(); mergeExistingContainer.AddSpacing(16); var labelMergeExistingExplanation = new UILabel() { TranslatesAutoresizingMaskIntoConstraints = false, Text = PowerPlannerResources.GetString("Settings_ConvertToOnline_TextBlockConfirmMergeExisting.Text"), Lines = 0, TextColor = UIColor.Red }; mergeExistingContainer.AddArrangedSubview(labelMergeExistingExplanation); labelMergeExistingExplanation.StretchWidth(mergeExistingContainer, left: 16, right: 16); mergeExistingContainer.AddSpacing(16); mergeExistingContainer.AddDivider(); var buttonContinue = new UIButton(UIButtonType.System) { TranslatesAutoresizingMaskIntoConstraints = false, TintColor = UIColor.Red }; buttonContinue.TouchUpInside += new WeakEventHandler <EventArgs>(async delegate { ShowLoadingOverlay(); await ViewModel.MergeExisting(); HideLoadingOverlay(); }).Handler; buttonContinue.SetTitle(PowerPlannerResources.GetString("Settings_ConfirmIdentityPage_ButtonContinue.Content"), UIControlState.Normal); mergeExistingContainer.AddArrangedSubview(buttonContinue); buttonContinue.StretchWidth(mergeExistingContainer); buttonContinue.SetHeight(44); mergeExistingContainer.AddDivider(); var buttonCancel = new UIButton(UIButtonType.System) { TranslatesAutoresizingMaskIntoConstraints = false }; buttonCancel.TouchUpInside += new WeakEventHandler <EventArgs>(delegate { ViewModel.CancelMergeExisting(); }).Handler; buttonCancel.SetTitle(PowerPlannerResources.GetString("Buttons_Cancel.Content"), UIControlState.Normal); mergeExistingContainer.AddArrangedSubview(buttonCancel); buttonCancel.StretchWidth(mergeExistingContainer); buttonCancel.SetHeight(44); } AddUnderVisiblity(mergeExistingContainer, nameof(ViewModel.ShowConfirmMergeExisting)); AddBottomSectionDivider(); BindingHost.SetBinding(nameof(ViewModel.Error), delegate { if (string.IsNullOrWhiteSpace(ViewModel.Error)) { _errorContainer.IsVisible = false; } else { _errorContainer.IsVisible = true; _labelError.Text = ViewModel.Error; } }); base.OnViewModelLoadedOverride(); }