Link osszekapcsolas

bogargb képe

Sziasztok.
A segitsegeteket szeretnem kerni a kovetkezo temaban. Beleutkoztem abba a problemaba, h pl kirakok egy banner kepet az oldalra es pl kulon field-kent beviszek olyat h link, ahova beirom azt a cimet amire kene ugorjon a kepre kattintva. Ezt a kettot h lehet "osszebaratkoztatni"? Tehat hogy lehet linket rakni egy kep ala, vagy pl e-mail cimet egy nev ala.
Es szinten link problema a masik dolog is. Csinalok 3 viewst: ceg lista, termek listak, altermek listak. Azt szeretnem elerni, hogy a ceg listanal rakattintva egy cegre, kilistazza annak a termekeit, es ott rakattintva vmelyikre, kilistazza annak az altermekeit. Ezt hogy lehet megoldani?
A valaszokat elore is koszi.

Fórum: 
nevergone képe

Én egy elég csúnya megoldást választottam, ha lesz időm, akkor kijavítom, de tény: működik.
Van egy tartalomtípus, amely tartalmazza a banner képét, és a linket, amelyre mutatni fog. A modul neve ptbanner

ptbanner.info

name = PT bannerkezelés
description = PT bannerek megjelenítése
package = PT
version = 6.x-1.0
core = 6.x

ptbanner.module

<?php
 
/* hook_block() implementáció */
function ptbanner_block($op = 'list', $delta = 0, $edit = array())  {
  $cucc = theme('ptbanner_block_output');
  switch ($op) {
    case 'list':
      for ($i=0; $i<7; $i++)  {
        $block[$i]['info'] = 'PT banner '.$i;
        $block[$i]['cache'] = BLOCK_NO_CACHE;
      }
      return $block;
    case 'view':
      $banner_elem = theme('ptbanner_block_output');
      $block['content'] = '<a href="'.$banner_elem['banner_link_url'][$delta].'"><img src="/'.$banner_elem['banner_kep_url'][$delta].'"></a>';
      return $block;
  }
}
 
 
/* hook_theme() implementáció */
function ptbanner_theme($existing, $type, $theme, $path)  {
  return array(
    'ptbanner_block_output' => array(
      'arguments' => array()
    ),
  );
}
 
 
// TODO: elég csúnya megoldás, javítani kell!!!
function ptbanner_sql() {
  $result = db_query (db_rewrite_sql ("SELECT DISTINCT ctb.field_banner_kep_fid, ctb.field_banner_link_url FROM {node} n
              INNER JOIN {content_type_banner} ctb ON n.nid = ctb.nid WHERE n.type = '%s' AND n.status = 1 ORDER BY RAND() LIMIT 7"), 'banner');
  while ($banner = db_fetch_array($result)) {
    $output['banner_link_url'][] = $banner['field_banner_link_url'];
    $result2 = db_query (db_rewrite_sql ("SELECT filepath FROM {files} f WHERE f.fid = '%d'"), $banner['field_banner_kep_fid']);
    while ($banner_img = db_fetch_array($result2))
      $output['banner_kep_url'][] = $banner_img['filepath'];
  }
  return $output;
}
 
 
/* sminkfüggvény a megjelenítéshez */
function theme_ptbanner_block_output() {
  static $result;
  if (!$result)
    $result = ptbanner_sql();
  $output = $result;
  return $output;
}
?>

Az eredményt itt találod.
(Mielőtt valaki megfed: nem vagyok SQL guru.) :)

0
0
bogargb képe

Ezt megcsinaltam, bemasoltam, a drupal felismerte, telepitettem, de sehol semmi valtozas nincs, nem erem el, h hol kene benne dolgozni. Amugy a drupal nemtud ilyent? Marcsak m a fent emlitett problemak sztem sok weblapnal felmerultek mar.

0
0
nevergone képe

Nyilván amit adtam, az egy mintapéldány, amely mutat egy működő konstrukciót. Neked pl. kapásból módosítani kellene a tartalomtípus mezőinek nevét, a létrehozandó blokkok számát, stb.
Amúgy én nem értem, miért kellene ilyent a Drupalnak alapból tudnia.

0
0
bogargb képe

Azert, mert az oldalak legalabb felenel botlik ilyen problemaba az ember. Ha nem banner formajaban akkor, pl amit meg irtam fent: nev ala email cimet rakni, vagy pl a viewsos megoldas. Ezeken kivul biztos van meg hasonlo dolog amit szerettek volna masok megoldani.
Amugy a segitseget koszi, atirom akkor.

0
0
aboros képe

a banneres dolog:
van egy tartalomtípus a 'banner', abban van két mező, a 'kép' és a 'link'. a kettő közül az egyiket rejtettre állítod, a másiknak csinálsz egyedi tpl.php -t (devel modullal lenézed mi legyen annak a pontos neve) abban jelen lesz a $node amiben a másik meződ értéke is szerepel, így 'összeolvaszthatod' a két mezőt.
vagy ami talán elegánsabb, hogy a template_preprocess_node -ban, a 'banner' típusúaknál a két meződ alapján új értéket adsz a $content -nek. (ebben az esetben egy tpl.php -t se kell létrehozni vagy módosítani)

e-mail címet név alá:
ha ezt egy tartalom törzsébe akarod, akkor használd a 'hagyományos' 'a' teget, href="mailto:"
ha mezőként akarsz ilyet felvenni (pl egy 'munkatárs' tartalomtípusnál ugye jól jönne) akkor létezik egy 'link' nevű cck modul, használjad azt!

a 'másik dolog':
ez nem link probléma. nem ártana kicsit többet tudni arról, hogy eddig mit és hogyan csináltál, ennek szerintem nyithatnál egy új témát, amiben részletesebben leírod hol tartasz most, hogy jutottál oda és hova akarsz jutni egyébként. a megoldás valami olyasmi lesz, hogy argumentumokkal szabályozott blokk megjelenésű nézet(ek?) fogják megjeleníteni egy 'cég' 'termékeit' és egy 'termék' 'altermékeit'. hogy pontosan mi-merre, ahhoz több infó kéne.

0
0

-
clear: both;

bogargb képe

Koszi szepen a valaszokat, nagyon kisegitettel:) A link nevu modult ki is probaltam, a celnak tokeletes. A bannerrel is megprobalom majd a doldot, tehat ezek letudva. Tehat lehet koncentralni a viewsra.

