Skip to main content
Light Dark System

Tile

<zn-tile> | ZnTile
Since 1.0 experimental

Short summary of the component’s intended use.

Tiles are versatile components designed for building lists of structured content. They provide a consistent, responsive layout for displaying items with associated metadata, images, properties, and actions. Tiles can be clickable links or static containers, making them ideal for user lists, product catalogs, file browsers, and more.

Last seen 2h ago Active now
Contact
Last seen 1d ago
<zn-sp divide no-gap>
  <zn-tile caption="Leslie Alexander" description="leslie.alexander@example.com" href="https://google.com">
    <zn-icon slot="image" size="40" src="https://i.pravatar.cc/60?img=70" round></zn-icon>
    <zn-tile-property slot="properties" caption="Co-Founder / CEO">Last seen 2h ago</zn-tile-property>
  </zn-tile>

  <zn-tile caption="Michael Foster" description="michael.foster@example.com" href="https://google.com">
    <zn-icon slot="image" size="40" src="https://i.pravatar.cc/60?img=51" round></zn-icon>
    <zn-tile-property slot="properties" caption="Engineering Lead">Active now</zn-tile-property>
    <div slot="actions"><zn-button size="small">Contact</zn-button></div>
  </zn-tile>

  <zn-tile caption="Emma Davis" description="emma.davis@example.com">
    <zn-icon slot="image" size="40" src="https://i.pravatar.cc/60?img=47" round></zn-icon>
    <zn-tile-property slot="properties" caption="Product Manager">Last seen 1d ago</zn-tile-property>
  </zn-tile>
</zn-sp>

Examples

Basic Tile

A basic tile displays a caption and description. Tiles automatically apply padding when they contain structured content.

<zn-tile caption="Basic Tile" description="A simple tile with just caption and description"></zn-tile>

Tile with Image

Use the image slot to add an image or icon to the left side of the tile. This is commonly used for avatars, logos, or file icons.

<zn-tile caption="John Smith" description="Senior Developer">
  <zn-icon slot="image" size="40" src="https://i.pravatar.cc/60?img=12" round></zn-icon>
</zn-tile>

Clickable Tiles

Add the href attribute to make a tile clickable. The tile will render as an anchor tag and display hover effects.

<zn-sp divide no-gap>
  <zn-tile caption="Dashboard" description="View your analytics dashboard" href="/dashboard">
    <zn-icon slot="image" size="32" src="dashboard" round></zn-icon>
  </zn-tile>

  <zn-tile caption="Settings" description="Configure your preferences" href="/settings">
    <zn-icon slot="image" size="32" src="settings" round></zn-icon>
  </zn-tile>

  <zn-tile caption="Profile" description="Manage your account" href="/profile">
    <zn-icon slot="image" size="32" src="person" round></zn-icon>
  </zn-tile>
</zn-sp>

Tiles with Properties

Use the properties slot to display metadata on the right side of the tile. The zn-tile-property component provides consistent styling for property labels and values.

In Progress Completed
<zn-sp divide no-gap>
  <zn-tile caption="Project Alpha" description="Active development project">
    <zn-icon slot="image" size="32" src="folder" color="primary"></zn-icon>
    <zn-tile-property slot="properties" caption="Status">In Progress</zn-tile-property>
  </zn-tile>

  <zn-tile caption="Project Beta" description="Testing phase">
    <zn-icon slot="image" size="32" src="folder" color="success"></zn-icon>
    <zn-tile-property slot="properties" caption="Status">Completed</zn-tile-property>
  </zn-tile>
</zn-sp>

Multiple Properties

Add multiple zn-tile-property components to display several pieces of metadata in a horizontal layout.

2 hours ago John Smith 5 people
<zn-tile caption="Annual Report 2024.pdf" description="1.2 MB • PDF Document">
  <zn-icon slot="image" size="32" src="description" color="error"></zn-icon>
  <zn-tile-property slot="properties" caption="Modified">2 hours ago</zn-tile-property>
  <zn-tile-property slot="properties" caption="Owner">John Smith</zn-tile-property>
  <zn-tile-property slot="properties" caption="Shared">5 people</zn-tile-property>
</zn-tile>

Tiles with Actions

Use the actions slot to add buttons or other interactive elements to the right side of the tile.

