.. include:: /Includes.rst.txt .. _examples-linked-images: ============= Linked Images ============= .. versionadded:: 13.5.0 Complete link support with TYPO3 link browser integration, additional parameters, and proper URL handling. This guide covers how to create and configure linked images in CKEditor, including the link browser integration, click behavior options, and URL parameters. .. contents:: Table of Contents :depth: 3 :local: Click Behavior Options ====================== The image dialog provides three click behavior options: .. figure:: /Images/Examples/ClickBehaviorOptions.png :alt: Click Behavior options showing None, Enlarge, and Link radio buttons :class: with-shadow The Click Behavior section with three options: None, Enlarge, and Link .. confval:: None :name: click-behavior-none Image is not clickable. No link is applied. .. confval:: Enlarge :name: click-behavior-enlarge Opens the full-size image in a lightbox/popup. Uses the ``enableZoom`` attribute and TYPO3's built-in popup handling. See :ref:`examples-advanced-features` for lightbox integration. .. confval:: Link :name: click-behavior-link Wraps the image in a custom link. Opens the TYPO3 link browser to select the link target. Link Browser Integration ======================== When "Link" click behavior is selected, editors can use TYPO3's link browser to select link targets: .. figure:: /Images/Examples/LinkBrowserDialog.png :alt: TYPO3 Link Browser dialog with Page, File, Folder, External URL, Telephone, and Email tabs :class: with-shadow The TYPO3 Link Browser for selecting link targets Supported Link Types -------------------- - **Page**: Internal TYPO3 pages (``t3://page?uid=123``) - **File**: Files from FAL (``t3://file?uid=456``) - **Folder**: Folder references - **URL**: External URLs (``https://example.com``) - **Email**: Email links (``mailto:info@example.com``) - **Telephone**: Phone links (``tel:+1234567890``) Link Attributes --------------- Each link can have the following attributes: .. figure:: /Images/Examples/LinkFieldsExpanded.png :alt: Link fields showing URL, Target, Title, CSS Class, and Additional Parameters :class: with-shadow All link configuration fields in the Image Properties dialog .. rst-class:: dl-parameters Link URL The link target. Can be a TYPO3 link (``t3://...``) or external URL. Link Target Window target for the link: - **(default)**: Same window - **_blank**: New window/tab - **_self**: Same window (explicit) - **_parent**: Parent frame - **_top**: Top frame Link Title Advisory title shown as tooltip on hover. Link CSS Class CSS classes applied to the ```` element. Additional Parameters URL query parameters appended to the link (e.g., ``&L=1&type=123``). TypoLink Format =============== Linked images use TYPO3's TypoLink format internally. Understanding this format helps when debugging or customizing: :: url target class "title" additionalParams .. table:: TypoLink Parameter Order :widths: 10 20 30 40 ======== ============= ========================== ========================= Position Parameter Model Attribute Example ======== ============= ========================== ========================= 1 URL ``linkHref`` ``t3://page?uid=1`` 2 Target ``linkTarget`` ``_blank`` 3 Class ``linkClass`` ``external-link`` 4 Title ``linkTitle`` ``"Click here"`` 5 Params ``linkParams`` ``&L=1&type=123`` ======== ============= ========================== ========================= URL Parameter Handling ====================== Additional parameters are intelligently appended to URLs: Basic Examples -------------- .. code-block:: text # URL without query string /page + &L=1 → /page?L=1 # URL with existing query string /page?foo=bar + &L=1 → /page?foo=bar&L=1 # URL with fragment (preserved at end) /page#section + &L=1 → /page?L=1#section # URL with both query and fragment /page?foo=bar#section + &L=1 → /page?foo=bar&L=1#section PHP Implementation ------------------ The :php:`LinkDto::getUrlWithParams()` method handles all edge cases: .. code-block:: php use Netresearch\RteCKEditorImage\Domain\Model\LinkDto; $link = new LinkDto( url: 'https://example.com/page?existing=param#section', target: '_blank', class: 'external', params: '&utm_source=ckeditor&L=1', isPopup: false, jsConfig: null ); // Returns: https://example.com/page?existing=param&utm_source=ckeditor&L=1#section $fullUrl = $link->getUrlWithParams(); Frontend Rendering ================== Linked images are rendered with the configured attributes: .. code-block:: html Product image Fluid Template Access --------------------- In custom Fluid templates, access link properties via the ``link`` object: .. code-block:: html Clearing Stale Attributes ========================= When selecting a new link from the link browser, all previous link attributes are cleared automatically. This prevents stale values from being retained: .. code-block:: javascript // Before: Image linked to /old-page with target="_blank" and class="old-class" // User selects new link: /new-page with no target or class // After: Only the new URL is set, old attributes are cleared // linkHref: '/new-page' // linkTarget: null (cleared) // linkClass: null (cleared) // linkTitle: null (cleared) // linkParams: null (cleared) This behavior ensures editors always see the actual link configuration without inherited values from previous links. Translations ============ All link-related UI labels are translatable. The following keys are available in ``locallang_be.xlf``: .. code-block:: xml Translations are provided for 31 languages. See ``Resources/Private/Language/`` for the complete list. Troubleshooting =============== Link not saved -------------- **Symptom**: Link attributes are lost after saving. **Cause**: Processing rules may be stripping link attributes. **Solution**: Ensure your RTE processing configuration allows link attributes: .. code-block:: yaml processing: allowAttributes: - { attribute: 'href', elements: 'a' } - { attribute: 'target', elements: 'a' } - { attribute: 'title', elements: 'a' } - { attribute: 'class', elements: 'a' } Link browser doesn't open ------------------------- **Symptom**: Clicking "Browse..." does nothing. **Cause**: JavaScript error or missing backend route. **Solution**: Check browser console for errors. Ensure the extension is properly installed and the ``linkBrowserAction`` route is accessible. Parameters not appended correctly --------------------------------- **Symptom**: URL shows ``/page?foo=bar?L=1`` (double question mark). **Cause**: Parameters are prefixed with ``?`` instead of ``&``. **Solution**: Always use ``&`` prefix for additional parameters. The :php:`getUrlWithParams()` method handles normalization automatically. Related Documentation ===================== - :ref:`examples-advanced-features` - Lightbox/popup integration - :ref:`api-linkdto` - LinkDto API reference - :ref:`ckeditor-model-element` - Model attributes reference - :ref:`examples-template-overrides` - Custom Fluid templates