UI Cleanup - Updated Form and Handlebars subtree.

pull/3113/head
Taloth Saldono 10 years ago
parent fb7988edb8
commit a5fd28326e

@ -2,34 +2,40 @@ var Marionette = require('marionette');
var Handlebars = require('handlebars'); var Handlebars = require('handlebars');
var _ = require('underscore'); var _ = require('underscore');
module.exports = (function(){ var _templateRenderer = function(templateName) {
var templateFunction = Marionette.TemplateCache.get(templateName);
return new Handlebars.SafeString(templateFunction(this));
};
var _fieldBuilder = function(field) { var _fieldBuilder = function(field) {
if (!field.type) { if (!field.type) {
return _templateRenderer.apply(field, ['Form/TextboxTemplate']); return _templateRenderer.call(field, 'Form/TextboxTemplate');
} }
if (field.type === 'password') { if (field.type === 'password') {
return _templateRenderer.apply(field, ['Form/PasswordTemplate']); return _templateRenderer.call(field, 'Form/PasswordTemplate');
} }
if (field.type === 'checkbox') { if (field.type === 'checkbox') {
return _templateRenderer.apply(field, ['Form/CheckboxTemplate']); return _templateRenderer.call(field, 'Form/CheckboxTemplate');
} }
if (field.type === 'select') { if (field.type === 'select') {
return _templateRenderer.apply(field, ['Form/SelectTemplate']); return _templateRenderer.call(field, 'Form/SelectTemplate');
} }
if (field.type === 'path') { if (field.type === 'path') {
return _templateRenderer.apply(field, ['Form/PathTemplate']); return _templateRenderer.call(field, 'Form/PathTemplate');
} }
return _templateRenderer.apply(field, ['Form/TextboxTemplate']);
}; return _templateRenderer.call(field, 'Form/TextboxTemplate');
var _templateRenderer = function(templateName){
var templateFunction = Marionette.TemplateCache.get(templateName);
return new Handlebars.SafeString(templateFunction(this));
}; };
Handlebars.registerHelper('formBuilder', function() { Handlebars.registerHelper('formBuilder', function() {
var ret = ''; var ret = '';
_.each(this.fields, function(field) { _.each(this.fields, function(field) {
ret += _fieldBuilder(field); ret += _fieldBuilder(field);
}); });
return new Handlebars.SafeString(ret); return new Handlebars.SafeString(ret);
}); });
}).call(this);

@ -1,9 +1,7 @@
var Handlebars = require('handlebars'); var Handlebars = require('handlebars');
module.exports = (function(){
Handlebars.registerHelper('debug', function() { Handlebars.registerHelper('debug', function() {
console.group('Handlebar context'); console.group('Handlebar context');
console.log(this); console.log(this);
console.groupEnd(); console.groupEnd();
}); });
}).call(this);