Run Now
<zn-sp divide no-gap>
  <zn-tile caption="Database Backup" description="Last backup: 2 hours ago">
    <zn-icon slot="image" size="32" src="storage" color="info"></zn-icon>
    <div slot="actions">
      <zn-button size="small" color="primary">Run Now</zn-button>
    </div>
  </zn-tile>

  <zn-tile caption="Email Notification" description="Receive daily summaries">
    <zn-icon slot="image" size="32" src="mail" color="secondary"></zn-icon>
    <div slot="actions">
      <zn-button size="small" color="transparent" icon="edit" square></zn-button>
      <zn-button size="small" color="transparent" icon="delete" square></zn-button>
    </div>
  </zn-tile>
</zn-sp>

Properties with Actions

Combine both properties and actions for comprehensive tile layouts.

Marketing Manager
Message
Engineering Senior Dev
Message
<zn-sp divide no-gap>
  <zn-tile caption="Sarah Johnson" description="sarah.johnson@example.com" href="mailto:sarah.johnson@example.com">
    <zn-icon slot="image" size="40" src="https://i.pravatar.cc/60?img=45" round></zn-icon>
    <zn-tile-property slot="properties" caption="Department">Marketing</zn-tile-property>
    <zn-tile-property slot="properties" caption="Role">Manager</zn-tile-property>
    <div slot="actions">
      <zn-button size="small">Message</zn-button>
    </div>
  </zn-tile>

  <zn-tile caption="David Chen" description="david.chen@example.com" href="mailto:david.chen@example.com">
    <zn-icon slot="image" size="40" src="https://i.pravatar.cc/60?img=33" round></zn-icon>
    <zn-tile-property slot="properties" caption="Department">Engineering</zn-tile-property>
    <zn-tile-property slot="properties" caption="Role">Senior Dev</zn-tile-property>
    <div slot="actions">
      <zn-button size="small">Message</zn-button>
    </div>
  </zn-tile>
</zn-sp>

User List

A complete example showing a team member list with avatars, roles, and status information.

Last seen 2h ago Active now Last seen 1d ago Last seen 3h ago
<zn-sp divide no-gap>
  <zn-tile caption="Leslie Alexander" description="leslie.alexander@example.com" href="/users/leslie">
    <zn-icon slot="image" size="40" src="https://i.pravatar.cc/60?img=70" round></zn-icon>
    <zn-tile-property slot="properties" caption="Co-Founder / CEO">Last seen 2h ago</zn-tile-property>
  </zn-tile>

  <zn-tile caption="Michael Foster" description="michael.foster@example.com" href="/users/michael">
    <zn-icon slot="image" size="40" src="https://i.pravatar.cc/60?img=51" round></zn-icon>
    <zn-tile-property slot="properties" caption="Engineering Lead">Active now</zn-tile-property>
  </zn-tile>

  <zn-tile caption="Emma Davis" description="emma.davis@example.com" href="/users/emma">
    <zn-icon slot="image" size="40" src="https://i.pravatar.cc/60?img=47" round></zn-icon>
    <zn-tile-property slot="properties" caption="Product Manager">Last seen 1d ago</zn-tile-property>
  </zn-tile>

  <zn-tile caption="James Wilson" description="james.wilson@example.com" href="/users/james">
    <zn-icon slot="image" size="40" src="https://i.pravatar.cc/60?img=15" round></zn-icon>
    <zn-tile-property slot="properties" caption="Design Lead">Last seen 3h ago</zn-tile-property>
  </zn-tile>
</zn-sp>

File Browser

Example showing how to use tiles for a file browser interface.

Today Yesterday 2 days ago
Last week
<zn-sp divide no-gap>
  <zn-tile caption="Documents" description="24 files" href="/files/documents">
    <zn-icon slot="image" size="36" src="folder" color="primary"></zn-icon>
    <zn-tile-property slot="properties" caption="Modified">Today</zn-tile-property>
  </zn-tile>

  <zn-tile caption="Images" description="156 files" href="/files/images">
    <zn-icon slot="image" size="36" src="folder" color="warning"></zn-icon>
    <zn-tile-property slot="properties" caption="Modified">Yesterday</zn-tile-property>
  </zn-tile>

  <zn-tile caption="Presentation.pptx" description="4.2 MB • PowerPoint">
    <zn-icon slot="image" size="36" src="description" color="error"></zn-icon>
    <zn-tile-property slot="properties" caption="Modified">2 days ago</zn-tile-property>
    <div slot="actions">
      <zn-button size="small" color="transparent" icon="download" square></zn-button>
      <zn-button size="small" color="transparent" icon="more_vert" square></zn-button>
    </div>
  </zn-tile>

  <zn-tile caption="Budget-2024.xlsx" description="1.8 MB • Excel">
    <zn-icon slot="image" size="36" src="description" color="success"></zn-icon>
    <zn-tile-property slot="properties" caption="Modified">Last week</zn-tile-property>
    <div slot="actions">
      <zn-button size="small" color="transparent" icon="download" square></zn-button>
      <zn-button size="small" color="transparent" icon="more_vert" square></zn-button>
    </div>
  </zn-tile>
