mirror of
https://github.com/gristlabs/grist-core.git
synced 2024-10-27 20:44:07 +00:00
8ee23f5344
Summary: Fixing https://gristlabs.getgrist.com/doc/check-ins/p/12#a1.s19.r1045.c19 : > Problem: user creates fresh new empty column. Users with access to write to that column, but not modify schema, will not in fact be able to write into it (since on first data entry column type needs to change). Experience is confusing. Refactored `enter_indirection` and `leave_indirection` to a single context manager method for use with `with` instead of `try/finally`. Used the new method in `_ensure_column_accepts_data` around column changing actions converting empty column to data column. Test Plan: Updated a Python test, reflecting that the correct actions are now marked as direct=False. Tested manually that I can now add data to a blank column without schema access, while I wasn't able to before, and I still can't make other schema changes. Reviewers: paulfitz Reviewed By: paulfitz Differential Revision: https://phab.getgrist.com/D3446 |
||
---|---|---|
.. | ||
functions | ||
imports | ||
acl_formula.py | ||
acl.py | ||
action_obj.py | ||
action_summary.py | ||
actions.py | ||
autocomplete_context.py | ||
codebuilder.py | ||
column.py | ||
csv_patch.py | ||
depend.py | ||
docactions.py | ||
docmodel.py | ||
engine.py | ||
gencode.py | ||
gpath.py | ||
grist.py | ||
identifiers.py | ||
import_actions.py | ||
logger.py | ||
lookup.py | ||
main.py | ||
match_counter.py | ||
migrations.py | ||
moment.py | ||
objtypes.py | ||
parse_data.py | ||
records.py | ||
relabeling.py | ||
relation.py | ||
runtests.py | ||
sandbox.py | ||
schema.py | ||
sort_specs.py | ||
summary.py | ||
table_data_set.py | ||
table.py | ||
test_acl_formula.py | ||
test_acl_renames.py | ||
test_actions.py | ||
test_codebuilder.py | ||
test_column_actions.py | ||
test_completion.py | ||
test_default_formulas.py | ||
test_depend.py | ||
test_derived.py | ||
test_display_cols.py | ||
test_docmodel.py | ||
test_engine.py | ||
test_find_col.py | ||
test_formula_error.py | ||
test_formula_undo.py | ||
test_functions.py | ||
test_gencode.py | ||
test_gpath.py | ||
test_import_actions.py | ||
test_logger.py | ||
test_lookups.py | ||
test_match_counter.py | ||
test_migrations.py | ||
test_moment.py | ||
test_record_func.py | ||
test_recordlist.py | ||
test_reflist_rel.py | ||
test_relabeling.py | ||
test_renames2.py | ||
test_renames.py | ||
test_replay.py | ||
test_rules.py | ||
test_side_effects.py | ||
test_sort_spec.py | ||
test_summary2.py | ||
test_summary_choicelist.py | ||
test_summary_undo.py | ||
test_summary.py | ||
test_table_actions.py | ||
test_table_data_set.py | ||
test_temp_rowids.py | ||
test_textbuilder.py | ||
test_treeview.py | ||
test_trigger_formulas.py | ||
test_twowaymap.py | ||
test_types.py | ||
test_undo.py | ||
test_urllib_patch.py | ||
test_user.py | ||
test_useractions.py | ||
testsamples.py | ||
testscript.json | ||
testutil.py | ||
textbuilder.py | ||
treeview.py | ||
twowaymap.py | ||
tzdata.data | ||
urllib_patch.py | ||
user.py | ||
useractions.py | ||
usercode.py | ||
usertypes.py | ||
xmlrunner.py |