Revision 214 (by ahitrov, 2012/05/17 14:55:51) |
Full image list for any image form available
|
// This list may be created by a server logic page PHP/ASP/ASPX/JSP in some backend system.
// There images will be displayed as a dropdown in all image dialogs if the "external_link_image_url"
// option is defined in TinyMCE init.
var tinyMCEImageList = new Array(
// Name, URL
<% join(',', @imgstr) %>
);
<%args>
$class => undef
$id => undef
</%args>
<%init>
return unless $class && $id;
my $document = $keeper->get_document_by_id ( $id, class => $class );
return unless ref $document;
my @images;
my @props = grep { $_->{type} eq 'images' || $_->{type} eq 'image' } $document->structure;
foreach my $prop ( @props ) {
if ( $prop->{type} eq 'images' ) {
my $images = $document->get_image($prop->{attr});
if ( ref $images && exists $images->{maxnumber} && $images->{maxnumber} ) {
for ( 1..$images->{maxnumber} ) {
my $image = $images->{"image_$_"};
if ( ref $image && exists $image->{filename} ) {
my $img_path = ($state->{images_dir} =~ /^http:/ ? $state->{images_dir} : '').($image->{filename} =~ /^\// ? '' : '/').$image->{filename};
my $name = $image->{alt} || $prop->{attr}.": image_$_";
$name =~ s/"/\\"/g;
push @images, { url => $img_path, name => $name, mini => (exists $image->{mini} ? $image->{mini} : undef) };
}
}
}
} else {
my $image = $document->get_image($prop->{attr});
if ( ref $image && exists $image->{filename} ) {
my $img_path = ($state->{images_dir} =~ /^http:/ ? $state->{images_dir} : '').($image->{filename} =~ /^\// ? '' : '/').$image->{filename};
my $name = $image->{alt} || $document->name.' ('.$prop->{attr}.')';
$name =~ s/"/\\"/g;
push @images, { url => $img_path, name => $name, mini => (exists $image->{mini} ? $image->{mini} : undef) };
}
}
}
return unless @images;
my $comma = 0;
my @imgstr;
foreach my $img ( @images ) {
push @imgstr, '["'.$img->{name}.'","'.$img->{url}.'"]';
if ( exists $img->{mini} && ref $img->{mini} eq 'HASH' ) {
while ( my ($dim, $mini) = each %{$img->{mini}} ) {
next unless ref $mini eq 'HASH' && exists $mini->{filename};
push @imgstr, '["'.$img->{name}.'. Mini: '.$dim.'","'.$mini->{filename}.'"]';
}
}
}
</%init>
Небольшая справка по веткам
cnddist – контейнер, в котором хранятся все дистрибутивы всех библиотек и программных пакетов, которые использовались при построении различных версий Contenido. Если какой-то библиотеки в данном хранилище нет, инсталлятор сделает попытку "подтянуть" ее с веба (например, с CPAN). Если библиотека слишком старая, есть очень большая вероятность, что ее там уже нет. Поэтому мы храним весь хлам от всех сборок. Если какой-то дистрибутив вдруг отсутствует в cnddist - напишите нам, мы положим его туда.
koi8 – отмирающая ветка, чей код, выдача и все внутренние библиотеки заточены на кодировку KOI8-R. Вносятся только те дополнения, которые касаются внешнего вида и функционала админки, баги ядра, обязательные обновления портов и мелочи, которые легко скопипастить. В дальнейшем планируется полная остановка поддержки по данной ветке.
utf8 – актуальная ветка, заточенная под UTF-8.
Внутри каждой ветки: core – исходники ядра; install – скрипт установки инсталляции; plugins – плагины; samples – "готовые к употреблению" проекты, которые можно поставить, запустить и посмотреть, как они работают.