@ -3,70 +3,88 @@ var moment = require('moment');
var FormatHelpers = require('../../Shared/FormatHelpers'); var FormatHelpers = require('../../Shared/FormatHelpers');
var UiSettings = require('../../Shared/UiSettingsModel'); var UiSettings = require('../../Shared/UiSettingsModel');
module.exports = (function(){
Handlebars.registerHelper('ShortDate', function(input) { Handlebars.registerHelper('ShortDate', function(input) {
if (!input) { if (!input) {
return ''; return '';
} }
var date = moment(input); var date = moment(input);
var result = '<span title="' + date.format(UiSettings.longDateTime()) + '">' + date.format(UiSettings.get('shortDateFormat')) + '</span>'; var result = '<span title="' + date.format(UiSettings.longDateTime()) + '">' + date.format(UiSettings.get('shortDateFormat')) + '</span>';
return new Handlebars.SafeString(result); return new Handlebars.SafeString(result);
}); });
Handlebars.registerHelper('RelativeDate', function(input) { Handlebars.registerHelper('RelativeDate', function(input) {
if (!input) { if (!input) {
return ''; return '';
} }
var date = moment(input); var date = moment(input);
var result = '<span title="{0}">{1}</span>'; var result = '<span title="{0}">{1}</span>';
var tooltip = date.format(UiSettings.longDateTime()); var tooltip = date.format(UiSettings.longDateTime());
var text; var text;
if (UiSettings.get('showRelativeDates')) { if (UiSettings.get('showRelativeDates')) {
text = FormatHelpers.relativeDate(input); text = FormatHelpers.relativeDate(input);
} } else {
else {
text = date.format(UiSettings.get('shortDateFormat')); text = date.format(UiSettings.get('shortDateFormat'));
} }
result = result.format(tooltip, text); result = result.format(tooltip, text);
return new Handlebars.SafeString(result); return new Handlebars.SafeString(result);
}); });
Handlebars.registerHelper('Day', function(input) { Handlebars.registerHelper('Day', function(input) {
if (!input) { if (!input) {
return ''; return '';
} }
return moment(input).format('DD'); return moment(input).format('DD');
}); });
Handlebars.registerHelper('Month', function(input) { Handlebars.registerHelper('Month', function(input) {
if (!input) { if (!input) {
return ''; return '';
} }
return moment(input).format('MMM'); return moment(input).format('MMM');
}); });
Handlebars.registerHelper('StartTime', function(input) { Handlebars.registerHelper('StartTime', function(input) {
if (!input) { if (!input) {
return ''; return '';
} }
return moment(input).format(UiSettings.time(false, false)); return moment(input).format(UiSettings.time(false, false));
}); });
Handlebars.registerHelper('LTS', function(input) { Handlebars.registerHelper('LTS', function(input) {
if (!input) { if (!input) {
return ''; return '';
} }
return moment(input).format(UiSettings.time(true, true)); return moment(input).format(UiSettings.time(true, true));
}); });
Handlebars.registerHelper('if_today', function(context, options) { Handlebars.registerHelper('if_today', function(context, options) {
var date = moment(context).startOf('day'); var date = moment(context).startOf('day');
var today = moment().startOf('day'); var today = moment().startOf('day');
if (date.isSame(today)) { if (date.isSame(today)) {
return options.fn(this); return options.fn(this);
} }
return options.inverse(this); return options.inverse(this);
}); });
Handlebars.registerHelper('unless_today', function(context, options) { Handlebars.registerHelper('unless_today', function(context, options) {
var date = moment(context).startOf('day'); var date = moment(context).startOf('day');
var today = moment().startOf('day'); var today = moment().startOf('day');
if (date.isSame(today)) { if (date.isSame(today)) {
return options.inverse(this); return options.inverse(this);
} }
return options.fn(this); return options.fn(this);
}); });
}).call(this);

@ -1,17 +1,16 @@
var Handlebars = require('handlebars'); var Handlebars = require('handlebars');
module.exports = (function(){
Handlebars.registerHelper('eachReverse', function(context) { Handlebars.registerHelper('eachReverse', function(context) {
var options = arguments[arguments.length - 1]; var options = arguments[arguments.length - 1];
var ret = ''; var ret = '';
if (context && context.length > 0) { if (context && context.length > 0) {
for (var i = context.length - 1; i >= 0; i--) { for (var i = context.length - 1; i >= 0; i--) {
ret += options.fn(context[i]); ret += options.fn(context[i]);
} }
} } else {
else {
ret = options.inverse(this); ret = options.inverse(this);
} }
return ret; return ret;
}); });
}).call(this);

@ -1,18 +1,21 @@
var Handlebars = require('handlebars'); var Handlebars = require('handlebars');
module.exports = (function(){
Handlebars.registerHelper('times', function(n, block) { Handlebars.registerHelper('times', function(n, block) {
var accum = ''; var accum = '';
for (var i = 0; i < n; ++i) { for (var i = 0; i < n; ++i) {
accum += block.fn(i); accum += block.fn(i);
} }
return accum; return accum;
}); });
Handlebars.registerHelper('for', function(from, to, incr, block) { Handlebars.registerHelper('for', function(from, to, incr, block) {
var accum = ''; var accum = '';
for (var i = from; i < to; i += incr) { for (var i = from; i < to; i += incr) {
accum += block.fn(i); accum += block.fn(i);
} }
return accum; return accum;
}); });
}).call(this);

