Fixed #28357 -- Fixed ModelAdmin.prepopulated_fields on newly added stacked inline.

Thanks Jakob Köhler for the initial patch.
This commit is contained in:
Shubh1815 2021-11-15 19:57:11 +05:30 committed by Mariusz Felisiak
parent 3f0025c18a
commit bb223c6f78
4 changed files with 55 additions and 5 deletions

View File

@ -296,7 +296,13 @@
dependency_list = input.data('dependency_list') || [], dependency_list = input.data('dependency_list') || [],
dependencies = []; dependencies = [];
$.each(dependency_list, function(i, field_name) { $.each(dependency_list, function(i, field_name) {
dependencies.push('#' + row.find('.form-row .field-' + field_name).find('input, select, textarea').attr('id')); // Dependency in a fieldset.
let field_element = row.find('.form-row .field-' + field_name);
// Dependency without a fieldset.
if (!field_element.length) {
field_element = row.find('.form-row.field-' + field_name);
}
dependencies.push('#' + field_element.find('input, select, textarea').attr('id'));
}); });
if (dependencies.length) { if (dependencies.length) {
input.prepopulate(dependencies, input.attr('maxlength')); input.prepopulate(dependencies, input.attr('maxlength'));

View File

@ -3,7 +3,11 @@
const $ = django.jQuery; const $ = django.jQuery;
const fields = $('#django-admin-prepopulated-fields-constants').data('prepopulatedFields'); const fields = $('#django-admin-prepopulated-fields-constants').data('prepopulatedFields');
$.each(fields, function(index, field) { $.each(fields, function(index, field) {
$('.empty-form .form-row .field-' + field.name + ', .empty-form.form-row .field-' + field.name).addClass('prepopulated_field'); $(
'.empty-form .form-row .field-' + field.name +
', .empty-form.form-row .field-' + field.name +
', .empty-form .form-row.field-' + field.name
).addClass('prepopulated_field');
$(field.id).data('dependency_list', field.dependency_list).prepopulate( $(field.id).data('dependency_list', field.dependency_list).prepopulate(
field.dependency_ids, field.maxLength, field.allowUnicode field.dependency_ids, field.maxLength, field.allowUnicode
); );

View File

@ -767,8 +767,22 @@ class RelatedPrepopulatedInline3(admin.TabularInline):
autocomplete_fields = ['fk', 'm2m'] autocomplete_fields = ['fk', 'm2m']
class RelatedPrepopulatedStackedInlineNoFieldsets(admin.StackedInline):
model = RelatedPrepopulated
extra = 1
prepopulated_fields = {
'slug1': ['name', 'pubdate'],
'slug2': ['status'],
}
class MainPrepopulatedAdmin(admin.ModelAdmin): class MainPrepopulatedAdmin(admin.ModelAdmin):
inlines = [RelatedPrepopulatedInline1, RelatedPrepopulatedInline2, RelatedPrepopulatedInline3] inlines = [
RelatedPrepopulatedInline1,
RelatedPrepopulatedInline2,
RelatedPrepopulatedInline3,
RelatedPrepopulatedStackedInlineNoFieldsets,
]
fieldsets = ( fieldsets = (
(None, { (None, {
'fields': (('pubdate', 'status'), ('name', 'slug1', 'slug2', 'slug3')) 'fields': (('pubdate', 'status'), ('name', 'slug1', 'slug2', 'slug3'))

View File

@ -4611,7 +4611,7 @@ class SeleniumTests(AdminSeleniumTestCase):
self.assertEqual(slug2, 'option-two-the-main-name-and-its-awesomeiiii') self.assertEqual(slug2, 'option-two-the-main-name-and-its-awesomeiiii')
self.assertEqual(slug3, 'the-main-n\xe0m\xeb-and-its-aw\u03b5\u0161ome\u0131\u0131\u0131i') self.assertEqual(slug3, 'the-main-n\xe0m\xeb-and-its-aw\u03b5\u0161ome\u0131\u0131\u0131i')
# Stacked inlines ---------------------------------------------------- # Stacked inlines with fieldsets -------------------------------------
# Initial inline # Initial inline
self.selenium.find_element(By.ID, 'id_relatedprepopulated_set-0-pubdate').send_keys('2011-12-17') self.selenium.find_element(By.ID, 'id_relatedprepopulated_set-0-pubdate').send_keys('2011-12-17')
self.select_option('#id_relatedprepopulated_set-0-status', 'option one') self.select_option('#id_relatedprepopulated_set-0-status', 'option one')
@ -4687,6 +4687,32 @@ class SeleniumTests(AdminSeleniumTestCase):
len(self.selenium.find_elements(By.CLASS_NAME, 'select2-selection')), len(self.selenium.find_elements(By.CLASS_NAME, 'select2-selection')),
num_initial_select2_inputs + 6 num_initial_select2_inputs + 6
) )
# Stacked Inlines without fieldsets ----------------------------------
# Initial inline.
row_id = 'id_relatedprepopulated_set-4-0-'
self.selenium.find_element(By.ID, f'{row_id}pubdate').send_keys('2011-12-12')
self.select_option(f'#{row_id}status', 'option one')
self.selenium.find_element(By.ID, f'{row_id}name').send_keys(' sŤāÇkeð inline ! ')
slug1 = self.selenium.find_element(By.ID, f'{row_id}slug1').get_attribute('value')
slug2 = self.selenium.find_element(By.ID, f'{row_id}slug2').get_attribute('value')
self.assertEqual(slug1, 'stacked-inline-2011-12-12')
self.assertEqual(slug2, 'option-one')
# Add inline.
self.selenium.find_elements(
By.LINK_TEXT,
'Add another Related prepopulated',
)[3].click()
row_id = 'id_relatedprepopulated_set-4-1-'
self.selenium.find_element(By.ID, f'{row_id}pubdate').send_keys('1999-01-20')
self.select_option(f'#{row_id}status', 'option two')
self.selenium.find_element(By.ID, f'{row_id}name').send_keys(
' now you haVe anöther sŤāÇkeð inline with a very loooong '
)
slug1 = self.selenium.find_element(By.ID, f'{row_id}slug1').get_attribute('value')
slug2 = self.selenium.find_element(By.ID, f'{row_id}slug2').get_attribute('value')
self.assertEqual(slug1, 'now-you-have-another-stacked-inline-with-a-very-lo')
self.assertEqual(slug2, 'option-two')
# Save and check that everything is properly stored in the database # Save and check that everything is properly stored in the database
with self.wait_page_loaded(): with self.wait_page_loaded():
self.selenium.find_element(By.XPATH, '//input[@value="Save"]').click() self.selenium.find_element(By.XPATH, '//input[@value="Save"]').click()
@ -4699,7 +4725,7 @@ class SeleniumTests(AdminSeleniumTestCase):
slug2='option-two-the-main-name-and-its-awesomeiiii', slug2='option-two-the-main-name-and-its-awesomeiiii',
slug3='the-main-nàmë-and-its-awεšomeıııi', slug3='the-main-nàmë-and-its-awεšomeıııi',
) )
self.assertEqual(RelatedPrepopulated.objects.all().count(), 4) self.assertEqual(RelatedPrepopulated.objects.all().count(), 6)
RelatedPrepopulated.objects.get( RelatedPrepopulated.objects.get(
name=' here is a sŤāÇkeð inline ! ', name=' here is a sŤāÇkeð inline ! ',
pubdate='2011-12-17', pubdate='2011-12-17',