@graupl/graupl 1.0.0-alpha.9 → 1.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.github/workflows/codeql-analysis.yml +3 -3
- package/.husky/commit-msg +0 -1
- package/.husky/pre-commit +0 -1
- package/CHANGELOG.md +153 -0
- package/build.js +7 -0
- package/dist/css/base/button.css +2 -0
- package/dist/css/base/button.css.map +1 -0
- package/dist/css/base/form.css +2 -0
- package/dist/css/base/form.css.map +1 -0
- package/dist/css/base/link.css +2 -0
- package/dist/css/base/link.css.map +1 -0
- package/dist/css/base/table.css +2 -0
- package/dist/css/base/table.css.map +1 -0
- package/dist/css/base.css +2 -0
- package/dist/css/base.css.map +1 -0
- package/dist/css/component/accordion.css +2 -0
- package/dist/css/component/accordion.css.map +1 -0
- package/dist/css/component/alert.css +2 -0
- package/dist/css/component/alert.css.map +1 -0
- package/dist/css/component/card.css +2 -0
- package/dist/css/component/card.css.map +1 -0
- package/dist/css/component/carousel.css +2 -0
- package/dist/css/component/carousel.css.map +1 -0
- package/dist/{component → css/component}/input-group.css +1 -1
- package/dist/css/component/input-group.css.map +1 -0
- package/dist/css/component/menu.css +2 -0
- package/dist/css/component/menu.css.map +1 -0
- package/dist/css/component/navigation.css +2 -0
- package/dist/css/component/navigation.css.map +1 -0
- package/dist/css/component.css +2 -0
- package/dist/css/component.css.map +1 -0
- package/dist/css/graupl.css +2 -0
- package/dist/css/graupl.css.map +1 -0
- package/dist/css/init.css +2 -0
- package/dist/css/init.css.map +1 -0
- package/dist/css/layout/columns.css +2 -0
- package/dist/css/layout/columns.css.map +1 -0
- package/dist/css/layout/container.css.map +1 -0
- package/dist/css/layout/flex-columns.css +2 -0
- package/dist/css/layout/flex-columns.css.map +1 -0
- package/dist/css/layout.css +2 -0
- package/dist/css/layout.css.map +1 -0
- package/dist/css/normalize.css +2 -0
- package/dist/css/normalize.css.map +1 -0
- package/dist/css/state/focus.css +2 -0
- package/dist/css/state/focus.css.map +1 -0
- package/dist/css/state.css +2 -0
- package/dist/css/state.css.map +1 -0
- package/dist/css/theme/color.css +2 -0
- package/dist/css/theme/color.css.map +1 -0
- package/dist/css/theme/typography.css +2 -0
- package/dist/css/theme/typography.css.map +1 -0
- package/dist/css/theme.css +2 -0
- package/dist/css/theme.css.map +1 -0
- package/dist/css/utilities/alignment.css +2 -0
- package/dist/css/utilities/alignment.css.map +1 -0
- package/dist/{utilities/colors.css → css/utilities/color.css} +2 -2
- package/dist/css/utilities/color.css.map +1 -0
- package/dist/css/utilities/display.css +2 -0
- package/dist/css/utilities/display.css.map +1 -0
- package/dist/css/utilities/flex.css +2 -0
- package/dist/css/utilities/flex.css.map +1 -0
- package/dist/css/utilities/height.css +2 -0
- package/dist/css/utilities/height.css.map +1 -0
- package/dist/css/utilities/inset.css +2 -0
- package/dist/css/utilities/inset.css.map +1 -0
- package/dist/css/utilities/justification.css +2 -0
- package/dist/css/utilities/justification.css.map +1 -0
- package/dist/css/utilities/list.css +2 -0
- package/dist/css/utilities/list.css.map +1 -0
- package/dist/css/utilities/order.css +2 -0
- package/dist/css/utilities/order.css.map +1 -0
- package/dist/css/utilities/postion.css +2 -0
- package/dist/css/utilities/postion.css.map +1 -0
- package/dist/css/utilities/ratio.css +2 -0
- package/dist/css/utilities/ratio.css.map +1 -0
- package/dist/css/utilities/spacing.css +2 -0
- package/dist/css/utilities/spacing.css.map +1 -0
- package/dist/css/utilities/typography.css +2 -0
- package/dist/css/utilities/typography.css.map +1 -0
- package/dist/css/utilities/visibility.css +2 -0
- package/dist/css/utilities/visibility.css.map +1 -0
- package/dist/css/utilities/width.css +2 -0
- package/dist/css/utilities/width.css.map +1 -0
- package/dist/css/utilities.css +2 -0
- package/dist/css/utilities.css.map +1 -0
- package/dist/js/component/accordion.cjs.js +3 -0
- package/dist/js/component/accordion.esm.js +1289 -0
- package/dist/js/component/accordion.iife.js +3 -0
- package/dist/js/component/alert.cjs.js +3 -0
- package/dist/js/component/alert.esm.js +529 -0
- package/dist/js/component/alert.iife.js +3 -0
- package/dist/js/component/carousel.cjs.js +3 -0
- package/dist/js/component/carousel.esm.js +1110 -0
- package/dist/js/component/carousel.iife.js +3 -0
- package/dist/js/graupl.cjs.js +5 -0
- package/dist/js/graupl.esm.js +1462 -0
- package/dist/js/graupl.iife.js +5 -0
- package/docs/.vitepress/config.js +39 -12
- package/docs/components/alert.md +130 -0
- package/docs/components/button.md +84 -0
- package/docs/components/card.md +369 -0
- package/docs/components/index.md +1 -0
- package/docs/components/inputgroup.md +159 -0
- package/docs/components/menu.md +326 -0
- package/docs/components/navigation.md +158 -0
- package/docs/content.md +237 -0
- package/docs/defaults.md +121 -0
- package/docs/forms.md +79 -0
- package/docs/functions.md +9 -0
- package/docs/getting-started.md +1 -0
- package/docs/index.md +1 -7
- package/docs/introduction.md +22 -2
- package/docs/layout.md +200 -0
- package/docs/mixins.md +47 -0
- package/docs/state.md +67 -0
- package/docs/theme.md +258 -0
- package/docs/utilities.md +357 -0
- package/eslint.config.js +1 -0
- package/index.html +816 -327
- package/index.js +12 -0
- package/package.json +31 -10
- package/scss/base/button.scss +3 -0
- package/scss/base/form.scss +1 -1
- package/scss/base/link.scss +1 -1
- package/scss/base/table.scss +1 -1
- package/scss/base.scss +1 -1
- package/scss/component/accordion.scss +3 -0
- package/scss/component/alert.scss +3 -0
- package/scss/component/card.scss +3 -0
- package/scss/component/carousel.scss +3 -0
- package/scss/component/input-group.scss +1 -1
- package/scss/component/menu.scss +3 -0
- package/scss/component/navigation.scss +3 -0
- package/scss/component.scss +1 -1
- package/scss/graupl.scss +1 -3
- package/scss/init.scss +3 -0
- package/scss/layout/columns.scss +1 -1
- package/scss/layout/container.scss +1 -1
- package/scss/layout/flex-columns.scss +3 -0
- package/scss/layout.scss +1 -1
- package/scss/normalize.scss +3 -0
- package/scss/state/focus.scss +1 -1
- package/scss/state.scss +1 -1
- package/scss/theme/color.scss +1 -1
- package/scss/theme/typography.scss +1 -1
- package/scss/theme.scss +1 -1
- package/scss/utilities/alignment.scss +3 -0
- package/scss/utilities/color.scss +3 -0
- package/scss/utilities/display.scss +3 -0
- package/scss/utilities/flex.scss +3 -0
- package/scss/utilities/height.scss +3 -0
- package/scss/utilities/inset.scss +3 -0
- package/scss/utilities/justification.scss +3 -0
- package/scss/utilities/list.scss +3 -0
- package/scss/utilities/order.scss +3 -0
- package/scss/utilities/postion.scss +3 -0
- package/scss/utilities/ratio.scss +3 -0
- package/scss/utilities/spacing.scss +1 -1
- package/scss/utilities/typography.scss +1 -1
- package/scss/utilities/visibility.scss +3 -0
- package/scss/utilities/width.scss +3 -0
- package/scss/utilities.scss +1 -1
- package/src/js/accordion/Accordion.js +1163 -0
- package/src/js/accordion/AccordionItem.js +496 -0
- package/src/js/accordion/index.js +10 -0
- package/src/js/alert/Alert.js +581 -0
- package/src/js/alert/index.js +11 -0
- package/src/js/carousel/Carousel.js +1427 -0
- package/src/js/carousel/index.js +10 -0
- package/src/js/domHelpers.js +37 -0
- package/src/js/eventHandlers.js +39 -0
- package/src/js/navigation/index.js +36 -0
- package/src/js/storage.js +106 -0
- package/src/js/validate.js +225 -0
- package/src/scss/_defaults.scss +74 -5
- package/src/scss/_index.scss +4 -3
- package/src/scss/_init.scss +2 -2
- package/src/scss/_normalize.scss +197 -0
- package/src/scss/_variables.scss +7 -7
- package/src/scss/base/_index.scss +2 -1
- package/src/scss/base/button/_defaults.scss +60 -0
- package/src/scss/base/button/_index.scss +107 -0
- package/src/scss/base/button/_mixins.scss +166 -0
- package/src/scss/{component → base}/button/_variables.scss +64 -19
- package/src/scss/base/form/_defaults.scss +14 -4
- package/src/scss/base/form/_index.scss +23 -20
- package/src/scss/base/form/_variables.scss +14 -2
- package/src/scss/base/link/_defaults.scss +48 -5
- package/src/scss/base/link/_index.scss +111 -10
- package/src/scss/base/link/_variables.scss +234 -4
- package/src/scss/base/table/_defaults.scss +49 -4
- package/src/scss/base/table/_index.scss +102 -8
- package/src/scss/base/table/_variables.scss +75 -5
- package/src/scss/component/_index.scss +7 -3
- package/src/scss/component/accordion/_defaults.scss +40 -0
- package/src/scss/component/accordion/_index.scss +180 -0
- package/src/scss/component/accordion/_variables.scss +316 -0
- package/src/scss/component/alert/_defaults.scss +49 -0
- package/src/scss/component/alert/_index.scss +118 -0
- package/src/scss/component/alert/_variables.scss +173 -0
- package/src/scss/component/card/_defaults.scss +32 -0
- package/src/scss/component/card/_index.scss +178 -0
- package/src/scss/component/card/_variables.scss +186 -0
- package/src/scss/component/carousel/_defaults.scss +43 -0
- package/src/scss/component/carousel/_index.scss +188 -0
- package/src/scss/component/carousel/_variables.scss +104 -0
- package/src/scss/component/input-group/_defaults.scss +11 -4
- package/src/scss/component/input-group/_index.scss +13 -11
- package/src/scss/component/input-group/_variables.scss +4 -1
- package/src/scss/component/menu/_defaults.scss +66 -0
- package/src/scss/component/menu/_index.scss +305 -0
- package/src/scss/component/menu/_variables.scss +500 -0
- package/src/scss/component/navigation/_defaults.scss +29 -0
- package/src/scss/component/navigation/_index.scss +189 -0
- package/src/scss/component/navigation/_variables.scss +237 -0
- package/src/scss/functions/_important.scss +2 -0
- package/src/scss/functions/_screen.scss +30 -0
- package/src/scss/functions/_theme.scss +28 -7
- package/src/scss/layout/_index.scss +2 -1
- package/src/scss/layout/columns/_defaults.scss +12 -4
- package/src/scss/layout/columns/_index.scss +29 -7
- package/src/scss/layout/columns/_variables.scss +6 -2
- package/src/scss/layout/container/_defaults.scss +13 -4
- package/src/scss/layout/container/_index.scss +12 -7
- package/src/scss/layout/container/_variables.scss +4 -1
- package/src/scss/layout/flex-columns/_defaults.scss +18 -0
- package/src/scss/layout/flex-columns/_index.scss +80 -0
- package/src/scss/layout/flex-columns/_variables.scss +26 -0
- package/src/scss/mixins/_animation.scss +15 -0
- package/src/scss/mixins/_layer.scss +3 -5
- package/src/scss/mixins/_screen.scss +56 -0
- package/src/scss/mixins/_utility.scss +30 -0
- package/src/scss/mixins/_visually-hidden.scss +20 -0
- package/src/scss/state/_index.scss +1 -1
- package/src/scss/state/focus/_defaults.scss +6 -4
- package/src/scss/state/focus/_index.scss +7 -7
- package/src/scss/state/focus/_mixins.scss +15 -0
- package/src/scss/state/focus/_variables.scss +6 -2
- package/src/scss/theme/_index.scss +1 -1
- package/src/scss/theme/color/_defaults.scss +101 -19
- package/src/scss/theme/color/_index.scss +17 -17
- package/src/scss/theme/color/_variables.scss +72 -64
- package/src/scss/theme/typography/_defaults.scss +7 -5
- package/src/scss/theme/typography/_index.scss +1 -1
- package/src/scss/theme/typography/_variables.scss +11 -7
- package/src/scss/utilities/_index.scss +14 -2
- package/src/scss/utilities/alignment/_defaults.scss +62 -0
- package/src/scss/utilities/alignment/_index.scss +75 -0
- package/src/scss/utilities/alignment/_variables.scss +6 -0
- package/src/scss/utilities/color/_defaults.scss +35 -0
- package/src/scss/utilities/color/_index.scss +91 -0
- package/src/scss/utilities/color/_variables.scss +6 -0
- package/src/scss/utilities/display/_defaults.scss +32 -0
- package/src/scss/utilities/display/_index.scss +61 -0
- package/src/scss/utilities/display/_variables.scss +6 -0
- package/src/scss/utilities/flex/_defaults.scss +63 -0
- package/src/scss/utilities/flex/_index.scss +71 -0
- package/src/scss/utilities/flex/_variables.scss +6 -0
- package/src/scss/utilities/height/_defaults.scss +41 -0
- package/src/scss/utilities/height/_index.scss +98 -0
- package/src/scss/utilities/height/_variables.scss +6 -0
- package/src/scss/utilities/inset/_defaults.scss +41 -0
- package/src/scss/utilities/inset/_index.scss +37 -0
- package/src/scss/utilities/inset/_variables.scss +6 -0
- package/src/scss/utilities/justification/_defaults.scss +59 -0
- package/src/scss/utilities/justification/_index.scss +75 -0
- package/src/scss/utilities/justification/_variables.scss +6 -0
- package/src/scss/utilities/list/_defaults.scss +39 -0
- package/src/scss/utilities/list/_index.scss +56 -0
- package/src/scss/utilities/list/_variables.scss +6 -0
- package/src/scss/utilities/order/_defaults.scss +22 -0
- package/src/scss/utilities/order/_index.scss +63 -0
- package/src/scss/utilities/order/_variables.scss +6 -0
- package/src/scss/utilities/position/_defaults.scss +26 -0
- package/src/scss/utilities/position/_index.scss +37 -0
- package/src/scss/utilities/position/_variables.scss +6 -0
- package/src/scss/utilities/ratio/_defaults.scss +28 -0
- package/src/scss/utilities/ratio/_index.scss +52 -0
- package/src/scss/utilities/ratio/_variables.scss +9 -0
- package/src/scss/utilities/spacing/_defaults.scss +9 -4
- package/src/scss/utilities/spacing/_index.scss +134 -29
- package/src/scss/utilities/spacing/_variables.scss +5 -2
- package/src/scss/utilities/typography/_defaults.scss +29 -4
- package/src/scss/utilities/typography/_index.scss +155 -23
- package/src/scss/utilities/typography/_variables.scss +5 -2
- package/src/scss/utilities/visibility/_defaults.scss +25 -0
- package/src/scss/utilities/visibility/_index.scss +36 -0
- package/src/scss/utilities/visibility/_variables.scss +6 -0
- package/src/scss/utilities/width/_defaults.scss +41 -0
- package/src/scss/utilities/width/_index.scss +98 -0
- package/src/scss/utilities/width/_variables.scss +6 -0
- package/stylelint.config.js +5 -0
- package/vite.config.js +57 -0
- package/dist/base/form.css +0 -2
- package/dist/base/form.css.map +0 -1
- package/dist/base/link.css +0 -2
- package/dist/base/link.css.map +0 -1
- package/dist/base/table.css +0 -2
- package/dist/base/table.css.map +0 -1
- package/dist/base.css +0 -2
- package/dist/base.css.map +0 -1
- package/dist/component/button.css +0 -2
- package/dist/component/button.css.map +0 -1
- package/dist/component/input-group.css.map +0 -1
- package/dist/component/table.css +0 -2
- package/dist/component/table.css.map +0 -1
- package/dist/component.css +0 -2
- package/dist/component.css.map +0 -1
- package/dist/graupl.css +0 -2
- package/dist/graupl.css.map +0 -1
- package/dist/layout/columns.css +0 -2
- package/dist/layout/columns.css.map +0 -1
- package/dist/layout/container.css.map +0 -1
- package/dist/layout.css +0 -2
- package/dist/layout.css.map +0 -1
- package/dist/state/focus.css +0 -2
- package/dist/state/focus.css.map +0 -1
- package/dist/state.css +0 -2
- package/dist/state.css.map +0 -1
- package/dist/theme/color.css +0 -2
- package/dist/theme/color.css.map +0 -1
- package/dist/theme/typography.css +0 -2
- package/dist/theme/typography.css.map +0 -1
- package/dist/theme.css +0 -2
- package/dist/theme.css.map +0 -1
- package/dist/utilities/colors.css.map +0 -1
- package/dist/utilities/spacing.css +0 -2
- package/dist/utilities/spacing.css.map +0 -1
- package/dist/utilities/typography.css +0 -2
- package/dist/utilities/typography.css.map +0 -1
- package/dist/utilities.css +0 -2
- package/dist/utilities.css.map +0 -1
- package/scss/component/button.scss +0 -3
- package/scss/component/table.scss +0 -3
- package/scss/utilities/colors.scss +0 -3
- package/src/scss/component/button/_defaults.scss +0 -39
- package/src/scss/component/button/_index.scss +0 -98
- package/src/scss/component/table/_defaults.scss +0 -30
- package/src/scss/component/table/_index.scss +0 -77
- package/src/scss/component/table/_variables.scss +0 -64
- package/src/scss/mixins/_media-queries.scss +0 -26
- package/src/scss/utilities/colors/_defaults.scss +0 -5
- package/src/scss/utilities/colors/_index.scss +0 -22
- package/src/scss/utilities/colors/_variables.scss +0 -3
- /package/dist/{layout → css/layout}/container.css +0 -0
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
var Graupl=function(){"use strict";var R=Object.defineProperty;var U=(d,i,p)=>i in d?R(d,i,{enumerable:!0,configurable:!0,writable:!0,value:p}):d[i]=p;var a=(d,i,p)=>U(d,typeof i!="symbol"?i+"":i,p);function d(e,t){try{if(typeof t!="object"){const s=typeof t;throw new TypeError(`Elements given to isValidInstance() must be inside of an object. "${s}" given.`)}for(const s in t)if(!(t[s]instanceof e)){const r=typeof t[s];throw new TypeError(`${s} must be an instance of ${e.name}. "${r}" given.`)}return{status:!0,error:null}}catch(s){return{status:!1,error:s}}}function i(e,t){try{if(typeof t!="object"){const s=typeof t;throw new TypeError(`Values given to isValidType() must be inside of an object. "${s}" given.`)}for(const s in t){const r=typeof t[s];if(r!==e)throw new TypeError(`${s} must be a ${e}. "${r}" given.`)}return{status:!0,error:null}}catch(s){return{status:!1,error:s}}}function p(e){try{if(typeof e!="object"){const t=typeof e;throw new TypeError(`Values given to isQuerySelector() must be inside of an object. "${t}" given.`)}for(const t in e)try{if(e[t]===null)throw new Error;document.querySelector(e[t])}catch{throw new TypeError(`${t} must be a valid query selector. "${e[t]}" given.`)}return{status:!0,error:null}}catch(t){return{status:!1,error:t}}}function h(e){try{if(typeof e!="object"||Array.isArray(e)){const t=typeof e;throw new TypeError(`Values given to isValidClassList() must be inside of an object. "${t}" given.`)}for(const t in e){const s=typeof e[t];if(s!=="string")if(Array.isArray(e[t]))e[t].forEach(r=>{if(typeof r!="string")throw new TypeError(`${t} must be a string or an array of strings. An array containing non-strings given.`)});else throw new TypeError(`${t} must be a string or an array of strings. "${s}" given.`);else{const r={};r[t]=e[t],p(r)}}return{status:!0,error:null}}catch(t){return{status:!1,error:t}}}function w(e,t){if(i("string",{tagName:e}).status&&d(HTMLElement,t).status){const s=e.toLowerCase();let r=!0;for(const n in t)t[n].tagName.toLowerCase()!==s&&(r=!1);return r}else return!1}function u(e,t){e===""||e.length===0||(typeof e=="string"?t.classList.add(e):t.classList.add(...e))}function c(e,t){e===""||e.length===0||(typeof e=="string"?t.classList.remove(e):t.classList.remove(...e))}function m(e){try{const t=e.key||e.keyCode,s={Enter:t==="Enter"||t===13,Space:t===" "||t==="Spacebar"||t===32,Escape:t==="Escape"||t==="Esc"||t===27,ArrowUp:t==="ArrowUp"||t==="Up"||t===38,ArrowRight:t==="ArrowRight"||t==="Right"||t===39,ArrowDown:t==="ArrowDown"||t==="Down"||t===40,ArrowLeft:t==="ArrowLeft"||t==="Left"||t===37,Home:t==="Home"||t===36,End:t==="End"||t===35,Tab:t==="Tab"||t===9};return Object.keys(s).find(r=>s[r]===!0)||""}catch{return""}}function f(e){e.preventDefault(),e.stopPropagation()}function b(e=null){window.Graupl=window.Graupl||{},i("string",{type:e})&&(window.Graupl[e]=window.Graupl[e]||{})}function E(e=null){return i("string",{type:e})?window.Graupl[e]:window.Graupl}function T(e,t={}){i("string",{type:e})&&i("object",{data:t})&&(window.Graupl[e]=t)}function I(e){i("string",{type:e})&&(window.Graupl[e]={})}function k(e,t,s){i("string",{type:e,key:t})&&(window.Graupl[e][t]=s)}function v(e,t){return i("string",{type:e,key:t})?window.Graupl[e][t]:null}function A(e,t){i("string",{type:e,key:t})&&delete window.Graupl[e][t]}const y={initializeStorage:b,getStorage:E,setStorage:T,clearStorage:I,pushToStorage:k,getFromStorage:v,removeFromStorage:A};class x{constructor({alertElement:t,controllerElement:s=null,showClass:r="show",hideClass:n="hide",transitionClass:l="transitioning",transitionTimer:_=150,isHidden:C=!1,key:o=null,initialize:g=!1}){a(this,"_dom",{alert:null,controller:null});a(this,"_hidden",!1);a(this,"_showClass","");a(this,"_hideClass","");a(this,"_transitionClass","");a(this,"_transitionTimer",150);a(this,"_key","");a(this,"_errors",[]);a(this,"_showEvent",new CustomEvent("grauplAlertShow",{bubbles:!0,detail:{alert:this}}));a(this,"_hideEvent",new CustomEvent("grauplAlertHide",{bubbles:!0,detail:{alert:this}}));this._dom.alert=t,this._dom.controller=s,this._showClass=r||"",this._hideClass=n||"",this._transitionClass=l||"",this._transitionTimer=_,this._hidden=C,this._key=o||"",g&&this.initialize()}initialize(){try{if(!this._validate())throw new Error(`Graupl Alert: cannot initialize alert. The following errors have been found:
|
|
2
|
+
- ${this.errors.join(`
|
|
3
|
+
- `)}`);this._generateKey(),this._setIds(),this._handleClick(),this._handleKeydown(),this._handleKeyup(),y.initializeStorage("alerts"),y.pushToStorage("alerts",this.dom.alert.id,this)}catch(t){console.error(t)}}get dom(){return this._dom}get showClass(){return this._showClass}get hideClass(){return this._hideClass}get transitionClass(){return this._transitionClass}get transitionTimer(){return this._transitionTimer}get key(){return this._key}set showClass(t){h({showClass:t}),this._showClass!==t&&(this._showClass=t)}set hideClass(t){h({hideClass:t}),this._hideClass!==t&&(this._hideClass=t)}set transitionClass(t){h({transitionClass:t}),this._transitionClass!==t&&(this._transitionClass=t)}set transitionTimer(t){i("number",{transitionTimer:t}),this._transitionTimer!==t&&(this._transitionTimer=t)}set key(t){i("string",{value:t}),this._key!==t&&(this._key=t)}_validate(){let t=!0,s;if(this._dom.controller!==null?s=d(HTMLElement,{alertElement:this._dom.alert,controllerElement:this._dom.controller}):s=d(HTMLElement,{alertElement:this._dom.alert}),s.status||(this._errors.push(s.message),t=!1),this._showClass!==""){const l=h({showClass:this._showClass});l.status||(this._errors.push(l.message),t=!1)}if(this._hideClass!==""){const l=h({hideClass:this._hideClass});l.status||(this._errors.push(l.message),t=!1)}if(this._transitionClass!==""){const l=h({transitionClass:this._transitionClass});l.status||(this._errors.push(l.message),t=!1)}const r=i("number",{transitionTimer:this._transitionTimer});r.status||(this._errors.push(r.message),t=!1);const n=i("boolean",{isHidden:this._hidden});return n.status||(this._errors.push(n.message),t=!1),t}_generateKey(t=!1){(this.key===""||t)&&(this.key=Math.random().toString(36).replace(/[^a-z]+/g,"").substring(0,10))}_setIds(){this.dom.alert.id=this.dom.alert.id||`alert-${this.key}`,this.dom.controller.id=this.dom.controller.id||`alert-controller-${this.key}`}show(t=!0){this._hidden&&(this.transitionClass!==""?(u(this.transitionClass,this.dom.alert),requestAnimationFrame(()=>{this.hideClass!==""&&c(this.hideClass,this.dom.alert),requestAnimationFrame(()=>{this.showClass!==""&&u(this.showClass,this.dom.alert),requestAnimationFrame(()=>{c(this.transitionClass,this.dom.alert)})})})):(this.showClass!==""&&u(this.showClass,this.dom.alert),this.hideClass!==""&&c(this.hideClass,this.dom.alert)),this._hidden=!1,t&&this.dom.alert.dispatchEvent(this._hideEvent))}hide(t=!0){this._hidden||(this.transitionClass!==""?(u(this.transitionClass,this.dom.alert),requestAnimationFrame(()=>{this.showClass!==""&&c(this.showClass,this.dom.alert),requestAnimationFrame(()=>{this.transitionTimer>0?setTimeout(()=>{this.hideClass!==""&&u(this.hideClass,this.dom.alert),requestAnimationFrame(()=>{c(this.transitionClass,this.dom.alert)})},this.transitionTimer):(this.hideClass!==""&&u(this.hideClass,this.dom.alert),requestAnimationFrame(()=>{c(this.transitionClass,this.dom.alert)}))})})):(this.hideClass!==""&&u(this.hideClass,this.dom.alert),this.showClass!==""&&c(this.showClass,this.dom.alert)),this._hidden=!0,t&&this.dom.alert.dispatchEvent(this._hideEvent))}_handleClick(){this.dom.controller!==null&&this.dom.controller.addEventListener("pointerup",()=>this.hide())}_handleKeydown(){this.dom.controller!==null&&this.dom.controller.addEventListener("keydown",t=>{const s=m(t);(s==="Space"||s==="Enter")&&f(t)})}_handleKeyup(){this.dom.controller!==null&&this.dom.controller.addEventListener("keyup",t=>{const s=m(t);(s==="Space"||s==="Enter")&&this.hide()})}}class D{constructor({carouselElement:t,carouselItemSelector:s=".carousel-item",carouselItemContainerSelector:r=".carousel-item-container",carouselControlSelector:n=".carousel-control",carouselControlContainerSelector:l=".carousel-control-container",carouselTabSelector:_=".carousel-tab",carouselTabContainerSelector:C=".carousel-tab-container",autoplaySelector:o=".autoplay",nextSelector:g=".next",previousSelector:S=".previous",activeClass:L="active",previousClass:$="previous",nextClass:M="next",playClass:G="play",pauseClass:F="pause",autoplay:O=!0,transitionDelay:q=1e4,transitionDuration:j=500,playText:K="Play",pauseText:z="Pause",prefix:H="graupl-",key:P=null,initialize:V=!1}){a(this,"_dom",{carousel:null,carouselItems:[],carouselItemContainer:null,carouselControls:[],carouselControlContainer:null,carouselTabs:[],carouselTabContainer:null,autoplay:null,next:null,previous:null});a(this,"_selectors",{carouselItems:"",carouselItemContainer:"",carouselControls:"",carouselControlContainer:"",carouselTabs:"",carouselTabContainer:"",autoplay:"",next:"",previous:""});a(this,"_activeClass","active");a(this,"_previousClass","previous");a(this,"_nextClass","next");a(this,"_playClass","play");a(this,"_pauseClass","pause");a(this,"_currentItem",0);a(this,"_autoplay",!0);a(this,"_transitionDelay",1e4);a(this,"_transitionDuration",500);a(this,"_playText","Play");a(this,"_pauseText","Pause");a(this,"_currentAction","next");a(this,"_autoplayInterval",null);a(this,"_prefix","graupl-");a(this,"_key","");a(this,"_errors",[]);this._dom.carousel=t,this._selectors.carouselItems=s,this._selectors.carouselItemContainer=r,this._selectors.carouselControls=n,this._selectors.carouselControlContainer=l,this._selectors.carouselTabs=_,this._selectors.carouselTabContainer=C,this._selectors.autoplay=o,this._selectors.next=g,this._selectors.previous=S,this._activeClass=L||"",this._previousClass=$||"",this._nextClass=M||"",this._playClass=G||"",this._pauseClass=F||"",this._autoplay=O,this._transitionDelay=q,this._transitionDuration=j,this._playText=K||"",this._pauseText=z||"",this._prefix=H||"",this._key=P||"",V&&this.initialize()}initialize(){try{if(!this._validate())throw new Error(`Graupl Carousel: cannot initialize carousel. The following errors have been found:
|
|
4
|
+
- ${this.errors.join(`
|
|
5
|
+
- `)}`);this._generateKey(),this._setDOMElements(),this._setIds(),this._setAriaAttributes(),this.activateFirstItem(),this._handleAutoplay(),this._handleFocus(),this._handleClick(),this._handleHover(),this._handleKeydown(),this._handleKeyup(),this._setTransitionDuration(),y.initializeStorage("carousels"),y.pushToStorage("carousels",this.dom.carousel.id,this)}catch(t){console.error(t)}}get dom(){return this._dom}get selectors(){return this._selectors}get activeClass(){return this._activeClass}get previousClass(){return this._previousClass}get nextClass(){return this._nextClass}get playClass(){return this._playClass}get pauseClass(){return this._pauseClass}get currentItem(){return this._currentItem}get currentCarouselItem(){return this.dom.carouselItems[this.currentItem]}get currentCarouselTab(){return this.dom.carouselTabs[this.currentItem]}get autoplay(){return this._autoplay}get transitionDelay(){return this._transitionDelay}get transitionDuration(){return this._transitionDuration}get playText(){return this._playText}get pauseText(){return this._pauseText}get prefix(){return this._prefix}get key(){return this._key}get currentAction(){return this._currentAction}get errors(){return this._errors}set currentItem(t){if(i("number",{value:t}),t===this.currentItem)return;t<0?this._currentItem=0:t>=this.dom.carouselItems.length?this._currentItem=this.dom.carouselItems.length-1:this._currentItem=t,this._dom.carousel.querySelectorAll(this.selectors.carouselTab)&&this.dom.carouselItems.forEach((r,n)=>{r.setAttribute("aria-selected",n===this._currentItem)})}set autoplay(t){i("boolean",{value:t}),this._autoplay!==t&&(this._autoplay=t)}set activeClass(t){h({activeClass:t}),this._activeClass!==t&&(this._activeClass=t)}set previousClass(t){h({previousClass:t}),this._previousClass!==t&&(this._previousClass=t)}set nextClass(t){h({nextClass:t}),this._nextClass!==t&&(this._nextClass=t)}set playClass(t){h({playClass:t}),this._playClass!==t&&(this._playClass=t)}set pauseClass(t){h({pauseClass:t}),this._pauseClass!==t&&(this._pauseClass=t)}set transitionDelay(t){i("number",{value:t}),t!==this.transitionDelay&&t>=0&&(this._currentItem=t)}set transitionDuration(t){i("number",{value:t}),this._transitionDuration!==t&&t>=0&&(this._transitionDuration=t,this._setTransitionDuration())}set playText(t){i("string",{value:t}),this._playText!==t&&(this._playText=t)}set pauseText(t){i("string",{value:t}),this._pauseText!==t&&(this._pauseText=t)}set prefix(t){i("string",{value:t}),this._prefix!==t&&(this._prefix=t)}set key(t){i("string",{value:t}),this._key!==t&&(this._key=t)}_validate(){let t=!0;const s=d(HTMLElement,{carousel:this.dom.carousel});s||(this._errors.push(s.message),t=!1);const r=p({carouselItemsSelector:this._selectors.carouselItems,carouselItemContainerSelector:this._selectors.carouselItemContainer,carouselControlsSelector:this._selectors.carouselControls,carouselControlContainerSelector:this._selectors.carouselControlContainer,carouselTabsSelector:this._selectors.carouselTabs,carouselTabContainerSelector:this._selectors.carouselTabContainer,autoplaySelector:this._selectors.autoplay,nextSelector:this._selectors.next,previousSelector:this._selectors.previous});r||(this._errors.push(r.message),t=!1);const n=i("boolean",{autoplay:this.autoplay});n||(this._errors.push(n.message),t=!1);const l=i("number",{transitionDelay:this._transitionDelay});l||(this._errors.push(l.message),t=!1);const _=i("number",{transitionDuration:this._transitionDuration});if(_||(this._errors.push(_.message),t=!1),this._activeClass!==""){const o=h({activeClass:this._activeClass});o||(this._errors.push(o.message),t=!1)}if(this._previousClass!==""){const o=h({previousClass:this._previousClass});o||(this._errors.push(o.message),t=!1)}if(this._nextClass!==""){const o=h({nextClass:this._nextClass});o||(this._errors.push(o.message),t=!1)}if(this._playClass!==""){const o=h({playClass:this._playClass});o||(this._errors.push(o.message),t=!1)}if(this._pauseClass!==""){const o=h({pauseClass:this._pauseClass});o||(this._errors.push(o.message),t=!1)}if(this._playText!==""){const o=i("string",{playText:this._playText});o||(this._errors.push(o.message),t=!1)}if(this._pauseText!==""){const o=i("string",{pauseText:this._pauseText});o||(this._errors.push(o.message),t=!1)}const C=i("string",{prefix:this._prefix});return C||(this._errors.push(C.message),t=!1),t}_setDOMElementType(t,s=this.dom.carousel,r=!0){if(typeof this.selectors[t]=="string"){if(t==="carousel")throw new Error(`Graupl Carousel: "${t}" element cannot be set through _setDOMElementType.`);if(s!==this.dom.carousel&&d(HTMLElement,{base:s}),Array.isArray(this._dom[t])){const l=Array.from(s.querySelectorAll(this.selectors[t])).filter(_=>_.parentElement===s);r?this._dom[t]=l:this._dom[t]=[...this._dom[t],...l]}else{const n=s.querySelector(this.selectors[t]);if(n&&n.parentElement!==s)return;r&&(this._dom[t]=n)}}else throw new Error(`Graupl Carousel: "${t}" is not a valid element type within the carousel.`)}_resetDOMElementType(t){if(typeof this.selectors[t]=="string"){if(t==="carousel")throw new Error(`Graupl Carousel: "${t}" element cannot be reset through _resetDOMElementType.`);Array.isArray(this._dom[t])?this._dom[t]=[]:this._dom[t]=null}else throw new Error(`Graupl Carousel: "${t}" is not a valid element type within the carousel.`)}_setDOMElements(){this._setDOMElementType("carouselItemContainer"),this._setDOMElementType("carouselControlContainer"),this._setDOMElementType("carouselTabContainer"),this.dom.carouselItemContainer&&this._setDOMElementType("carouselItems",this.dom.carouselItemContainer),this.dom.carouselControlContainer&&(this._setDOMElementType("carouselControls",this.dom.carouselControlContainer),this._setDOMElementType("autoplay",this.dom.carouselControlContainer),this._setDOMElementType("next",this.dom.carouselControlContainer),this._setDOMElementType("previous",this.dom.carouselControlContainer)),this._dom.carouselTabContainer&&this._setDOMElementType("carouselTabs",this.dom.carouselTabContainer)}_generateKey(t=!1){(this.key===""||t)&&(this.key=Math.random().toString(36).replace(/[^a-z]+/g,"").substring(0,10))}_setIds(){this.dom.carousel.id=this.dom.carousel.id||`carousel-${this.key}`,this.dom.carouselItems.forEach((t,s)=>{t.id=t.id||`carousel-item-${this.key}-${s}`}),this.dom.carouselTabs.forEach((t,s)=>{t.id=t.id||`carousel-tab-${this.key}-${s}`})}_setAriaAttributes(){!w("section",{carousel:this.dom.carousel})&&!this.dom.carousel.getAttribute("role")!=="region"&&this.dom.carousel.setAttribute("role","group"),this._dom.carousel.setAttribute("aria-roledescription","carousel"),this.dom.carouselTabContainer&&this.dom.carouselTabContainer.setAttribute("role","tablist"),this.dom.carouselTabs.forEach((t,s)=>{w("button",{tab:t})||t.setAttribute("role","button"),t.setAttribute("aria-selected",s===0),t.setAttribute("aria-controls",this.dom.carouselItems[s].id)})}_setInterval(){this._clearInterval(),this._autoplayInterval=setInterval(()=>{this.activateNextItem()},this.transitionDelay)}_clearInterval(){clearInterval(this._autoplayInterval)}_handleAutoplay(){this.autoplay?(u(this.pauseClass,this.dom.autoplay),c(this.playClass,this.dom.autoplay),this.dom.autoplay.setAttribute("aria-label",this.pauseText),this.dom.carousel.setAttribute("aria-live","off"),this._setInterval()):(u(this.playClass,this.dom.autoplay),c(this.pauseClass,this.dom.autoplay),this.dom.autoplay.setAttribute("aria-label",this.playText),this.dom.carousel.setAttribute("aria-live","polite"),this._clearInterval())}_handleFocus(){this.dom.carousel.addEventListener("focusin",()=>{this.autoplay&&this._clearInterval()}),this.dom.carousel.addEventListener("focusout",()=>{this.autoplay&&this._setInterval()})}_handleClick(){this.dom.next.addEventListener("pointerup",()=>{this.activateNextItem()}),this.dom.previous.addEventListener("pointerup",()=>{this.activatePreviousItem()}),this.dom.autoplay.addEventListener("pointerup",()=>{this.toggleAutoplay()}),this.dom.carouselTabs.forEach((t,s)=>{t.addEventListener("pointerup",()=>{this.currentItem>s?this._currentAction="previous":this._currentAction="next",this.activateItem(s)})})}_handleHover(){this.dom.carousel.addEventListener("pointerover",()=>{this.autoplay&&this._clearInterval()}),this.dom.carousel.addEventListener("pointerleave",()=>{this.autoplay&&this._setInterval()})}_handleKeydown(){this.dom.carouselControls.forEach(t=>{t.addEventListener("keydown",s=>{switch(m(s)){case"Space":case"Enter":f(s);break}})}),this.dom.carouselTabs.forEach(t=>{t.addEventListener("keydown",s=>{switch(m(s)){case"Space":case"Enter":f(s);break}})})}_handleKeyup(){this.dom.next.addEventListener("keyup",t=>{switch(m(t)){case"Space":case"Enter":this.activateNextItem(),f(t);break}}),this.dom.previous.addEventListener("keyup",t=>{switch(m(t)){case"Space":case"Enter":this.activatePreviousItem(),f(t);break}}),this.dom.autoplay.addEventListener("keyup",t=>{switch(m(t)){case"Space":case"Enter":this.toggleAutoplay(),f(t);break}}),this.dom.carouselTabs.forEach((t,s)=>{t.addEventListener("keyup",r=>{switch(m(r)){case"Space":case"Enter":this.activateItem(s),f(r);break}})})}_setTransitionDuration(){this.dom.carousel.style.setProperty(`--${this.prefix}carousel-transition-duration`,`${this.transitionDuration}ms`)}activateCurrentItem(){u(this.activeClass,this.currentCarouselItem),this.currentCarouselTab&&(this.currentCarouselTab.setAttribute("aria-selected",!0),u(this.activeClass,this.currentCarouselTab))}deactivateCurrentItem(){c(this.activeClass,this.currentCarouselItem),this.currentCarouselTab&&(this.currentCarouselTab.setAttribute("aria-selected",!1),c(this.activeClass,this.currentCarouselTab))}activateItem(t){const s=this.currentItem;this.dom.carousel.dataset.grauplAction=this._currentAction,this.autoplay&&this._clearInterval(),u(this.previousClass,this.currentCarouselItem),u(this.nextClass,this.dom.carouselItems[t]),requestAnimationFrame(()=>{this.deactivateCurrentItem(),this.currentItem=t,this.activateCurrentItem(),requestAnimationFrame(()=>{setTimeout(()=>{c(this.previousClass,this.dom.carouselItems[s]),c(this.nextClass,this.currentCarouselItem)},this.transitionDuration)})}),this.autoplay&&this._setInterval()}activateFirstItem(){this.activateItem(0)}activateLastItem(){this.activateItem(this.dom.carouselItems.length-1)}activateNextItem(){this._currentAction="next",this.currentItem+1>=this.dom.carouselItems.length?this.activateFirstItem():this.activateItem(this.currentItem+1)}activatePreviousItem(){this._currentAction="previous",this.currentItem-1<0?this.activateLastItem():this.activateItem(this.currentItem-1)}toggleAutoplay(){this.autoplay=!this.autoplay,this._handleAutoplay()}}return{Alert:x,Carousel:D}}();
|
|
@@ -35,17 +35,44 @@ export default defineConfig({
|
|
|
35
35
|
|
|
36
36
|
socialLinks: [{ icon: "github", link: "https://github.com/Graupl/graupl" }],
|
|
37
37
|
|
|
38
|
-
sidebar:
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
38
|
+
sidebar: [
|
|
39
|
+
{
|
|
40
|
+
text: "Getting Started",
|
|
41
|
+
items: [
|
|
42
|
+
{ text: "Compiling Graupl", link: "/compiling-graupl" },
|
|
43
|
+
{ text: "Introduction", link: "/introduction" },
|
|
44
|
+
],
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
text: "Layout & Content",
|
|
48
|
+
items: [
|
|
49
|
+
{ text: "Layout", link: "/layout" },
|
|
50
|
+
{ text: "Content", link: "/content" },
|
|
51
|
+
{ text: "Forms", link: "/forms" },
|
|
52
|
+
],
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
text: "Components",
|
|
56
|
+
items: [
|
|
57
|
+
{ text: "Alert", link: "/components/alert" },
|
|
58
|
+
{ text: "Button", link: "/components/button" },
|
|
59
|
+
{ text: "Card", link: "/components/card" },
|
|
60
|
+
{ text: "Input Group", link: "/components/inputgroup" },
|
|
61
|
+
{ text: "Menu", link: "/components/menu" },
|
|
62
|
+
{ text: "Navigation", link: "/components/navigation" },
|
|
63
|
+
],
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
text: "Advanced Topics",
|
|
67
|
+
items: [
|
|
68
|
+
{ text: "Utilities", link: "/utilities" },
|
|
69
|
+
{ text: "Functions", link: "/functions" },
|
|
70
|
+
{ text: "Mixins", link: "/mixins" },
|
|
71
|
+
{ text: "State", link: "/state" },
|
|
72
|
+
{ text: "Theme", link: "/theme" },
|
|
73
|
+
{ text: "Defaults", link: "/defaults" },
|
|
74
|
+
],
|
|
75
|
+
},
|
|
76
|
+
],
|
|
50
77
|
},
|
|
51
78
|
});
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
# Alert
|
|
2
|
+
|
|
3
|
+
Defaults
|
|
4
|
+
|
|
5
|
+
```jsx
|
|
6
|
+
// Alert selectors.
|
|
7
|
+
$alert-selector: ".alert" !default;
|
|
8
|
+
$alert-theme-selector-prefix: "." !default;
|
|
9
|
+
$alert-body-selector: ".alert-body" !default;
|
|
10
|
+
$alert-header-selector: ".alert-header" !default;
|
|
11
|
+
$alert-footer-selector: ".alert-footer" !default;
|
|
12
|
+
$alert-title-selector: ".alert-title" !default;
|
|
13
|
+
$alert-dismisser-selector: ".dismisser" !default;
|
|
14
|
+
$alert-hidden-selector: ".hide" !default;
|
|
15
|
+
$alert-shown-selector: ".show" !default;
|
|
16
|
+
$alert-transition-selector: ".transitioning" !default;
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
Variables
|
|
20
|
+
|
|
21
|
+
Alert Properties
|
|
22
|
+
|
|
23
|
+
```jsx
|
|
24
|
+
--#{root-defaults.$prefix}-alert-padding-x
|
|
25
|
+
--#{root-defaults.$prefix}-alert-padding-y
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
Alert Gap Properties
|
|
29
|
+
|
|
30
|
+
```jsx
|
|
31
|
+
--#{root-defaults.$prefix}-alert-column-gap
|
|
32
|
+
--#{root-defaults.$prefix}-alert-row-gap
|
|
33
|
+
--#{root-defaults.$prefix}-alert-gap
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
Alert Colour Properties
|
|
37
|
+
|
|
38
|
+
```jsx
|
|
39
|
+
--#{root-defaults.$prefix}-alert-background
|
|
40
|
+
--#{root-defaults.$prefix}-alert-color
|
|
41
|
+
--#{root-defaults.$prefix}-alert-link-color
|
|
42
|
+
--#{root-defaults.$prefix}-alert-link-visited-color
|
|
43
|
+
--#{root-defaults.$prefix}-alert-link-focus-color
|
|
44
|
+
--#{root-defaults.$prefix}-alert-link-hover-color
|
|
45
|
+
--#{root-defaults.$prefix}-alert-link-active-color
|
|
46
|
+
--#{root-defaults.$prefix}-alert-link-disabled-color
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
Alert Border Properties
|
|
50
|
+
|
|
51
|
+
```jsx
|
|
52
|
+
--#{root-defaults.$prefix}-alert-border-color
|
|
53
|
+
--#{root-defaults.$prefix}-alert-top-left-border-radius
|
|
54
|
+
--#{root-defaults.$prefix}-alert-top-right-border-radius
|
|
55
|
+
--#{root-defaults.$prefix}-alert-bottom-left-border-radius
|
|
56
|
+
--#{root-defaults.$prefix}-alert-bottom-right-border-radius
|
|
57
|
+
--#{root-defaults.$prefix}-alert-border-radius
|
|
58
|
+
--#{root-defaults.$prefix}-alert-border-style
|
|
59
|
+
--#{root-defaults.$prefix}-alert-border-width
|
|
60
|
+
--#{root-defaults.$prefix}-alert-border
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
Alert Title Properties
|
|
64
|
+
|
|
65
|
+
```jsx
|
|
66
|
+
--#{root-defaults.$prefix}-alert-title-color
|
|
67
|
+
--#{root-defaults.$prefix}-alert-title-font-size
|
|
68
|
+
--#{root-defaults.$prefix}-alert-title-font-weight
|
|
69
|
+
--#{root-defaults.$prefix}-alert-title-font-family
|
|
70
|
+
--#{root-defaults.$prefix}-alert-title-line-height
|
|
71
|
+
--#{root-defaults.$prefix}-alert-title-margin
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
Markup
|
|
75
|
+
|
|
76
|
+
```jsx
|
|
77
|
+
<div class="py-10 full-width container">
|
|
78
|
+
<h2>Alerts</h2>
|
|
79
|
+
<div class="display-grid g-5">
|
|
80
|
+
<div class="alert">
|
|
81
|
+
<div class="alter-header">
|
|
82
|
+
<h3 class="alert-title">Alert</h3>
|
|
83
|
+
</div>
|
|
84
|
+
<div class="alert-body">
|
|
85
|
+
<p>This is some text that describes the alert.</p>
|
|
86
|
+
</div>
|
|
87
|
+
<div class="alert-footer">
|
|
88
|
+
<a href="#">Action</a>
|
|
89
|
+
</div>
|
|
90
|
+
<button class="alert-dismisser button">x</button>
|
|
91
|
+
</div>
|
|
92
|
+
<div class="alert primary">
|
|
93
|
+
<div class="alter-header">
|
|
94
|
+
<h3 class="alert-title">Primary Alert</h3>
|
|
95
|
+
</div>
|
|
96
|
+
<div class="alert-body">
|
|
97
|
+
<p>This is some text that describes the alert.</p>
|
|
98
|
+
</div>
|
|
99
|
+
<div class="alert-footer">
|
|
100
|
+
<a href="#">Primary Action</a>
|
|
101
|
+
</div>
|
|
102
|
+
<button class="alert-dismisser button primary">x</button>
|
|
103
|
+
</div>
|
|
104
|
+
<div class="alert secondary">
|
|
105
|
+
<div class="alter-header">
|
|
106
|
+
<h3 class="alert-title">Secondary Alert</h3>
|
|
107
|
+
</div>
|
|
108
|
+
<div class="alert-body">
|
|
109
|
+
<p>This is some text that describes the alert.</p>
|
|
110
|
+
</div>
|
|
111
|
+
<div class="alert-footer">
|
|
112
|
+
<a href="#">Secondary Action</a>
|
|
113
|
+
</div>
|
|
114
|
+
<button class="alert-dismisser button secondary">x</button>
|
|
115
|
+
</div>
|
|
116
|
+
<div class="alert tertiary">
|
|
117
|
+
<div class="alter-header">
|
|
118
|
+
<h3 class="alert-title">Tertiary Alert</h3>
|
|
119
|
+
</div>
|
|
120
|
+
<div class="alert-body">
|
|
121
|
+
<p>This is some text that describes the alert.</p>
|
|
122
|
+
</div>
|
|
123
|
+
<div class="alert-footer">
|
|
124
|
+
<a href="#">Tertiary Action</a>
|
|
125
|
+
</div>
|
|
126
|
+
<button class="alert-dismisser button tertiary">x</button>
|
|
127
|
+
</div>
|
|
128
|
+
</div>
|
|
129
|
+
</div>
|
|
130
|
+
```
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
# Button
|
|
2
|
+
|
|
3
|
+
Default Values
|
|
4
|
+
|
|
5
|
+
```jsx
|
|
6
|
+
// Button selectors.
|
|
7
|
+
$button-selector: ".button" !default;
|
|
8
|
+
$button-link-selector: ".link" !default;
|
|
9
|
+
$button-theme-selector-prefix: "." !default;
|
|
10
|
+
|
|
11
|
+
// Button properties.
|
|
12
|
+
$button-transform: none !default;
|
|
13
|
+
$button-visited-transform: $button-transform !default;
|
|
14
|
+
$button-focus-transform: $button-transform !default;
|
|
15
|
+
$button-hover-transform: $button-transform !default;
|
|
16
|
+
$button-active-transform: scale(0.95) !default;
|
|
17
|
+
$button-disabled-transform: $button-transform !default;
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
Button Properties
|
|
21
|
+
|
|
22
|
+
```jsx
|
|
23
|
+
--#{root-defaults.$prefix}-button-min-width
|
|
24
|
+
--#{root-defaults.$prefix}-button-min-height
|
|
25
|
+
--#{root-defaults.$prefix}-button-padding-x
|
|
26
|
+
--#{root-defaults.$prefix}-button-padding-y
|
|
27
|
+
--#{root-defaults.$prefix}-button-padding
|
|
28
|
+
--#{root-defaults.$prefix}-button-font-size
|
|
29
|
+
--#{root-defaults.$prefix}-button-transition
|
|
30
|
+
--#{root-defaults.$prefix}-button-transition-reduced-motion
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
Transform Properties
|
|
34
|
+
|
|
35
|
+
```jsx
|
|
36
|
+
--#{root-defaults.$prefix}-button-transform
|
|
37
|
+
--#{root-defaults.$prefix}-button-visited-transform
|
|
38
|
+
--#{root-defaults.$prefix}-button-focus-transform
|
|
39
|
+
--#{root-defaults.$prefix}-button-hover-transform
|
|
40
|
+
--#{root-defaults.$prefix}-button-active-transform
|
|
41
|
+
--#{root-defaults.$prefix}-button-disabled-transform
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
Background Properties
|
|
45
|
+
|
|
46
|
+
```jsx
|
|
47
|
+
--#{root-defaults.$prefix}-button-background
|
|
48
|
+
--#{root-defaults.$prefix}-button-visited-background
|
|
49
|
+
--#{root-defaults.$prefix}-button-focus-background
|
|
50
|
+
--#{root-defaults.$prefix}-button-hover-background
|
|
51
|
+
--#{root-defaults.$prefix}-button-active-background
|
|
52
|
+
--#{root-defaults.$prefix}-button-disabled-background
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
Text Properties
|
|
56
|
+
|
|
57
|
+
```jsx
|
|
58
|
+
--#{root-defaults.$prefix}-button-color
|
|
59
|
+
--#{root-defaults.$prefix}-button-visited-color
|
|
60
|
+
--#{root-defaults.$prefix}-button-focus-color
|
|
61
|
+
--#{root-defaults.$prefix}-button-hover-color
|
|
62
|
+
--#{root-defaults.$prefix}-button-active-color
|
|
63
|
+
--#{root-defaults.$prefix}-button-disabled-color
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
Border Properties
|
|
67
|
+
|
|
68
|
+
```jsx
|
|
69
|
+
--#{root-defaults.$prefix}-button-border-width
|
|
70
|
+
--#{root-defaults.$prefix}-botton-border-style
|
|
71
|
+
--#{root-defaults.$prefix}-button-border
|
|
72
|
+
--#{root-defaults.$prefix}-button-border-radius
|
|
73
|
+
```
|
|
74
|
+
|
|
75
|
+
Border Colour Properties
|
|
76
|
+
|
|
77
|
+
```jsx
|
|
78
|
+
--#{root-defaults.$prefix}-button-border-color
|
|
79
|
+
--#{root-defaults.$prefix}-button-visited-border-color
|
|
80
|
+
--#{root-defaults.$prefix}-button-focus-border-color
|
|
81
|
+
--#{root-defaults.$prefix}-button-hover-border-color
|
|
82
|
+
--#{root-defaults.$prefix}-button-active-border-color
|
|
83
|
+
--#{root-defaults.$prefix}-button-disabled-border-color
|
|
84
|
+
```
|