@ -3,51 +3,59 @@ var FormatHelpers = require('../../Shared/FormatHelpers');
var moment = require('moment'); var moment = require('moment');
require('../../Activity/Queue/QueueCollection'); require('../../Activity/Queue/QueueCollection');
module.exports = (function(){
Handlebars.registerHelper('EpisodeNumber', function() { Handlebars.registerHelper('EpisodeNumber', function() {
if (this.series.seriesType === 'daily') { if (this.series.seriesType === 'daily') {
return moment(this.airDate).format('L'); return moment(this.airDate).format('L');
} } else if (this.series.seriesType === 'anime' && this.absoluteEpisodeNumber !== undefined) {
else if(this.series.seriesType === 'anime' && this.absoluteEpisodeNumber !== undefined) {
return '{0}x{1} ({2})'.format(this.seasonNumber, FormatHelpers.pad(this.episodeNumber, 2), FormatHelpers.pad(this.absoluteEpisodeNumber, 2)); return '{0}x{1} ({2})'.format(this.seasonNumber, FormatHelpers.pad(this.episodeNumber, 2), FormatHelpers.pad(this.absoluteEpisodeNumber, 2));
} } else {
else {
return '{0}x{1}'.format(this.seasonNumber, FormatHelpers.pad(this.episodeNumber, 2)); return '{0}x{1}'.format(this.seasonNumber, FormatHelpers.pad(this.episodeNumber, 2));
} }
}); });
Handlebars.registerHelper('StatusLevel', function() { Handlebars.registerHelper('StatusLevel', function() {
var hasFile = this.hasFile; var hasFile = this.hasFile;
var downloading = require('../../Activity/Queue/QueueCollection').findEpisode(this.id) || this.downloading; var downloading = require('../../Activity/Queue/QueueCollection').findEpisode(this.id) || this.downloading;
var currentTime = moment(); var currentTime = moment();
var start = moment(this.airDateUtc); var start = moment(this.airDateUtc);
var end = moment(this.end); var end = moment(this.end);
if (hasFile) { if (hasFile) {
return 'success'; return 'success';
} }
if (downloading) { if (downloading) {
return 'purple'; return 'purple';
} }
if (this.episodeNumber === 1) { if (this.episodeNumber === 1) {
return 'premiere'; return 'premiere';
} }
if (currentTime.isAfter(start) && currentTime.isBefore(end)) { if (currentTime.isAfter(start) && currentTime.isBefore(end)) {
return 'warning'; return 'warning';
} }
if (start.isBefore(currentTime) && !hasFile) { if (start.isBefore(currentTime) && !hasFile) {
return 'danger'; return 'danger';
} }
return 'primary'; return 'primary';
}); });
Handlebars.registerHelper('EpisodeProgressClass', function() { Handlebars.registerHelper('EpisodeProgressClass', function() {
if (this.episodeFileCount === this.episodeCount) { if (this.episodeFileCount === this.episodeCount) {
if (this.status === 'continuing') { if (this.status === 'continuing') {
return ''; return '';
} }
return 'progress-bar-success'; return 'progress-bar-success';
} }
if (this.monitored) { if (this.monitored) {
return 'progress-bar-danger'; return 'progress-bar-danger';
} }
return 'progress-bar-warning'; return 'progress-bar-warning';
}); });
}).call(this);

@ -2,25 +2,29 @@ var $ = require('jquery');
var Handlebars = require('handlebars'); var Handlebars = require('handlebars');
var StatusModel = require('../../System/StatusModel'); var StatusModel = require('../../System/StatusModel');
module.exports = (function(){
var placeholder = StatusModel.get('urlBase') + '/Content/Images/poster-dark.png'; var placeholder = StatusModel.get('urlBase') + '/Content/Images/poster-dark.png';
window.NzbDrone.imageError = function(img) { window.NzbDrone.imageError = function(img) {
if (!img.src.contains(placeholder)) { if (!img.src.contains(placeholder)) {
img.src = placeholder; img.src = placeholder;
$(img).addClass('placeholder-image'); $(img).addClass('placeholder-image');
} }
img.onerror = null; img.onerror = null;
}; };
Handlebars.registerHelper('defaultImg', function(src, size) { Handlebars.registerHelper('defaultImg', function(src, size) {
if (!src) { if (!src) {
return new Handlebars.SafeString('onerror="window.NzbDrone.imageError(this);"'); return new Handlebars.SafeString('onerror="window.NzbDrone.imageError(this);"');
} }
if (size) { if (size) {
src = src.replace(/\.jpg($|\?)/g, '-' + size + '.jpg$1'); src = src.replace(/\.jpg($|\?)/g, '-' + size + '.jpg$1');
} }
return new Handlebars.SafeString('src="{0}" onerror="window.NzbDrone.imageError(this);"'.format(src)); return new Handlebars.SafeString('src="{0}" onerror="window.NzbDrone.imageError(this);"'.format(src));
}); });
Handlebars.registerHelper('UrlBase', function() { Handlebars.registerHelper('UrlBase', function() {
return new Handlebars.SafeString(StatusModel.get('urlBase')); return new Handlebars.SafeString(StatusModel.get('urlBase'));
}); });
}).call(this);

