Develop Custom Field in Views
am 03.05.2022 - 16:22 Uhr in
Hallo zusammen,
ich versuche nun schon seit längerem für folgende Aufgabe eine Lösung zu finden und würde mich über Feedback/Hilfe/Ideen freuen:
In einer View möchte ich Daten aus der SQL Tabelle über ein selbst programmiertes Modul ausgeben. Das Modul stellt dabei die Felder in der View bereit. Die SQL Tabelle soll im ersten schritt Node sein, im zweiten meine eigene SQL Tabelle. Leider klappt es bisher selbst für eine Node nicht.
Was funktioniert ist das Einfügen und Anzeigen des Feldes in die View:
customcode.views.inc
function customcode_views_data_alter(array &$data) {
$data['node']['custom_name'] = [
'title' => t('Attendee Name'),
'field' => [
'title' => t('Attendee Name'),
'help' => t('Links a webform submission to a user profile.'),
'id' => 'custom_name',
],
];
}
Das Anzeigen der Daten funktioniert hingegen nicht:
Code.php
namespace Drupal\customcode\Plugin\views\field;
use Drupal\views\Plugin\views\field\FieldPluginBase;
use Drupal\views\ResultRow;
use Drupal\Core\Link;
class Code extends FieldPluginBase {
public function query() {
}
public function render(ResultRow $values) {
// Hier muss das Datenfeld in der SQL Tabelle ausgelesen werden - aber wie???
//folgenden Ansatz habe ich gefunden, aber die Seite gibt dann nur einen Error aus:
$show = $values->_entity;
$show_data = $show->getElementData('name_datenfeld');
return $show_data;
}
Frage: Was genau muss name_datenfeld sein? Das feld einer Node funktioniert bei mir nicht. Auch wenn name_datenfeld der Name einer Tabelle in SQL ist, funktioniert es nicht. Habt ihr Ideen für eine Lösung? Ich würde mich sehr freuen.
- Anmelden oder Registrieren um Kommentare zu schreiben
Ich kann Dir nur empfehlen
am 06.05.2022 - 06:46 Uhr
Ich kann Dir nur empfehlen Devel kint und Extrakint zu installieren.
Dann kannst Du mit dsm($variable); die Werte von Variablen (auch Arrays) ausgeben lassen.
Extra-Kint braucht es, um auch Methoden zeigen zu lassen, mit denen Du an diverse Werte kommst oder auch solche zuweisen kannst.
Also, du musst...
am 30.07.2022 - 17:47 Uhr
... erstmal in. die Datenbank rein.
// Hier muss das Datenfeld in der SQL Tabelle ausgelesen werden - aber wie???
Da gibt es mehrere Methoden in Drupal...
$database = \Drupal::database(); //macht die Verbindung zur DB
$search = '/mein/toller/alias';
$search = '%'.$database->escapeLike($search).'%';
$result = $database->select('path_alias','p')->fields('p')->condition('p.alias',$search,'LIKE')->execute();
Das Beispiel liest aus der Path-alias Tabelle, anschließend kannst Du bei mehreren Treffern eine Schleife über $result machen.
ODER
wenn du nur nodes durchfräsen willst würde ich den entitytypemanager bemühen...
Rhodes
Was ist denn
am 02.08.2022 - 07:55 Uhr
Was ist denn "name_datenfeld"? Ist das ein existierndes Node Feld? Dann gibt es doch eine Feldausgabe in Views, oder?
Also den Wert eines Feldes bekommst Du nicht mit getElementData(), sondern so:
$value = $show->get('name_datenfeld')->value
oder
$value = $show->get('name_datenfeld')->getValue()
Nur zur Erklärung: so ein Views Feld Plugin sollte nicht dazu genutzt, in dem Plugin selbst noch mal SQL Queries auszuführen. Eigentlich ist das Plugin dazu gedacht, der View beim Aufbau der Query zu sagen, welche Daten der Views-Query hinzugefügt werden sollen. Wenn in einem Feld-Plugin noch mal völlig andere SQL-Queries durchgeführt werden, kann das schnell zu einem echten Performance-Fiasko führen und ist halt auch nicht so, wie das gedacht ist.
Was ist denn die Ausgangssituation? Du scheinst mir ja eigentlich Daten aus einer anderen Tabelle hinzufügen zu wollen, kann das sein? Ist das eine Tabelle, die Du in einem Custom Modul hinzugefügt hast? Eine Custom Entity oder etwas ganz anderes? Wenn "name_datenfeld" eine Tabelle ist (das hast Du irgendwie erwähnt) muss das ganz anders gemacht werden.