what-did-they-say/js/toggle-transcript.js

112 lines
3.2 KiB
JavaScript
Raw Permalink Normal View History

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) {
WhatDidTheySay.transcript_effects.open(t);
2009-10-05 02:37:22 +00:00
} else {
t.show();
}
} else {
2009-10-05 02:37:22 +00:00
if (WhatDidTheySay.use_transcript_effects) {
WhatDidTheySay.transcript_effects.close(t);
2009-10-05 02:37:22 +00:00
} else {
t.hide();
}
}
});
};
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
}
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-06 01:35:49 +00:00
Event.stop(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-06 01:35:49 +00:00
Event.stop(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-10-06 11:01:17 +00:00
opener_container.show();
2009-10-05 01:53:46 +00:00
}
2009-09-13 16:35:20 +00:00
});