2009-10-04 22:54:22 +00:00
|
|
|
WhatDidTheySay.get_transcript_language_code = function(transcript) {
|
|
|
|
for (code in WhatDidTheySay.languages) {
|
|
|
|
if (WhatDidTheySay.languages.hasOwnProperty(code)) {
|
|
|
|
if (transcript.hasClassName(code)) {
|
|
|
|
return code;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
};
|
|
|
|
|
|
|
|
WhatDidTheySay.build_bundle_header = function(bundle) {
|
|
|
|
bundle.select('h3').each(function(h) { h.parentNode.removeChild(h); });
|
|
|
|
|
|
|
|
var new_header = new Element('h3', { 'className': 'wdts-transcript-language' });
|
|
|
|
|
|
|
|
var transcript_holders = bundle.select('.transcript-holder');
|
|
|
|
transcript_holders.invoke('show');
|
|
|
|
|
|
|
|
var show_only_this_code = function(code) {
|
|
|
|
transcript_holders.each(function(t) {
|
|
|
|
if (t.hasClassName(code)) {
|
2009-10-05 02:37:22 +00:00
|
|
|
if (WhatDidTheySay.use_transcript_effects) {
|
2009-10-06 01:13:35 +00:00
|
|
|
WhatDidTheySay.transcript_effects.open(t);
|
2009-10-05 02:37:22 +00:00
|
|
|
} else {
|
|
|
|
t.show();
|
|
|
|
}
|
2009-10-04 22:54:22 +00:00
|
|
|
} else {
|
2009-10-05 02:37:22 +00:00
|
|
|
if (WhatDidTheySay.use_transcript_effects) {
|
2009-10-06 01:13:35 +00:00
|
|
|
WhatDidTheySay.transcript_effects.close(t);
|
2009-10-05 02:37:22 +00:00
|
|
|
} else {
|
|
|
|
t.hide();
|
|
|
|
}
|
2009-10-04 22:54:22 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
if (transcript_holders.length > 1) {
|
|
|
|
var select = new Element('select');
|
|
|
|
|
|
|
|
show_only_this_code(WhatDidTheySay.default_language);
|
|
|
|
|
|
|
|
transcript_holders.each(function(t) {
|
|
|
|
var code = WhatDidTheySay.get_transcript_language_code(t);
|
|
|
|
|
|
|
|
if (code) {
|
|
|
|
var option = new Element('option', { 'value': code }).update(WhatDidTheySay.languages[code]);
|
|
|
|
if (code == WhatDidTheySay.default_language) { option.selected = true; }
|
|
|
|
select.insert(option);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
select.observe('change', function(e) {
|
|
|
|
var code = select.options[select.selectedIndex].value;
|
|
|
|
show_only_this_code(code);
|
|
|
|
});
|
|
|
|
|
|
|
|
new_header.update(WhatDidTheySay.messages.bundle_header.replace('%s', '<span />'));
|
|
|
|
new_header.select('span')[0].insert(select);
|
|
|
|
} else {
|
|
|
|
var code = WhatDidTheySay.get_transcript_language_code(transcript_holders[0]);
|
|
|
|
|
|
|
|
if (code) {
|
|
|
|
new_header.update(WhatDidTheySay.messages.bundle_header.replace('%s', WhatDidTheySay.languages[code]));
|
|
|
|
}
|
2009-09-13 16:35:20 +00:00
|
|
|
}
|
2009-10-04 22:54:22 +00:00
|
|
|
|
|
|
|
bundle.insert({ top: new_header })
|
|
|
|
}
|
|
|
|
|
2009-10-05 01:53:46 +00:00
|
|
|
$$('.wdts-transcript-container').each(function(d) {
|
|
|
|
var bundle = d.select('.wdts-transcript-bundle').pop();
|
|
|
|
var opener_container = d.select('.wdts-transcript-opener').pop();
|
2009-10-05 00:09:59 +00:00
|
|
|
|
2009-10-05 01:53:46 +00:00
|
|
|
if (bundle && opener_container) {
|
|
|
|
WhatDidTheySay.build_bundle_header(bundle);
|
2009-10-05 00:09:59 +00:00
|
|
|
|
2009-10-05 01:53:46 +00:00
|
|
|
var opener = opener_container.select('.wdts-opener').pop();
|
|
|
|
var closer = opener_container.select('.wdts-closer').pop();
|
2009-10-05 00:09:59 +00:00
|
|
|
|
2009-10-05 01:53:46 +00:00
|
|
|
if (opener && closer) {
|
|
|
|
opener.observe('click', function(e) {
|
2009-10-05 02:37:22 +00:00
|
|
|
opener.hide(); closer.show();
|
|
|
|
if (WhatDidTheySay.use_transcript_effects) {
|
|
|
|
new Effect.BlindDown(bundle, { duration: 0.25 });
|
|
|
|
} else {
|
|
|
|
bundle.show();
|
|
|
|
}
|
2009-10-05 01:53:46 +00:00
|
|
|
});
|
2009-10-05 00:09:59 +00:00
|
|
|
|
2009-10-05 01:53:46 +00:00
|
|
|
closer.observe('click', function(e) {
|
2009-10-05 02:37:22 +00:00
|
|
|
closer.hide(); opener.show();
|
|
|
|
if (WhatDidTheySay.use_transcript_effects) {
|
|
|
|
new Effect.BlindUp(bundle, { duration: 0.25 });
|
|
|
|
} else {
|
|
|
|
bundle.hide();
|
|
|
|
}
|
2009-10-05 01:53:46 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
if (d.hasClassName('wdts-start-hidden')) {
|
2009-10-05 02:37:22 +00:00
|
|
|
bundle.hide(); closer.hide(); opener.show();
|
2009-10-05 01:53:46 +00:00
|
|
|
} else {
|
2009-10-05 02:37:22 +00:00
|
|
|
bundle.show(); closer.show(); opener.hide();
|
2009-10-05 01:53:46 +00:00
|
|
|
}
|
|
|
|
}
|
2009-09-13 16:35:20 +00:00
|
|
|
});
|