[gelöst] form / form_submit / install / schema: Variable Anzahl an Feldern
am 22.09.2016 - 10:35 Uhr in
Hallo Gemeinde,
ich schreibe gerade ein Modul, mit dem ein Redakteur die Breite und Höhe einzelner Divs auf der Startseite justieren kann. Konkret geht es um die Einstellungen für die Masonry "grid-items".
Zunächst soll der Redakteur für jeden einzelnen Node einstellen können, ob er auf der Startseite angezeigt wird. In einem Modul habe ich bereits die Ausgabe in einem Teplate mit Hilfe von EntityFieldQuery erzeugt. Views will ich wegen dem Overhead nicht nutzen.
Nun möchte ich also ein Modul schreiben, mit dem der Redakteur die Einstellungen für Breite und Höhe vornehmen kann. Die Anzahl an Feldern hängt folglich von der Anzahl an Nodes ab, die auf der Startseite angezeigt werden. Und genau hier liegt aktuell mein Problem.
Ich habe bereits einen Block, in dem ein Feld mit Breite und Höhe angezeigt wird, was auch gut funktioniert. Was mir fehlt ist eine Idee, wie ich programmatisch Instanzen von Höhe und Breite erzeugen kann - abhängig von der Anzahl der angezeigten Elemente!?
Hier mein aktueller Stand:
functiontest_frontpage_block_info() {
$blocks['item'] = array(
'info' => t('Test Sizer Block'),
'cache' => DRUPAL_CACHE_PER_ROLE,
);
return $blocks;
}
function test_frontpage_block_view($delta = 'sizerblock') {
$block = array();
switch ($delta) {
case 'sizerblock':
$block['subject'] = t('Sizer Block');
$form = drupal_get_form('test_frontpage_form');
$block['content'] = drupal_render($form);
break;
}
return $block;
}
Hier der hook_form und hook_form_submit:
function test_frontpage_form($form, &$form_state) {
$form = array();
if(empty($form_state['values'])) {
$form['width'] = array(
'#type' => 'textfield',
'#attributes' => array(
'data-type' => 'number',
),
'#title' => t('Width'),
'#required' => TRUE,
'#size' => 2,
'#maxlength' => 2,
);
$form['height'] = array(
'#type' => 'textfield',
'#attributes' => array(
'data-type' => 'number',
),
'#title' => t('Height'),
'#required' => TRUE,
'#size' => 2,
'#maxlength' => 2,
);
} else {
$form['width'] = array(
'#type' => 'textfield',
'#attributes' => array(
'data-type' => 'number',
),
'#title' => t('Width'),
'#required' => TRUE,
'#size' => 2,
'#maxlength' => 2,
'#value' => $form_state['values']['width'],
);
$form['height'] = array(
'#type' => 'textfield',
'#attributes' => array(
'data-type' => 'number',
),
'#title' => t('Height'),
'#required' => TRUE,
'#size' => 2,
'#maxlength' => 2,
'#value' => $form_state['values']['height'],
);
}
$form['submit'] = array(
'#type' => 'submit',
'#value' => 'Submit',
'#submit' => array('test_frontpage_form_submit'),
);
return $form;
}
function test_frontpage_form_submit($form, &$form_state) {
$width = $form_state['values']['width'];
$height = $form_state['values']['height'];
db_update('sizer')
->fields(array(
'width' => $width,
'height' => $height,
))
->execute();
drupal_set_message(t('Successfully saved form data'));
$form_state['rebuild'] = TRUE;
}
Und die hooks im .install-File:
function test_frontpage_install() {
db_insert('sizer')
->fields(array(
'width' => 7,
'height' => 3,
))
->execute();
}
function test_frontpage_schema() {
$schema = array();
$schema['sizer'] = array(
'description' => 'The base table for sizing the frontpage widgets.',
'fields' => array(
'id' => array(
'description' => 'The sizer ID.',
'type' => 'serial',
'not null' => TRUE
),
'width' => array(
'description' => 'The width value.',
'type' => 'int',
'not null' => TRUE,
'default' => 1,
),
'height' => array(
'description' => 'The height value.',
'type' => 'int',
'not null' => TRUE,
'default' => 1,
),
),
'primary key' => array('id'),
);
return $schema;
}
Ich wäre schon dankbar für einen kurzen Hinweis, wonach ich genau suchen soll.
Herzlichen Dank!
- Anmelden oder Registrieren um Kommentare zu schreiben
Install Schema
am 26.09.2016 - 17:10 Uhr
installiert eine Datenbanktabelle.
Die Struktur einer Datenbanktabelle ist relativ statisch.
Für Dein Vorhaben brauchst du aber (mindestens) zwei Datentabellen und einen Referenzschlüssel, über den diese miteinander verbunden sind.
Dafür brauchst du kein Schema, sondern nur contenn_types und musst mit entity_refernces arbeiten.
Aus Performancegründen, oder aus Migrationsgründen kann es dennoch sinnvoll sein, eigene Tabellen anzulegen.
Aber grundsätzlich bringt Drupal ein komplettes Management für Entities und beliebige Strukturen mit.
Grüße
Ronald
Das werde ich versuchen
am 27.09.2016 - 11:54 Uhr
Vielen Dank für den Tipp, Ronald! Das schaue ich mir bei nächster Gelegenheit genauer an.