- 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
88 lines
3.9 KiB
JavaScript
88 lines
3.9 KiB
JavaScript
/**
|
|
* Provides helper methods for invoking Studio modal windows in Jasmine tests.
|
|
*/
|
|
define(["jquery", "js/views/feedback_notification", "js/views/feedback_prompt", "js/common_helpers/template_helpers"],
|
|
function($, NotificationView, Prompt, TemplateHelpers) {
|
|
var installViewTemplates, createFeedbackSpy, verifyFeedbackShowing,
|
|
verifyFeedbackHidden, createNotificationSpy, verifyNotificationShowing,
|
|
verifyNotificationHidden, createPromptSpy, confirmPrompt, inlineEdit, verifyInlineEditChange,
|
|
installMockAnalytics, removeMockAnalytics, verifyPromptShowing, verifyPromptHidden;
|
|
|
|
assertDetailsView = function (view, text) {
|
|
expect(view.$el).toContainText(text);
|
|
expect(view.$el).toContainText('ID: 0');
|
|
expect(view.$('.delete')).toExist();
|
|
};
|
|
|
|
assertControllerView = function (view, detailsView, editView) {
|
|
// Details view by default
|
|
expect(view.$(detailsView)).toExist();
|
|
view.$('.action-edit .edit').click();
|
|
expect(view.$(editView)).toExist();
|
|
expect(view.$(detailsView)).not.toExist();
|
|
view.$('.action-cancel').click();
|
|
expect(view.$(detailsView)).toExist();
|
|
expect(view.$(editView)).not.toExist();
|
|
};
|
|
|
|
assertAndDeleteItemError = function (that, url, promptText) {
|
|
var requests = AjaxHelpers.requests(that),
|
|
promptSpy = ViewHelpers.createPromptSpy(),
|
|
notificationSpy = ViewHelpers.createNotificationSpy();
|
|
|
|
clickDeleteItem(that, promptSpy, promptText);
|
|
|
|
patchAndVerifyRequest(requests, url, notificationSpy);
|
|
|
|
AjaxHelpers.respondToDelete(requests);
|
|
ViewHelpers.verifyNotificationHidden(notificationSpy);
|
|
expect($(SELECTORS.itemView)).not.toExist();
|
|
};
|
|
|
|
assertAndDeleteItemWithError = function (that, url, listItemView, promptText) {
|
|
var requests = AjaxHelpers.requests(that),
|
|
promptSpy = ViewHelpers.createPromptSpy(),
|
|
notificationSpy = ViewHelpers.createNotificationSpy();
|
|
|
|
clickDeleteItem(that, promptSpy, promptText);
|
|
patchAndVerifyRequest(requests, url, notificationSpy);
|
|
|
|
AjaxHelpers.respondWithError(requests);
|
|
ViewHelpers.verifyNotificationShowing(notificationSpy, /Deleting/);
|
|
expect($(listItemView)).toExist();
|
|
};
|
|
|
|
assertUnusedOptions = function (that) {
|
|
that.model.set('usage', []);
|
|
that.view.render();
|
|
expect(that.view.$(SELECTORS.warningMessage)).not.toExist();
|
|
expect(that.view.$(SELECTORS.warningIcon)).not.toExist();
|
|
};
|
|
|
|
assertCannotDeleteUsed = function (that, toolTipText, warningText){
|
|
setUsageInfo(that.model);
|
|
that.view.render();
|
|
expect(that.view.$(SELECTORS.note)).toHaveAttr(
|
|
'data-tooltip', toolTipText
|
|
);
|
|
expect(that.view.$(SELECTORS.warningMessage)).toContainText(warningText);
|
|
expect(that.view.$(SELECTORS.warningIcon)).toExist();
|
|
expect(that.view.$('.delete')).toHaveClass('is-disabled');
|
|
};
|
|
|
|
return {
|
|
'installViewTemplates': installViewTemplates,
|
|
'createNotificationSpy': createNotificationSpy,
|
|
'verifyNotificationShowing': verifyNotificationShowing,
|
|
'verifyNotificationHidden': verifyNotificationHidden,
|
|
'confirmPrompt': confirmPrompt,
|
|
'createPromptSpy': createPromptSpy,
|
|
'verifyPromptShowing': verifyPromptShowing,
|
|
'verifyPromptHidden': verifyPromptHidden,
|
|
'inlineEdit': inlineEdit,
|
|
'verifyInlineEditChange': verifyInlineEditChange,
|
|
'installMockAnalytics': installMockAnalytics,
|
|
'removeMockAnalytics': removeMockAnalytics
|
|
};
|
|
});
|