</zn-sp>

Inline Layout

Use the inline attribute to display the caption and description on the same line, separated by a small gap.

<zn-sp divide no-gap>
  <zn-tile caption="Status:" description="Active" inline>
    <zn-icon slot="image" size="32" src="check_circle" color="success"></zn-icon>
  </zn-tile>

  <zn-tile caption="Last Login:" description="2024-01-23 10:30 AM" inline>
    <zn-icon slot="image" size="32" src="schedule" color="info"></zn-icon>
  </zn-tile>

  <zn-tile caption="Location:" description="San Francisco, CA" inline>
    <zn-icon slot="image" size="32" src="location_on" color="error"></zn-icon>
  </zn-tile>
</zn-sp>

Flush Tiles

The flush attribute removes all padding from the tile, while flush-x and flush-y remove horizontal and vertical padding respectively.

<zn-sp divide no-gap>
  <zn-tile caption="Flush Tile" description="No padding at all" flush>
    <zn-icon slot="image" size="32" src="info"></zn-icon>
  </zn-tile>

  <zn-tile caption="Flush X Tile" description="No horizontal padding" flush-x>
    <zn-icon slot="image" size="32" src="info"></zn-icon>
  </zn-tile>

  <zn-tile caption="Flush Y Tile" description="No vertical padding" flush-y>
    <zn-icon slot="image" size="32" src="info"></zn-icon>
  </zn-tile>
</zn-sp>

Product Catalog

Example showing tiles used for a product catalog with images and pricing.

$299 In Stock
Add to Cart
$399 Low Stock
Add to Cart
$79 In Stock
Add to Cart
<zn-sp divide no-gap>
  <zn-tile caption="Wireless Headphones" description="Premium noise-canceling headphones" href="/products/headphones">
    <zn-icon slot="image" size="48" src="headphones" color="primary"></zn-icon>
    <zn-tile-property slot="properties" caption="Price">$299</zn-tile-property>
    <zn-tile-property slot="properties" caption="Stock">In Stock</zn-tile-property>
    <div slot="actions">
      <zn-button size="small" color="primary">Add to Cart</zn-button>
    </div>
  </zn-tile>

  <zn-tile caption="Smart Watch" description="Fitness tracking and notifications" href="/products/watch">
    <zn-icon slot="image" size="48" src="watch" color="info"></zn-icon>
    <zn-tile-property slot="properties" caption="Price">$399</zn-tile-property>
    <zn-tile-property slot="properties" caption="Stock">Low Stock</zn-tile-property>
    <div slot="actions">
      <zn-button size="small" color="primary">Add to Cart</zn-button>
    </div>
  </zn-tile>

  <zn-tile caption="Laptop Stand" description="Ergonomic aluminum design" href="/products/stand">
    <zn-icon slot="image" size="48" src="computer" color="secondary"></zn-icon>
    <zn-tile-property slot="properties" caption="Price">$79</zn-tile-property>
    <zn-tile-property slot="properties" caption="Stock">In Stock</zn-tile-property>
    <div slot="actions">
      <zn-button size="small" color="primary">Add to Cart</zn-button>
    </div>
  </zn-tile>
</zn-sp>

Custom Slot Content

Use the default slot for completely custom tile content when you don’t need the structured layout.

Custom Content

You can put anything in the default slot

Active
<zn-tile>
  <div style="padding: 20px; display: flex; justify-content: space-between; align-items: center; width: 100%;">
    <div>
      <h3 style="margin: 0 0 5px 0;">Custom Content</h3>
      <p style="margin: 0; color: rgb(var(--zn-text-color));">You can put anything in the default slot</p>
    </div>
    <zn-chip type="success">Active</zn-chip>
  </div>
</zn-tile>

Use the data-uri attribute instead of href for internal navigation or custom click handling. Combine with data-target and gaid for tracking and analytics.

