You are here

bueditor.sprite.inc in BUEditor 7

Same filename and directory in other branches
  1. 6.2 admin/bueditor.sprite.inc

Generates CSS sprites for editor buttons.

File

admin/bueditor.sprite.inc
View source
<?php

/**
 * @file
 * Generates CSS sprites for editor buttons.
 */

/**
 * Create and return editor sprite depending on editor settings or buttons.
 */
function bueditor_sprite($editor, $buttons = array()) {
  if (!empty($buttons)) {
    uasort($buttons, function ($b1, $b2) {
      return $b1->weight - $b2->weight;
    });
    return bueditor_sprite_buttons($buttons, $editor->iconpath);
  }
  elseif (isset($editor->eid) && $editor->eid > 0) {
    return bueditor_sprite_editor($editor);
  }
  return '';
}

/**
 * Create an icon sprite for an editor.
 */
function bueditor_sprite_editor($editor) {
  return bueditor_sprite_buttons(bueditor_buttons($editor->eid), $editor->iconpath);
}

/**
 * Create an icon sprite for a set of buttons.
 */
function bueditor_sprite_buttons($buttons, $iconpath) {
  $icons = array();
  $iconpath = bueditor_path_tr($iconpath);
  foreach ($buttons as $button) {
    if (substr($button->title, 0, 4) != 'tpl:' && preg_match('/\\.(png|gif|jpg)$/', $button->icon)) {
      $icons[] = $iconpath . '/' . $button->icon;
    }
  }
  return bueditor_sprite_icons($icons);
}

/**
 * Create an icon sprite for a set of icons.
 */
function bueditor_sprite_icons($icons) {
  if (image_get_toolkit() != 'gd' || empty($icons) || ($total = count($icons)) < 2) {
    return '';
  }

  //Image properties of the first one in the list will be the reference for the sprite
  $first_icon = $icons[0];
  $sprite = new stdClass();
  $sprite->dir = bueditor_sprites_dir();
  $sizes = @array_map('filesize', $icons);
  $sprite->name = 'sprite_' . md5(implode(' ', array_merge($icons, $sizes))) . substr($first_icon, strrpos($first_icon, '.'));
  $sprite->source = $sprite->dir . '/' . $sprite->name;
  if (file_exists($sprite->source)) {
    return $sprite->name;
  }
  if (!file_prepare_directory($sprite->dir, 1) || !($icon = image_load($first_icon, 'gd'))) {
    return '';
  }

  //set fixed icon dimensions
  $icon_width = $icon->info['width'];
  $icon_height = $icon->info['height'];

  //set sprite dimensions based on the number of icons
  $sprite->info = $icon->info;
  $sprite->toolkit = $icon->toolkit;
  $sprite->info['width'] = $icon_width * $total;
  $sprite->resource = image_gd_create_tmp($icon, $sprite->info['width'], $sprite->info['height']);

  //copy first icon
  imagecopy($sprite->resource, $icon->resource, 0, 0, 0, 0, $icon_width, $icon_height);
  imagedestroy($icon->resource);

  //copy the rest
  for ($i = 1; $i < $total; $i++) {
    if ($icon = image_load($icons[$i], 'gd')) {
      imagecopy($sprite->resource, $icon->resource, $i * $icon_width, 0, 0, 0, $icon_width, $icon_height);
      imagedestroy($icon->resource);
    }
  }

  //save sprite to file
  $result = image_save($sprite);
  imagedestroy($sprite->resource);
  return $result ? $sprite->name : '';
}

Functions

Namesort descending Description
bueditor_sprite Create and return editor sprite depending on editor settings or buttons.
bueditor_sprite_buttons Create an icon sprite for a set of buttons.
bueditor_sprite_editor Create an icon sprite for an editor.
bueditor_sprite_icons Create an icon sprite for a set of icons.