Hauptmenü

Werkzeuge

Kategorien

Archiv

AbstractConditionViewHelper in TYPO3 11

Erstellt in Extension Entwicklung, TYPO3 am 3. September 2023 vom Daschmi

Ich habe mit TYPO3 einen „inArray“ ViewHelper verwendet, dieser sah in TYPO3 10 wie folgt aus:

class InArrayViewHelper extends \TYPO3Fluid\Fluid\Core\ViewHelper\AbstractConditionViewHelper {  
  
	public function initializeArguments() {  
  
		parent::initializeArguments();  
  
		$this->registerArgument('haystack', 'mixed', 'View helper haystack ', TRUE);  
		$this->registerArgument('needle', 'string', 'View helper needle', TRUE);  
  
	}  

	public function render() {  

		$needle = $this->arguments['needle'];  
		$haystack = $this->arguments['haystack'];  

		if (!is_array($haystack)) {  

			return $this->renderElseChild();  

		}  
	
		if (in_array($needle, $haystack)) {  
	
			return $this->renderThenChild();  
	
		} else {  
	
			return $this->renderElseChild();  
	
		}  

	}

}

Genutzt habe ich ihn zum Beispiel in einem EXT:news Template wie folgt:

<w:inArray haystack="{1:'4',2:'5',3:'6'}" needle="{settings.templateLayout}">  
	<f:then>
		<!-- Template Layout = 4 oder 5 oder 6 -->
	</f:then>	
	<f:else>
		<!-- Sonstiges Template Layout -->
	</f:else>
</w:inArray>

das funktioniert auch noch in TYPO3 11, allerdings nur bis man den Cache aktiviert und die Seite aus dem Cache geladen wird. Wenn man aber statt der render Methode die evaluateCondition Methode überschreibt funktioniert es.

class InArrayViewHelper extends \TYPO3Fluid\Fluid\Core\ViewHelper\AbstractConditionViewHelper {  
  
	public function initializeArguments() {  
  
		parent::initializeArguments();  
  
		$this->registerArgument('haystack', 'mixed', 'View helper haystack ', TRUE);  
		$this->registerArgument('needle', 'string', 'View helper needle', TRUE);  
  
	}  
  
	protected static function evaluateCondition($arguments = null): bool {  
  
		$needle = $arguments['needle'];  
		$haystack = $arguments['haystack'];  
		  
		if (!is_array($haystack)) {  
		  
			return false;  
		  
		}  
		  
		if (in_array($needle, $haystack)) {  
		  
			return true;  
		  
		} else {  
		  
			return false;  
		  
		}  
  
	}  
  
}

So prüfen Sie mit WooCommerce, ob ein Kunde ein Produkt gekauft hat

Erstellt in Allgemein am 27. April 2023 vom Daschmi

Wenn Sie einen WooCommerce-Shop betreiben, kann es nützlich sein zu wissen, ob ein bestimmter Kunde bereits ein bestimmtes Produkt gekauft hat. In diesem Blog-Beitrag zeige ich Ihnen, wie Sie mit einer selbst erstellten Funktion in WooCommerce überprüfen können, ob ein Kunde ein Produkt gekauft hat.

Zunächst müssen Sie die Funktion in Ihrem WooCommerce-Shop einbinden. Öffnen Sie dazu Ihre functions.php-Datei Ihres WordPress-Theme und fügen Sie den folgenden Code am Ende der Datei ein:

abstract class WooHelper {  
     
   public static function check_customer_purchased_product($user_id, $product_id) {  
        
      $customer_orders = \wc_get_orders([  
         'customer_id' => $user_id,  
         'status' => array_keys(\wc_get_order_statuses()),  
      ]);  
    foreach ($customer_orders as $order ) {  
           
         if (self::has_product($order, $product_id)) {  
              
            return true;  
         }  
        
      }  
      
      return false;  
      }  
     
   public static function has_product($order, $product_id) {  
  
      foreach ($order->get_items() as $item) {  
  
         if ($item->get_product_id() == $product_id) {  
  
            return true;  
  
         }  
  
      }  
  
      return false;  
  
   }  
     
}

Sobald Sie den Code in Ihre functions.php-Datei eingefügt haben, können Sie die Funktion in Ihrem Shop verwenden, um zu überprüfen, ob ein Kunde ein bestimmtes Produkt gekauft hat. Die Funktion heißt check_customer_purchased_product und akzeptiert zwei Parameter: user_id (die ID des Kunden, den Sie überprüfen möchten) und product_id (die ID des Produkts, das Sie überprüfen möchten).

if (WooHelper::check_customer_purchased_product($user_id, $product_id)) {
    // Kunden hat das Produkt bereits gekauft
} else {
    // Kunden hat das Produkt noch nicht gekauft
}

Die Funktion durchsucht die Bestellungen des Kunden nach dem angegebenen Produkt und gibt true zurück, wenn der Kunde das Produkt bereits gekauft hat, andernfalls gibt sie false zurück.

Zusammenfassend kann diese selbst erstellte Funktion in WooCommerce nützlich sein, um zu überprüfen, ob ein Kunde bereits ein bestimmtes Produkt gekauft hat. Mit nur wenigen Zeilen Code können Sie diese Funktion in Ihrem Shop implementieren und von ihren Vorteilen profitieren.

Tabindex/Focus bei durch Layer überdeckten Elementen

Erstellt in Javascript am 3. Februar 2023 vom Daschmi

Liegt über einem focusierbaren Element z.B. ein Layer dann sind diese Elemente weiterhin mit Tastatur auswählbar. Folgendes Script löst das Problem durch temporäres setzen eines negativen tabindex.

Beispiel: https://daschmi.de/static/ds_focuser/

const ds_focuser_open_layer = (el_layer) => {
  
  document.querySelectorAll('button:not([disabled]), [href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex="-1"]):not([disabled]), details:not([disabled]), summary:not(:disabled)').forEach((el) => {

    el.setAttribute('ds_focuser_tabindex', el.getAttribute('tabindex'));
    el.setAttribute('tabindex', '-1');

  });

  el_layer.querySelectorAll('*[ds_focuser_tabindex]').forEach((el) => {
    
    el.setAttribute('tabindex', el.getAttribute('ds_focuser_tabindex'));
    el.removeAttribute('ds_focuser_tabindex');

  });

};

const ds_focuser_close_layer = () => {

  document.querySelectorAll('*[ds_focuser_tabindex]').forEach((el) => {
    
    el.setAttribute('tabindex', el.getAttribute('ds_focuser_tabindex'));
    el.removeAttribute('ds_focuser_tabindex');

  });

};

Auf erste Kindseite leiten, wenn eine Seite Kindseiten hat

Erstellt in PHP, Wordpress am 20. Januar 2023 vom Daschmi

Mit folgendem Code kann man auf die erste Unterseite umleiten, sofern eine Seite Unterseiten hat. Dies ist nützlich wenn z.B. die Oberseite keinen Inhalt aufweist.

function my_template_redirect() {

  if (\is_page()) {

      $subPages = \get_children([
          'post_parent' => \get_the_ID(),
          'post_type'   => 'page',
          'post_status' => 'publish'
      ]);

      if (sizeof($subPages) > 0) {

          \wp_redirect(\get_permalink(array_shift($subPages)->ID)); exit;

      }

  }

}

\add_action('template_redirect', 'my_template_redirect');