- SOL-465: Initial implementation of certificates web view and signatories (names/titles) - SOL-718 Close button is working properly - SOL-801 Backbone Signatories Modeling - SOL-803 Underscore template: Editor (Add) - SOL-802 Signatories: Underscore template - Details - SOL-804 Signatories: Underscore template: Editor (Edit) - Add signatory delete Django view - SOL-805 Signatory editor (Delete) - Add Coffeescript router - SOL-716 Jasmine Tests - Added missing minified JS library - client side validation of signatory fields - SOL-390 signatories names - Remove obsolete extends Sass files - input maxlength limiting for signatory information - SOL-389: Course title override - SOL-466: Add capability to upload digitized signatures in Studio - ziafazal: fixed css for upload signature image - ziafazal: completed deletion of signature images - UX-1741: Add initial static rendering/styling for Open edX web certs * creating new global static dir * adding static version of edX UX pattern library assets * adding web certificates static assets * adding static (+abstracted) web certificates rendering * creating two tiers of rendering (base + distinguished) * providing sample assets for certificate rendering * supporting RTL layouts * adding certifcates assests to edX static asset pipeline * temporarily hiding the mozilla open badges share action * wiring print button to print view/page * fixup! addressing conflict artifact in valid cert template * fixup! adding missing %hd-subsection sass extend + components comment clean up * fixup! correcting pattern library .hd-4 font-weight value - SOL-468 Linked Student View for Web View Credential - SOL-467: Add capability to upload organization logos for certificates - SOL-391 / SOL-387: Signatory related info (assets) in certificates web view - kelketek: Fixes for static asset collection in certificate HTML view. - SOL-398 Web View: Public Access - mattdrayer: Post-merge branch stabilization - catong: Initial changes to Studio template and Help config file - ziafazal: Branch stabilizations - SOL-387: Display organization logo on LMS web view - talbs/mattdrayer: Branch Stabilizations - talbs: converting backpack action to use a button HTML element - talbs: revising placeholder assets + their rendering in cert view - mattdrayer: Username web view wireup - SOL-386 Certificate Mode Previews - SOL-905: Make organization logo and signatory signature uneditable - SOL-922: Improve test coverage - SOL-765: Add LinkedIn sharing - [marco] temporary styling adjustment to account for smaller linkedin share image / fake button - SOL-921: Address hardcoded template items - SOL-927: Deleting certificate should delete org logo image also * updated invalid template * removed hr * fix invalid certificate error - clrux: Add i18n to certificate templates and partials - mattdrayer: Pylint violations - SOL-920 Certificate Activation/Deactivation - mattdrayer: Added LMS support - SOL-932: Fix preview mode support in certificate view - SOL-934: Fixed bug reported and broken tests - SOL-935 removed the 'valid' word from web view title - talbs: RTL support updates/fixes * revising certificate type icon/name vertical alignment * removing unused older certificate template * revising styling for message/banner actions * abstracting accomplishment type to use course mode + adding in honor/verified-specific placeholders - mattdrayer: JSHint violations
112 lines
3.8 KiB
JavaScript
112 lines
3.8 KiB
JavaScript
/**
|
|
* A generic list view class.
|
|
*
|
|
* Expects the following properties to be overriden:
|
|
* render when the collection is empty.
|
|
* - createItemView (function): Create and return an item view for a
|
|
* model in the collection.
|
|
* - newModelOptions (object): Options to pass to models which are
|
|
* added to the collection.
|
|
* - itemCategoryDisplayName (string): Display name for the category
|
|
* of items this list contains. For example, 'Group Configuration'.
|
|
* Note that it must be translated.
|
|
* - emptyMessage (string): Text to render when the list is empty.
|
|
*/
|
|
define([
|
|
'js/views/baseview'
|
|
], function(BaseView) {
|
|
'use strict';
|
|
var ListView = BaseView.extend({
|
|
events: {
|
|
'click .action-add': 'onAddItem',
|
|
'click .new-button': 'onAddItem'
|
|
},
|
|
|
|
listContainerCss: '.list-items',
|
|
|
|
initialize: function() {
|
|
this.listenTo(this.collection, 'add', this.addNewItemView);
|
|
this.listenTo(this.collection, 'remove', this.onRemoveItem);
|
|
this.template = this.loadTemplate('list');
|
|
|
|
// Don't render the add button when editing a form
|
|
this.listenTo(this.collection, 'change:editing', this.toggleAddButton);
|
|
this.listenTo(this.collection, 'add', this.toggleAddButton);
|
|
this.listenTo(this.collection, 'remove', this.toggleAddButton);
|
|
},
|
|
|
|
render: function(model) {
|
|
this.$el.html(this.template({
|
|
itemCategoryDisplayName: this.itemCategoryDisplayName,
|
|
emptyMessage: this.emptyMessage,
|
|
length: this.collection.length,
|
|
isEditing: model && model.get('editing'),
|
|
canCreateNewItem: this.canCreateItem(this.collection)
|
|
}));
|
|
|
|
this.collection.each(function(model) {
|
|
this.$(this.listContainerCss).append(this.createItemView({model: model}).render().el);
|
|
}, this);
|
|
|
|
return this;
|
|
},
|
|
|
|
hideOrShowAddButton: function(shouldShow) {
|
|
var addButtonCss = '.action-add';
|
|
if (this.collection.length) {
|
|
if (shouldShow) {
|
|
this.$(addButtonCss).removeClass('is-hidden');
|
|
} else {
|
|
this.$(addButtonCss).addClass('is-hidden');
|
|
}
|
|
}
|
|
},
|
|
|
|
toggleAddButton: function(model) {
|
|
if (model.get('editing') && this.collection.contains(model)) {
|
|
this.hideOrShowAddButton(false);
|
|
} else {
|
|
this.hideOrShowAddButton(true);
|
|
}
|
|
},
|
|
|
|
addNewItemView: function (model) {
|
|
var view = this.createItemView({model: model});
|
|
|
|
// If items already exist, just append one new.
|
|
// Otherwise re-render the empty list HTML.
|
|
if (this.collection.length > 1) {
|
|
this.$(this.listContainerCss).append(view.render().el);
|
|
} else {
|
|
this.render();
|
|
}
|
|
|
|
view.$el.focus();
|
|
},
|
|
|
|
canCreateItem: function(collection) {
|
|
var canCreateNewItem = true;
|
|
if (collection.length > 0) {
|
|
var maxAllowed = collection.maxAllowed;
|
|
if (!_.isUndefined(maxAllowed) && collection.length >= maxAllowed) {
|
|
canCreateNewItem = false;
|
|
}
|
|
}
|
|
return canCreateNewItem;
|
|
},
|
|
|
|
onAddItem: function(event) {
|
|
if (event && event.preventDefault) { event.preventDefault(); }
|
|
this.collection.add({editing: true}, this.newModelOptions);
|
|
},
|
|
|
|
onRemoveItem: function () {
|
|
if (this.collection.length === 0) {
|
|
this.render();
|
|
}
|
|
}
|
|
});
|
|
|
|
return ListView;
|
|
});
|