@ -1,14 +1,14 @@
var Handlebars = require('handlebars'); var Handlebars = require('handlebars');
var FormatHelpers = require('../../Shared/FormatHelpers'); var FormatHelpers = require('../../Shared/FormatHelpers');
module.exports = (function(){
Handlebars.registerHelper('Bytes', function(size) { Handlebars.registerHelper('Bytes', function(size) {
return new Handlebars.SafeString(FormatHelpers.bytes(size)); return new Handlebars.SafeString(FormatHelpers.bytes(size));
}); });
Handlebars.registerHelper('Pad2', function(input) { Handlebars.registerHelper('Pad2', function(input) {
return FormatHelpers.pad(input, 2); return FormatHelpers.pad(input, 2);
}); });
Handlebars.registerHelper('Number', function(input) { Handlebars.registerHelper('Number', function(input) {
return FormatHelpers.number(input); return FormatHelpers.number(input);
}); });
}).call(this);

@ -1,12 +1,12 @@
var Handlebars = require('handlebars'); var Handlebars = require('handlebars');
var ProfileCollection = require('../../Profile/ProfileCollection'); var ProfileCollection = require('../../Profile/ProfileCollection');
module.exports = (function(){
Handlebars.registerHelper('profile', function(profileId) { Handlebars.registerHelper('profile', function(profileId) {
var profile = ProfileCollection.get(profileId); var profile = ProfileCollection.get(profileId);
if (profile) { if (profile) {
return new Handlebars.SafeString('<span class="label label-default profile-label">' + profile.get('name') + '</span>'); return new Handlebars.SafeString('<span class="label label-default profile-label">' + profile.get('name') + '</span>');
} }
return undefined; return undefined;
}); });
}).call(this);

@ -1,10 +1,7 @@
'use strict'; var Handlebars = require('handlebars');
define( var StatusModel = require('../../System/StatusModel');
[ var _ = require('underscore');
'handlebars',
'System/StatusModel',
'underscore'
], function (Handlebars, StatusModel, _) {
Handlebars.registerHelper('poster', function() { Handlebars.registerHelper('poster', function() {
var placeholder = StatusModel.get('urlBase') + '/Content/Images/poster-dark.png'; var placeholder = StatusModel.get('urlBase') + '/Content/Images/poster-dark.png';
@ -80,4 +77,3 @@ define(
return new Handlebars.SafeString('{0} <span class="year">({1})</span>'.format(this.title, this.year)); return new Handlebars.SafeString('{0} <span class="year">({1})</span>'.format(this.title, this.year));
}); });
});

@ -1,9 +1,7 @@
var Handlebars = require('handlebars'); var Handlebars = require('handlebars');
module.exports = (function(){
Handlebars.registerHelper('TitleCase', function(input) { Handlebars.registerHelper('TitleCase', function(input) {
return new Handlebars.SafeString(input.replace(/\w\S*/g, function(txt) { return new Handlebars.SafeString(input.replace(/\w\S*/g, function(txt) {
return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase(); return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();
})); }));
}); });
}).call(this);

@ -1,17 +1,18 @@
var Handlebars = require('handlebars'); var Handlebars = require('handlebars');
var StatusModel = require('../../System/StatusModel'); var StatusModel = require('../../System/StatusModel');
module.exports = (function(){
Handlebars.registerHelper('if_windows', function(options) { Handlebars.registerHelper('if_windows', function(options) {
if (StatusModel.get('isWindows')) { if (StatusModel.get('isWindows')) {
return options.fn(this); return options.fn(this);
} }
return options.inverse(this); return options.inverse(this);
}); });
Handlebars.registerHelper('if_mono', function(options) { Handlebars.registerHelper('if_mono', function(options) {
if (StatusModel.get('isMono')) { if (StatusModel.get('isMono')) {
return options.fn(this); return options.fn(this);
} }
return options.inverse(this); return options.inverse(this);
}); });
}).call(this);

@ -14,10 +14,13 @@ require('./Handlebars.Debug');
module.exports = function() { module.exports = function() {
this.get = function(templateId) { this.get = function(templateId) {
var templateKey = templateId.toLowerCase().replace('template', ''); var templateKey = templateId.toLowerCase().replace('template', '');
var templateFunction = window.T[templateKey]; var templateFunction = window.T[templateKey];
if (!templateFunction) { if (!templateFunction) {
throw 'couldn\'t find pre-compiled template ' + templateKey; throw 'couldn\'t find pre-compiled template ' + templateKey;
} }
return function(data) { return function(data) {
try { try {
var wrappedTemplate = Handlebars.template.call(Handlebars, templateFunction); var wrappedTemplate = Handlebars.template.call(Handlebars, templateFunction);

Loading…
Cancel
Save