Szval arrol lenne szo, h van 3 tartalom tipusom: TERMEK KATEGORIA (pl cipo marka: nike, adidas, skachers), TERMEKLISTA (pl a niken belul 10 cipo kilistazva), TERMEK (a 10 cipobol egyre kattintva arrol az egy termekrol kapjunk leirast)
Az utolso 2-vel nincs gond, az tulajdonkeppen egy views. A kerdes az lenne h a termek kategoriat h tudnam osszekotni a sajat termeklistajaval?
Ebben a peldaban most 3 tartalom tipussal szeretnem csinalni, de lehet ez tobb is.
Remelem ertheto:)

0
0
Nagy Gusztáv képe

Ehhez miért kell külön tartalomtípus? A Views alapból tudja kezelni a lapozást. Szerintem ezt ki kellene hagyni, és tiszta lappal nekifutni.

0
0

Nagy Gusztáv

bogargb képe

Nem lapozasrol van szo hanem termek kategoriak, termeklistak, es termekek kozotti navigalasrol, ugyhogy a listaban szereplo elemek linkkent jelenjenek meg es egymas kozt ossze legyenek kapcsolva.

0
0
thamas képe

Az egyszerűbb: létrehozol egy "Cipő márka" szótárat, ebbe felveszed kategóriáknak a cipő márkákat és a cipő tartalom beküldésénél kiválasztod a megfelelő kategóriát. A szótár elemei listázhatók, az egy katagóriába tartozó node-ok listázhatók, és a node-ok önállóan megjeleníthetőek.

Ha ragaszkodsz ahhoz, hogy minden tartalomtípus legyen, akkor a Node Referece lehet a megoldás. Kiindulásnak nézd meg a legutóbbi DUG videót és olvasd el ezt: http://drupal.hu/tippek/tartalomszervezes2

0
0

Üdvözlettel:
Hajas Tamás

bogargb képe

Talaltam egy tokeletes megoldast erre a link osszekapcsolasos dologra es gondoltam h akkor megosztom veletek is, hatha utkozik meg valaki ebbe a problemaba. Telepitettem az Og modult es ott van egy olyan dolog h book. Azon belul lehet kialakitani szulo-gyerek kapcsolatot es minden kattinthato es osszekotheto tetszes szerint pofon egyszeruen.:)

0
0
Nagy Gusztáv képe

de a Book modulnak nincs köze az OG-hoz.

0
0

Nagy Gusztáv

bogargb képe

Igazad van, kozbe rajottem h csak annyi a koze h az OG keri a bekapcsolasat es igy jottem ra h milyen hasznos modul es eddig nem hasznaltam:)
Kosz a javitast

0
0