<zn-sp divide no-gap>
  <zn-tile
    caption="Navigate to Dashboard"
    description="Uses data-uri for custom routing"
    data-uri="/dashboard"
    data-target="main-content"
    gaid="tile-dashboard-click">
    <zn-icon slot="image" size="32" src="dashboard"></zn-icon>
  </zn-tile>

  <zn-tile
    caption="View Reports"
    description="Custom navigation handling"
    data-uri="/reports"
    gaid="tile-reports-click">
    <zn-icon slot="image" size="32" src="assessment"></zn-icon>
  </zn-tile>
</zn-sp>

Usage Notes

Responsive Behavior

Tiles are responsive and adapt to different screen sizes. On smaller screens (below md breakpoint):

  • Properties in the properties slot are hidden automatically
  • The tile maintains its core caption, description, and actions
  • This ensures tiles remain functional on mobile devices

Layout Structure

When using structured content (caption, description, properties, or actions), the tile automatically:

  • Applies padding (var(--zn-spacing-large))
  • Creates a horizontal layout with left and right sections
  • The left section contains the image and content (max-width: 400px on desktop, 320px on tablet)
  • The right section contains properties and actions (50% width, grows to fill space)

Hover Effects

When a tile has an href or data-uri attribute:

  • The cursor changes to pointer
  • On hover, the background changes to var(--zn-color-neutral-100)
  • The entire tile area becomes clickable

Slot Behavior

The tile uses different rendering logic based on slot usage:

  • If only the default slot is used, it renders the slot content directly
  • If any named slots (caption, description, properties, actions, image) are used, it switches to structured layout mode
  • The caption can be provided via attribute or via the caption slot

Content Overflow

Text content in tiles uses ellipsis overflow handling:

  • Captions and descriptions are truncated with ellipsis if too long
  • Properties have a max-width of 150px and use ellipsis overflow
  • The properties container has horizontal scrolling on overflow

Tile Property Component

The zn-tile-property component is designed to work within the properties slot of tiles. It provides consistent formatting for metadata.

Properties

  • caption - The label for the property (e.g., “Status”, “Modified”, “Owner”)
  • description - Optional description text (can also use default slot)
  • icon - Optional icon to display next to the property

Example

Active High Jan 30, 2024
<zn-tile caption="Project Status" description="Current project information">
  <zn-icon slot="image" size="32" src="folder"></zn-icon>
  <zn-tile-property slot="properties" caption="Status" icon="check_circle">Active</zn-tile-property>
  <zn-tile-property slot="properties" caption="Priority" icon="flag">High</zn-tile-property>
  <zn-tile-property slot="properties" caption="Due Date">Jan 30, 2024</zn-tile-property>
</zn-tile>

CSS Parts

The following CSS parts are available for styling:

  • caption - The tile caption text
  • description - The tile description text
  • image - The image slot container
  • properties - The properties slot container
  • actions - The actions slot container

CSS Custom Properties

Tiles use the following CSS custom properties from the Zinc design system:

  • --zn-spacing-large - Padding around tile content
  • --zn-spacing-medium - Gap between image and content
  • --zn-spacing-small - Gap between action buttons
  • --zn-spacing-2x-small - Margin above description text
  • --zn-color-neutral-100 - Hover background color
  • --zn-text-heading - Caption text color
  • --zn-text-color - Description text color
  • --zn-font-size-medium - Description font size

Importing

If you’re using the autoloader or the traditional loader, you can ignore this section. Otherwise, feel free to use any of the following snippets to cherry pick this component.

To import this component from the CDN using a script tag:

<script type="module" src="https://cdn.jsdelivr.net/npm/@kubex/zinc@1.0.86/dist/components/tile/tile.js"></script>

To import this component from the CDN using a JavaScript import:

import 'https://cdn.jsdelivr.net/npm/@kubex/zinc@1.0.86/dist/components/tile/tile.js';

To import this component using a bundler:

import '@kubex/zinc/dist/components/tile/tile.js';

Slots

Name Description
(default) The default slot.
example An example slot.

Learn more about using slots.

Events

Name React Event Description Event Detail
zn-event-name Emitted as an example. -

Learn more about events.

Custom Properties

Name Description Default
--example An example CSS custom property.

Learn more about customizing CSS custom properties.

Parts

Name Description
base The component’s base wrapper.

Learn more about customizing CSS parts.

Dependencies

This component automatically imports the following dependencies.

  • <zn-example>