- 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
150 lines
2.6 KiB
SCSS
150 lines
2.6 KiB
SCSS
// ------------------------------
|
|
// edX Pattern Library: Helpers
|
|
|
|
// About: Sass partial for defining extends and re-usable elements at the Sass compile level.
|
|
|
|
// #UTILITIES
|
|
// #RESETS
|
|
|
|
// ----------------------------
|
|
// #UTILITIES
|
|
// ----------------------------
|
|
// visual disabled
|
|
%state-disabled {
|
|
pointer-events: none;
|
|
outline: none;
|
|
cursor: default;
|
|
}
|
|
|
|
// presentational wrapper
|
|
%wrapper {
|
|
@include clearfix();
|
|
width: 100%;
|
|
}
|
|
|
|
// remove spacing from first/last children
|
|
%clear-first-child {
|
|
|
|
&:first-child {
|
|
margin-top: 0;
|
|
padding-top: 0;
|
|
border-top: none;
|
|
}
|
|
}
|
|
|
|
%clear-last-child {
|
|
|
|
&:last-child {
|
|
margin-bottom: 0;
|
|
padding-bottom: 0;
|
|
border-bottom: none;
|
|
}
|
|
}
|
|
|
|
// accessibility
|
|
%a11y-hide {
|
|
border: 0;
|
|
clip: rect(0 0 0 0);
|
|
height: 1px;
|
|
margin: -1px;
|
|
overflow: hidden;
|
|
padding: 0;
|
|
position: absolute;
|
|
width: 1px;
|
|
}
|
|
|
|
%a11y-hide-image-text {
|
|
overflow: hidden;
|
|
text-indent: 100%;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
// ----------------------------
|
|
// #UTILITIES
|
|
// ----------------------------
|
|
// reset of lists
|
|
%reset-lists {
|
|
margin: 0;
|
|
padding: 0;
|
|
list-style: none;
|
|
text-indent: 0;
|
|
}
|
|
|
|
%list-unstyled {
|
|
@extend %reset-lists;
|
|
|
|
li,
|
|
dt,
|
|
dd {
|
|
margin: 0;
|
|
padding: 0;
|
|
}
|
|
}
|
|
|
|
%list-inline {
|
|
@extend %list-unstyled;
|
|
|
|
li,
|
|
dt,
|
|
dd {
|
|
display: inline-block;
|
|
}
|
|
}
|
|
|
|
// reset of typography
|
|
%reset-headings {
|
|
margin: 0 0 spacing-horizontal(base) 0;
|
|
font-family: $headings-base-font-family;
|
|
font-weight: $headings-base-font-weight;
|
|
font-size: font-size(base);
|
|
line-height: line-height(base);
|
|
color: $headings-base-color;
|
|
}
|
|
|
|
// reset of copy
|
|
%reset-copy {
|
|
font-family: $text-base-font-family;
|
|
}
|
|
|
|
// reset of code
|
|
%reset-code {
|
|
font-family: $font-family-monospace;
|
|
font-size: font-size(base);
|
|
line-height: line-height(large);
|
|
color: $text-base-color;
|
|
}
|
|
|
|
// reset of links
|
|
%link {
|
|
@include transition(
|
|
color timing(xx-fast) ease-in-out 0s,
|
|
border-color timing(xx-fast) ease-in-out 0s
|
|
);
|
|
|
|
border-bottom: 1px solid $transparent;
|
|
color: palette(primary, base);
|
|
text-decoration: none;
|
|
|
|
// STATE: hover, active, focus
|
|
&:hover,
|
|
&:active,
|
|
&:focus {
|
|
border-bottom-color: palette(primary, accent);
|
|
color: palette(primary, accent);
|
|
}
|
|
|
|
// STATE: is disabled
|
|
&:disabled,
|
|
&.is-disabled {
|
|
display: none; // :)
|
|
color: palette(grayscale, light);
|
|
}
|
|
|
|
// STATE: is pressed or active
|
|
&:active,
|
|
&.is-pressed,
|
|
&.is-active {
|
|
color: palette(primary, dark);
|
|
}
|
|
}
|