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

Add support for hiding/unhiding objects #884

Merged
merged 31 commits into from
Jul 24, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
9a78a9b
feat: add `is_hidden` field to models
dodumosu Apr 19, 2022
8c34353
feat: add data migration
dodumosu Apr 20, 2022
5487018
feat: update list view and template
dodumosu Apr 22, 2022
efd7261
feat: remove hidden forms and events from UI
dodumosu Apr 22, 2022
477649d
feat: form list hiding (first version)
dodumosu Apr 25, 2022
f0a14ed
fix: ensure toggles work, backend and front end
dodumosu Apr 26, 2022
8bc623c
feat: make RR and QA dashboards inaccessible
dodumosu Apr 26, 2022
921f54e
chore: change logic
dodumosu Apr 26, 2022
515ca89
chore: update fixtures
dodumosu May 4, 2022
1e38016
fix: update fixtures
dodumosu May 4, 2022
ae7c882
fix: update fixtures
dodumosu May 4, 2022
b3d03c2
chore: remove unused import
dodumosu Aug 16, 2023
2ba60c7
feat: reorder migrations and fix rendering
dodumosu Aug 16, 2023
ed20655
feat: don't show hidden events
dodumosu Aug 16, 2023
442926e
fix: specify columns
dodumosu Mar 12, 2024
0cc4940
feat: explicitly make columns not nullable
dodumosu Mar 12, 2024
c070a27
chore: update migration so columns are not nullable
dodumosu Mar 12, 2024
55d7572
chore: change labels
dodumosu Mar 12, 2024
7e45fc9
chore: don't show submissions for archived forms
dodumosu Mar 12, 2024
dc3f7f3
chore: reorder migrations
dodumosu May 1, 2024
fc0d837
fix: set the server_default option on archivable models
dodumosu May 2, 2024
c004063
fix: use correct filter method
dodumosu May 13, 2024
8d4abaf
fix: workaround for flask-admin
dodumosu May 13, 2024
3bb957c
chore: minor refactor
dodumosu May 13, 2024
bc5c973
fix: override parent method in Event admin class
dodumosu May 14, 2024
d046314
chore: add hidden icon, remove default checked status on archived forms
dodumosu May 14, 2024
ad3610f
feat: add custom form converter
dodumosu May 14, 2024
09ff82f
feat: remove hidden location sets when creating/editing participant sets
dodumosu May 14, 2024
cf2be16
chore: refactor
dodumosu May 15, 2024
470ee6c
fix: archival buttons should respond to toggle all checkbox
dodumosu May 16, 2024
684ecfa
feat: various changes
dodumosu May 16, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fix: ensure toggles work, backend and front end
  • Loading branch information
dodumosu committed May 1, 2024
commit f0a14edf8aab8bfe2bbfae395a55b2c4ca63b75f
1 change: 1 addition & 0 deletions apollo/formsframework/forms.py
Original file line number Diff line number Diff line change
Expand Up @@ -489,6 +489,7 @@ class QuestionnaireHiddenToggleForm(SecureForm):
query_factory=_get_forms,
option_widget=wtforms.widgets.CheckboxInput(),
widget=wtforms.widgets.ListWidget(prefix_label=False),
get_pk=lambda f: f.id,
)
mode = wtforms.HiddenField(
validators=[
Expand Down
16 changes: 9 additions & 7 deletions apollo/formsframework/views_forms.py
Original file line number Diff line number Diff line change
Expand Up @@ -227,25 +227,27 @@ def forms_list(view):
query_params = request.args.to_dict(flat=False)
hidden_form_count = models.Form.query.filter(
models.Form.is_hidden == True).count() # noqa
query = models.Form.query.order_by('name')
show_hidden = bool(query_params.get(show_hidden_param))

if show_hidden:
show_toggle_link_label = _('Hide Hidden')
Copy link
Collaborator

Choose a reason for hiding this comment

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

What does "Hide Hidden" mean? The language should probably be clearer than this.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

changed to Hide Archived

add_show_url_param = False
query = models.Form.query.order_by('name')
else:
show_toggle_link_label = _(
'Show All (%(count)d Hidden)', count=hidden_form_count)
Copy link
Collaborator

Choose a reason for hiding this comment

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

Can you explain the rational for having the number of hidden objects displayed here?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

It was to give the user the number of items that weren't being displayed, but it's been removed

add_show_url_param = True
query = models.Form.query.filter(
query = query.filter(
models.Form.is_hidden == False).order_by('name') # noqa

if show_hide_form.validate_on_submit():
posted_data = show_hide_form.data.copy()
if len(posted_data.get('forms')) > 0:
hide_forms = True if posted_data.get('mode') == 'hide' else False
for questionnaire in posted_data.get('forms'):
questionnaire.is_hidden = hide_forms
db.session.commit()
hide_forms = True if posted_data.get('mode') == 'hide' else False
posted_form_ids = [f.id for f in posted_data.get('forms')]
models.Form.query.filter(models.Form.id.in_(posted_form_ids)).update(
{'is_hidden': hide_forms}, synchronize_session='fetch')
db.session.commit()
db.session.expire_all()

all_forms = query.all()
checklist_forms = query.filter(models.Form.form_type == 'CHECKLIST').all()
Expand Down
53 changes: 43 additions & 10 deletions apollo/templates/admin/form_list.html
Original file line number Diff line number Diff line change
Expand Up @@ -361,21 +361,50 @@ <h5 id="formImportModalLabel" class="modal-title">{{ _('Import Form') }}</h5>
var hideButton = document.querySelector('#hide_button');
var modeSelector = document.querySelector('#{{ show_hide_form.mode.id }}');

function toggleActionButtons() {
var numChecked = document.querySelectorAll('input[data-show-toggle]:checked').length;
if (numChecked === 0) {
hideButton.classList.add('invisible');
showButton.classList.add('invisible');
} else {
hideButton.classList.remove('invisible');
showButton.classList.remove('invisible');
}

changeToggleAllState();
}

function changeToggleAllState() {
// change the state of the 'toggle all' checkbox depending on how many checkboxes
// are checked
var numCheckboxes = document.querySelectorAll('input[data-show-toggle]').length;
var numChecked = document.querySelectorAll('input[data-show-toggle]:checked').length;

if (numChecked === 0) {
// none are checked, make it unchecked
toggleAll.indeterminate = false;
toggleAll.checked = false;
} else if (numCheckboxes === numChecked) {
// all are checked, make it checked
toggleAll.indeterminate = false;
toggleAll.checked = true;
} else {
// some are checked, but not all
toggleAll.indeterminate = true;
}
}

toggleForm.addEventListener('click', function (event) {
// capture all clicks on this form. if a form checkbox
// is checked, make the buttons visible
if (event.target.matches('[data-show-toggle]')) {
if (event.target.checked) {
hideButton.classList.remove('invisible');
showButton.classList.remove('invisible');
} else {
var numChecked = document.querySelectorAll('input[data-show-toggle]:checked').length;
toggleActionButtons();
}

if (numChecked === 0) {
hideButton.classList.add('invisible');
showButton.classList.add('invisible');
}
}
if (event.target === toggleAll) {
document.querySelectorAll('input[data-show-toggle]').forEach(function (checkbox) {
checkbox.checked = toggleAll.checked;
});
}
});

Expand All @@ -388,5 +417,9 @@ <h5 id="formImportModalLabel" class="modal-title">{{ _('Import Form') }}</h5>
modeSelector.value = 'hide';
toggleForm.submit();
});

document.addEventListener('DOMContentLoaded', function () {
toggleActionButtons();
});
</script>
{%- endblock %}