2.5. A tartalmi szerkezet kitalálása
A témakör végére képesek leszünk megtervezni a webhelyünk tartalmi szerkezetét, azaz hozzá tudjuk rendelni a különbözőféle közzétenni kívánt információinkat a Drupal adott entitástípusaihoz és -altípusaihoz. Valamint eldöntjük azt is, hogy webhelyünk mely oldalai fognak csak más tartalmak felsorolásából állni (ezek a listaoldalak).
- Először is tartsunk egy szabad ötletbörzét társainkkal arról, hogy egyáltalán milyenféle információkat szeretnénk közzétenni leendő webhelyünkön, és hogy látogatóink mire lesznek várhatóan kiváncsiak. Az ötletelés végén gyűjtsük össze eredményeinket, körülbelül úgy, ahogy az i.6. szakasz - A példaként használt webhelyünkről témakörnél látható.
E felsorolás elemein haladjunk végig egyesével, és döntsük el, hogy valószínűleg melyik entitástípus lenne a legmegfelelőbb számukra. Bár ez nem könnyű elsőre, de segítségünkre lehet pár alapelv szem előtt tartása. Tegyük fel a kérdést, hogy a webhelyünk mely pontjain szeretnénk, hogy feltűnjön egy bizonyos tartalom? Például egy termelői piac esetén kiemelten fontos a nyitvatartási idő szerepeltetése a webhely lehető legtöbb aloldalán, valahol az oldalsávon mondjuk. Erre tökéletesen alkalmas a blokkok használata. Vagy vegyünk egy másik példát: ugyanitt azt szeretnénk, hogy a piacunk árusainak lehessen egy-egy saját bemutatkozó oldala a webhelyen, amit bejelentkezve ők maguk tudnak szerkeszteni. Ehhez viszont jól használható az alaprendszer Node modulja, amelynek részletes jogosultságkezelő képességével ezt könnyen megvalósíthatjuk.
Ezekre a kérdésekre azonban nem csak egy helyes válasz létezhet. Dönthetünk úgy, hogy árusaink előbb említett bemutatkozó oldalait nem önálló tartalomtípusként hozzuk létre, hanem a felhasználói fiókjuk profiloldalát bővítjük ki további információkkal. Ekkor azonban gondolnunk kell arra, hogy a jövőben nem fogja tudni másik felhasználó – például egy kereskedő alkalmazottja – frissíteni a cég adatlapját, ha az felettesének a személyes profiloldala.
- Miután nagyjából csoportosítottuk a közzétenni kívánt tartalmainkat fajtájuk szerint, a következő lépés azok további elkülönítése, de már egy-egy fajtán belül. Maradva a termelői piac webhelyünk példájánál, kitaláltuk, hogy háromféle aloldalt különböztetünk meg: egy teljesen általánosat (például a Címlap és Rólunk oldalakhoz), egy bemutatkozó oldalt az árusainknak és végül egy harmadik oldaltípust az általuk feltöltött recepteknek.
- Erre az oldaltípusokra való csoportosításra az előző lépésben azért volt szükség, mert a most következő mezők megléte, száma, sorrendje, beállításaik stb. mind-mind eltérőek lehetnek az egyes aloldaltípusainknál. Például az árusok bemutatkozó oldalain szükség lehet egy webcím mezőre (amiben linkelni tudja a saját honlapját), ám ennek semmi értelme nem lenne egy recept aloldalán.
- Aztán döntenünk kell arról is, hogy az eddig kitalált tartalomtípusainkat hol és hogyan fogjuk kilistázni? Melyeknek szükséges egy egész listaoldalt elfoglalniuk, és melyeknek elég, ha csak valahol mellékesen vannak felsorolva? Egy listázó (hivatalos nevén nézet) esetén a legelső kérdés, hogy milyen entitásokat listáz. Ha ez megvan, akkor jöhetnek a részletek: milyen szűréssel válogasson az összes elem közül és a leszűrt elemek melyik közös értékük alapján és milyen irányban legyenek sorba állítva. Ehhez persze előbb ki kell választanunk, hogy a listázó bemeneteként használt entitástípus tulajdonságai közül egyáltalán melyiket vegye figyelembe megjelenítéskor? Amikor például recepteket sorolunk majd fel a termelői piac webhelyünk erre szolgáló listaoldalán, és szeretnénk, ha azon lenne egy „Szükséges hozzávalók” szerinti szűrési lehetőség, akkor a Recept tartalomtípusnak kell, hogy legyen egy Összetevők nevű mezője, amire ez a kereső szűrni tud.
- Miután így összegyűjtöttük, hogy milyen mezőkre lesz szükség az egyes tartalomtípusoknál (pontosabban fogalmazva entitásaltípusoknál), a következő feladatunk, hogy meghatározzuk, milyen fajta adatot (például formázatlan vagy HTML-formázott szöveget, dátumot, vagy képet stb.) fog egy-egy mező tárolni. A mezők legtöbbször egy értéket tudnak tárolni, de vannak kivételek: a Recept tartalomtípusunknál használt, fentebb is említett Összetevők mezőnk például több értéket is képes lesz majd tárolni (például a répa, krumpli, zeller 3 különböző érték lehet egyetlen mezőben).
- Megvannak a mezőink, ez nagyszerű. De hogy ne kelljen majd a felhasználóinknak minden egyes recept beküldésekor kézzel begépelni a zöldségek neveit, sőt, az egyező zöldségnevek valahogy központilag kezelhetőek legyenek, ezért ki kell találnunk egy megoldást arra, hogyan alakítsunk ki kapcsolatot közöttük. E célra jó lehet valamilyen egységes címkézés (a későbbiekben taxonómiaként említjük majd), ezért mezőink alakuló listája mentén gondoljuk át, melyeknél lehet majd hasznos egy ilyen hivatkozott értékadás? Az előbb csak egy példát említettünk a receptek összetevőivel, de hasonlóan működhet például az Árusok bemutatkozó oldalának szerkesztésekor a standjaik kiválasztása egy adminisztrátorok által előre felvitt listából.
- Már majdnem kész vagyunk a tervezéssel: a mezők azonban nemcsak címkékre hivatkozhatnak, hanem más tartalmi egységekre is. Például az árusok fognak recepteket feltölteni a webhelyre, de jó lenne látni az egyes receptek megtekintésekor, hogy ki küldte be őket. Ehhez fel kell venni egy felhasználói fiókra hivatkozó mezőt, amiben ezt az információt majd eltároljuk.
A könnyebb áttekintés kedvéért foglaljuk össze az alábbi táblázatban az eddig példaként említett tervünket:
| Entitástípus | Entitásaltípus | Példák | Mezők |
|---|---|---|---|
Tartalmi egység | Egyszerű oldal | Címlap, Rólunk | Cím, Törzs |
Tartalmi egység | Árus | A piac kereskedőinek bemutatkozó oldalai | Árus neve, Törzs, Fotó, Webcím |
Tartalmi egység | Recept | Beküldött receptek külön oldalakon | Étel neve, Törzs, Étel fotója, Beküldő árusra hivatkozás, Összetevők címkékként |
Egyéni blokk | (nincs altípusa) | Szerzői jogi megjegyzés a láblécben Nyitvatartási idő és helyszín az oldalsávra | Nincsenek egyéni mezői |
Taxonómiakifejezés | Összetevők | Répa, krumpli, zeller és más zöldségek | Nincsenek egyéni mezői |
Kapcsolatfelvételi űrlap | (nincs altípusa) | Általános webhelyszintű | Név, e-mail, tárgy, üzenet |
Felhasználói fiók | (nincs altípusa) | Nem lesz megjelenítve nyilvánosan | Nincsenek egyéni mezői |
Listaoldalakból (nézetekből) pedig ezekre lesz szükségünk:
| Oldal vagy oldalrégió | Entitástípus és -altípus | Szűrés, rendezés, lapozás | Megjelenített mezők |
|---|---|---|---|
Árusok listaoldal | Árus tartalmakat listáz | Mindegyik, ábécérendben, lapozóval | Árus neve és fotója, Törzs mező rövidítve |
Receptek listaoldal | Recept tartalmakat listáz | Szűrés hozzávalók szerint, ábécérendben | Étel fotója és neve |
Legújabb receptek, oldalsávon | Recept tartalmakat listáz | Az öt legutóbb beküldött | Étel fotója és neve |
A tartalmi szerkezet kitalálása
Közreműködők
Írta és szerkesztette: Jennifer Hodgdon és Grant Dunham. Fordította: Balu Ertl (Brainsum).
Source file: planning-structure.asciidoc
Help improve this page
You can:
- Log in, click Edit, and edit this page
- Log in, click Discuss, update the Page status value, and suggest an improvement
- Log in and create a Documentation issue with your suggestion