diff --git a/_site/collections/menu.overrides b/_site/collections/menu.overrides
index c172e5f..cba59ef 100644
--- a/_site/collections/menu.overrides
+++ b/_site/collections/menu.overrides
@@ -1,3 +1,3 @@
/*******************************
Site Overrides
-*******************************/
\ No newline at end of file
+*******************************/
diff --git a/_site/elements/flag.variables b/_site/elements/flag.variables
index e3e125d..728296f 100644
--- a/_site/elements/flag.variables
+++ b/_site/elements/flag.variables
@@ -1,3 +1,3 @@
-/*-------------------
+/* -------------------
Flag Variables
---------------------*/
+-------------------- */
diff --git a/_site/globals/site.variables b/_site/globals/site.variables
index 3b5dc7d..cd95544 100644
--- a/_site/globals/site.variables
+++ b/_site/globals/site.variables
@@ -1,3 +1,3 @@
/*******************************
User Global Variables
-*******************************/
\ No newline at end of file
+*******************************/
diff --git a/_site/modules/embed.variables b/_site/modules/embed.variables
index e69de29..6f085f9 100644
--- a/_site/modules/embed.variables
+++ b/_site/modules/embed.variables
@@ -0,0 +1,3 @@
+/*******************************
+ User Variable Overrides
+*******************************/
diff --git a/definitions/behaviors/api.js b/definitions/behaviors/api.js
index 43300db..a2e09b5 100644
--- a/definitions/behaviors/api.js
+++ b/definitions/behaviors/api.js
@@ -1,1236 +1,1214 @@
/*!
* # Fomantic-UI - API
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-;(function ($, window, document, undefined) {
-
-'use strict';
-
-$.isWindow = $.isWindow || function(obj) {
- return obj != null && obj === obj.window;
-};
-
- window = (typeof window != 'undefined' && window.Math == Math)
- ? window
- : (typeof self != 'undefined' && self.Math == Math)
- ? self
- : Function('return this')()
-;
-
-$.api = $.fn.api = function(parameters) {
-
- var
- // use window context if none specified
- $allModules = $.isFunction(this)
- ? $(window)
- : $(this),
- moduleSelector = $allModules.selector || '',
- time = new Date().getTime(),
- performance = [],
-
- query = arguments[0],
- methodInvoked = (typeof query == 'string'),
- queryArguments = [].slice.call(arguments, 1),
-
- returnedValue
- ;
-
- $allModules
- .each(function() {
- var
- settings = ( $.isPlainObject(parameters) )
- ? $.extend(true, {}, $.fn.api.settings, parameters)
- : $.extend({}, $.fn.api.settings),
-
- // internal aliases
- namespace = settings.namespace,
- metadata = settings.metadata,
- selector = settings.selector,
- error = settings.error,
- className = settings.className,
-
- // define namespaces for modules
- eventNamespace = '.' + namespace,
- moduleNamespace = 'module-' + namespace,
-
- // element that creates request
- $module = $(this),
- $form = $module.closest(selector.form),
-
- // context used for state
- $context = (settings.stateContext)
- ? ([window,document].indexOf(settings.stateContext) < 0 ? $(document).find(settings.stateContext) : $(settings.stateContext))
- : $module,
-
- // request details
- ajaxSettings,
- requestSettings,
- url,
- data,
- requestStartTime,
- originalData,
-
- // standard module
- element = this,
- context = $context[0],
- instance = $module.data(moduleNamespace),
- module
- ;
-
- module = {
-
- initialize: function() {
- if(!methodInvoked) {
- originalData = settings.data;
- module.bind.events();
- }
- module.instantiate();
- },
+(function ($, window, document) {
+ 'use strict';
- instantiate: function() {
- module.verbose('Storing instance of module', module);
- instance = module;
- $module
- .data(moduleNamespace, instance)
- ;
- },
+ function isWindow(obj) {
+ return obj !== null && obj === obj.window;
+ }
- destroy: function() {
- module.verbose('Destroying previous module for', element);
- $module
- .removeData(moduleNamespace)
- .off(eventNamespace)
- ;
- },
+ function isFunction(obj) {
+ return typeof obj === 'function' && typeof obj.nodeType !== 'number';
+ }
- bind: {
- events: function() {
- var
- triggerEvent = module.get.event()
- ;
- if( triggerEvent ) {
- module.verbose('Attaching API events to element', triggerEvent);
- $module
- .on(triggerEvent + eventNamespace, module.event.trigger)
- ;
- }
- else if(settings.on == 'now') {
- module.debug('Querying API endpoint immediately');
- module.query();
- }
- }
- },
+ window = window !== undefined && window.Math === Math
+ ? window
+ : globalThis;
- decode: {
- json: function(response) {
- if(response !== undefined && typeof response == 'string') {
- try {
- response = JSON.parse(response);
- }
- catch(e) {
- // isn't json string
- }
- }
- return response;
- }
- },
+ $.fn.api = function (parameters) {
+ var
+ // use window context if none specified
+ $allModules = isFunction(this)
+ ? $(window)
+ : $(this),
+ moduleSelector = $allModules.selector || '',
+ time = Date.now(),
+ performance = [],
- read: {
- cachedResponse: function(url) {
+ query = arguments[0],
+ methodInvoked = typeof query === 'string',
+ queryArguments = [].slice.call(arguments, 1),
+
+ returnedValue
+ ;
+
+ $allModules.each(function () {
var
- response
+ settings = $.isPlainObject(parameters)
+ ? $.extend(true, {}, $.fn.api.settings, parameters)
+ : $.extend({}, $.fn.api.settings),
+
+ // internal aliases
+ namespace = settings.namespace,
+ metadata = settings.metadata,
+ selector = settings.selector,
+ error = settings.error,
+ className = settings.className,
+
+ // define namespaces for modules
+ eventNamespace = '.' + namespace,
+ moduleNamespace = 'module-' + namespace,
+
+ // element that creates request
+ $module = $(this),
+ $form = $module.closest(selector.form),
+
+ // context used for state
+ $context = settings.stateContext
+ ? ([window, document].indexOf(settings.stateContext) < 0 ? $(document).find(settings.stateContext) : $(settings.stateContext))
+ : $module,
+
+ // request details
+ ajaxSettings,
+ requestSettings,
+ url,
+ data,
+ requestStartTime,
+ originalData,
+
+ // standard module
+ element = this,
+ context = $context[0],
+ instance = $module.data(moduleNamespace),
+ module
;
- if(window.Storage === undefined) {
- module.error(error.noStorage);
- return;
- }
- response = sessionStorage.getItem(url + module.get.normalizedData());
- module.debug('Using cached response', url, settings.data, response);
- response = module.decode.json(response);
- return response;
- }
- },
- write: {
- cachedResponse: function(url, response) {
- if(response && response === '') {
- module.debug('Response empty, not caching', response);
- return;
- }
- if(window.Storage === undefined) {
- module.error(error.noStorage);
- return;
- }
- if( $.isPlainObject(response) ) {
- response = JSON.stringify(response);
- }
- sessionStorage.setItem(url + module.get.normalizedData(), response);
- module.verbose('Storing cached response for url', url, settings.data, response);
- }
- },
- query: function() {
+ module = {
- if(module.is.disabled()) {
- module.debug('Element is disabled API request aborted');
- return;
- }
+ initialize: function () {
+ if (!methodInvoked) {
+ originalData = settings.data;
+ module.bind.events();
+ }
+ module.instantiate();
+ },
+
+ instantiate: function () {
+ module.verbose('Storing instance of module', module);
+ instance = module;
+ $module
+ .data(moduleNamespace, instance)
+ ;
+ },
- if(module.is.loading()) {
- if(settings.interruptRequests) {
- module.debug('Interrupting previous request');
- module.abort();
- }
- else {
- module.debug('Cancelling request, previous request is still pending');
- return;
- }
- }
-
- // pass element metadata to url (value, text)
- if(settings.defaultData) {
- $.extend(true, settings.urlData, module.get.defaultData());
- }
-
- // Add form content
- if(settings.serializeForm) {
- settings.data = module.add.formData(originalData || settings.data);
- }
-
- // call beforesend and get any settings changes
- requestSettings = module.get.settings();
-
- // check if before send cancelled request
- if(requestSettings === false) {
- module.cancelled = true;
- module.error(error.beforeSend);
- return;
- }
- else {
- module.cancelled = false;
- }
-
- // get url
- url = module.get.templatedURL();
-
- if(!url && !module.is.mocked()) {
- module.error(error.missingURL);
- return;
- }
-
- // replace variables
- url = module.add.urlData( url );
- // missing url parameters
- if( !url && !module.is.mocked()) {
- return;
- }
-
- requestSettings.url = settings.base + url;
-
- // look for jQuery ajax parameters in settings
- ajaxSettings = $.extend(true, {}, settings, {
- type : settings.method || settings.type,
- data : data,
- url : settings.base + url,
- beforeSend : settings.beforeXHR,
- success : function() {},
- failure : function() {},
- complete : function() {}
- });
-
- module.debug('Querying URL', ajaxSettings.url);
- module.verbose('Using AJAX settings', ajaxSettings);
- if(settings.cache === 'local' && module.read.cachedResponse(url)) {
- module.debug('Response returned from local cache');
- module.request = module.create.request();
- module.request.resolveWith(context, [ module.read.cachedResponse(url) ]);
- return;
- }
-
- if( !settings.throttle ) {
- module.debug('Sending request', data, ajaxSettings.method);
- module.send.request();
- }
- else {
- if(!settings.throttleFirstRequest && !module.timer) {
- module.debug('Sending request', data, ajaxSettings.method);
- module.send.request();
- module.timer = setTimeout(function(){}, settings.throttle);
- }
- else {
- module.debug('Throttling request', settings.throttle);
- clearTimeout(module.timer);
- module.timer = setTimeout(function() {
- if(module.timer) {
- delete module.timer;
- }
- module.debug('Sending throttled request', data, ajaxSettings.method);
- module.send.request();
- }, settings.throttle);
- }
- }
+ destroy: function () {
+ module.verbose('Destroying previous module for', element);
+ $module
+ .removeData(moduleNamespace)
+ .off(eventNamespace)
+ ;
+ },
+
+ bind: {
+ events: function () {
+ var
+ triggerEvent = module.get.event()
+ ;
+ if (triggerEvent) {
+ module.verbose('Attaching API events to element', triggerEvent);
+ $module
+ .on(triggerEvent + eventNamespace, module.event.trigger)
+ ;
+ } else if (settings.on === 'now') {
+ module.debug('Querying API endpoint immediately');
+ module.query();
+ }
+ },
+ },
+
+ decode: {
+ json: function (response) {
+ if (response !== undefined && typeof response === 'string') {
+ try {
+ response = JSON.parse(response);
+ } catch (e) {
+ // isn't json string
+ }
+ }
+
+ return response;
+ },
+ },
+
+ read: {
+ cachedResponse: function (url) {
+ var
+ response
+ ;
+ if (window.Storage === undefined) {
+ module.error(error.noStorage);
+
+ return;
+ }
+ response = sessionStorage.getItem(url + module.get.normalizedData());
+ module.debug('Using cached response', url, settings.data, response);
+ response = module.decode.json(response);
+
+ return response;
+ },
+ },
+ write: {
+ cachedResponse: function (url, response) {
+ if (window.Storage === undefined) {
+ module.error(error.noStorage);
+
+ return;
+ }
+ if ($.isPlainObject(response)) {
+ response = JSON.stringify(response);
+ }
+ sessionStorage.setItem(url + module.get.normalizedData(), response);
+ module.verbose('Storing cached response for url', url, settings.data, response);
+ },
+ },
+
+ query: function () {
+ if (module.is.disabled()) {
+ module.debug('Element is disabled API request aborted');
+
+ return;
+ }
- },
+ if (module.is.loading()) {
+ if (settings.interruptRequests) {
+ module.debug('Interrupting previous request');
+ module.abort();
+ } else {
+ module.debug('Cancelling request, previous request is still pending');
- should: {
- removeError: function() {
- return ( settings.hideError === true || (settings.hideError === 'auto' && !module.is.form()) );
- }
- },
+ return;
+ }
+ }
- is: {
- disabled: function() {
- return ($module.filter(selector.disabled).length > 0);
- },
- expectingJSON: function() {
- return settings.dataType === 'json' || settings.dataType === 'jsonp';
- },
- form: function() {
- return $module.is('form') || $context.is('form');
- },
- mocked: function() {
- return (settings.mockResponse || settings.mockResponseAsync || settings.response || settings.responseAsync);
- },
- input: function() {
- return $module.is('input');
- },
- loading: function() {
- return (module.request)
- ? (module.request.state() == 'pending')
- : false
- ;
- },
- abortedRequest: function(xhr) {
- if(xhr && xhr.readyState !== undefined && xhr.readyState === 0) {
- module.verbose('XHR request determined to be aborted');
- return true;
- }
- else {
- module.verbose('XHR request was not aborted');
- return false;
- }
- },
- validResponse: function(response) {
- if( (!module.is.expectingJSON()) || !$.isFunction(settings.successTest) ) {
- module.verbose('Response is not JSON, skipping validation', settings.successTest, response);
- return true;
- }
- module.debug('Checking JSON returned success', settings.successTest, response);
- if( settings.successTest(response) ) {
- module.debug('Response passed success test', response);
- return true;
- }
- else {
- module.debug('Response failed success test', response);
- return false;
- }
- }
- },
+ // pass element metadata to url (value, text)
+ if (settings.defaultData) {
+ $.extend(true, settings.urlData, module.get.defaultData());
+ }
- was: {
- cancelled: function() {
- return (module.cancelled || false);
- },
- successful: function() {
- return (module.request && module.request.state() == 'resolved');
- },
- failure: function() {
- return (module.request && module.request.state() == 'rejected');
- },
- complete: function() {
- return (module.request && (module.request.state() == 'resolved' || module.request.state() == 'rejected') );
- }
- },
+ // Add form content
+ if (settings.serializeForm) {
+ settings.data = module.add.formData(originalData || settings.data);
+ }
- add: {
- urlData: function(url, urlData) {
- var
- requiredVariables,
- optionalVariables
- ;
- if(url) {
- requiredVariables = url.match(settings.regExp.required);
- optionalVariables = url.match(settings.regExp.optional);
- urlData = urlData || settings.urlData;
- if(requiredVariables) {
- module.debug('Looking for required URL variables', requiredVariables);
- $.each(requiredVariables, function(index, templatedString) {
- var
- // allow legacy {$var} style
- variable = (templatedString.indexOf('$') !== -1)
- ? templatedString.slice(2, -1)
- : templatedString.slice(1, -1),
- value = ($.isPlainObject(urlData) && urlData[variable] !== undefined)
- ? urlData[variable]
- : ($module.data(variable) !== undefined)
- ? $module.data(variable)
- : ($context.data(variable) !== undefined)
- ? $context.data(variable)
- : urlData[variable]
- ;
- // remove value
- if(value === undefined) {
- module.error(error.requiredParameter, variable, url);
- url = false;
- return false;
- }
- else {
- module.verbose('Found required variable', variable, value);
- value = (settings.encodeParameters)
- ? module.get.urlEncodedValue(value)
- : value
+ // call beforesend and get any settings changes
+ requestSettings = module.get.settings();
+
+ // check if before send cancelled request
+ if (requestSettings === false) {
+ module.cancelled = true;
+ module.error(error.beforeSend);
+
+ return;
+ }
+
+ module.cancelled = false;
+
+ // get url
+ url = module.get.templatedURL();
+
+ if (!url && !module.is.mocked()) {
+ module.error(error.missingURL);
+
+ return;
+ }
+
+ // replace variables
+ url = module.add.urlData(url);
+ // missing url parameters
+ if (!url && !module.is.mocked()) {
+ return;
+ }
+
+ requestSettings.url = settings.base + url;
+
+ // look for jQuery ajax parameters in settings
+ ajaxSettings = $.extend(true, {}, settings, {
+ type: settings.method || settings.type,
+ data: data,
+ url: settings.base + url,
+ beforeSend: settings.beforeXHR,
+ success: function () {},
+ failure: function () {},
+ complete: function () {},
+ });
+
+ module.debug('Querying URL', ajaxSettings.url);
+ module.verbose('Using AJAX settings', ajaxSettings);
+ if (settings.cache === 'local' && module.read.cachedResponse(url)) {
+ module.debug('Response returned from local cache');
+ module.request = module.create.request();
+ module.request.resolveWith(context, [module.read.cachedResponse(url)]);
+
+ return;
+ }
+
+ if (!settings.throttle) {
+ module.debug('Sending request', data, ajaxSettings.method);
+ module.send.request();
+ } else {
+ if (!settings.throttleFirstRequest && !module.timer) {
+ module.debug('Sending request', data, ajaxSettings.method);
+ module.send.request();
+ module.timer = setTimeout(function () {}, settings.throttle);
+ } else {
+ module.debug('Throttling request', settings.throttle);
+ clearTimeout(module.timer);
+ module.timer = setTimeout(function () {
+ if (module.timer) {
+ delete module.timer;
+ }
+ module.debug('Sending throttled request', data, ajaxSettings.method);
+ module.send.request();
+ }, settings.throttle);
+ }
+ }
+ },
+
+ should: {
+ removeError: function () {
+ return settings.hideError === true || (settings.hideError === 'auto' && !module.is.form());
+ },
+ },
+
+ is: {
+ disabled: function () {
+ return $module.filter(selector.disabled).length > 0;
+ },
+ expectingJSON: function () {
+ return settings.dataType === 'json' || settings.dataType === 'jsonp';
+ },
+ form: function () {
+ return $module.is('form') || $context.is('form');
+ },
+ mocked: function () {
+ return settings.mockResponse || settings.mockResponseAsync || settings.response || settings.responseAsync;
+ },
+ input: function () {
+ return $module.is('input');
+ },
+ loading: function () {
+ return module.request
+ ? module.request.state() === 'pending'
+ : false;
+ },
+ abortedRequest: function (xhr) {
+ if (xhr && xhr.readyState !== undefined && xhr.readyState === 0) {
+ module.verbose('XHR request determined to be aborted');
+
+ return true;
+ }
+
+ module.verbose('XHR request was not aborted');
+
+ return false;
+ },
+ validResponse: function (response) {
+ if (!module.is.expectingJSON() || !isFunction(settings.successTest)) {
+ module.verbose('Response is not JSON, skipping validation', settings.successTest, response);
+
+ return true;
+ }
+ module.debug('Checking JSON returned success', settings.successTest, response);
+ if (settings.successTest(response)) {
+ module.debug('Response passed success test', response);
+
+ return true;
+ }
+
+ module.debug('Response failed success test', response);
+
+ return false;
+ },
+ },
+
+ was: {
+ cancelled: function () {
+ return module.cancelled || false;
+ },
+ successful: function () {
+ return module.request && module.request.state() === 'resolved';
+ },
+ failure: function () {
+ return module.request && module.request.state() === 'rejected';
+ },
+ complete: function () {
+ return module.request && (module.request.state() === 'resolved' || module.request.state() === 'rejected');
+ },
+ },
+
+ add: {
+ urlData: function (url, urlData) {
+ var
+ requiredVariables,
+ optionalVariables
+ ;
+ if (url) {
+ requiredVariables = url.match(settings.regExp.required);
+ optionalVariables = url.match(settings.regExp.optional);
+ urlData = urlData || settings.urlData;
+ if (requiredVariables) {
+ module.debug('Looking for required URL variables', requiredVariables);
+ $.each(requiredVariables, function (index, templatedString) {
+ var
+ // allow legacy {$var} style
+ variable = templatedString.indexOf('$') !== -1
+ ? templatedString.slice(2, -1)
+ : templatedString.slice(1, -1),
+ value = $.isPlainObject(urlData) && urlData[variable] !== undefined
+ ? urlData[variable]
+ : ($module.data(variable) !== undefined
+ ? $module.data(variable)
+ : ($context.data(variable) !== undefined // eslint-disable-line unicorn/no-nested-ternary
+ ? $context.data(variable)
+ : urlData[variable]))
+ ;
+ // remove value
+ if (value === undefined) {
+ module.error(error.requiredParameter, variable, url);
+ url = false;
+
+ return false;
+ }
+
+ module.verbose('Found required variable', variable, value);
+ value = settings.encodeParameters
+ ? module.get.urlEncodedValue(value)
+ : value;
+ url = url.replace(templatedString, value);
+ });
+ }
+ if (optionalVariables) {
+ module.debug('Looking for optional URL variables', requiredVariables);
+ $.each(optionalVariables, function (index, templatedString) {
+ var
+ // allow legacy {/$var} style
+ variable = templatedString.indexOf('$') !== -1
+ ? templatedString.slice(3, -1)
+ : templatedString.slice(2, -1),
+ value = $.isPlainObject(urlData) && urlData[variable] !== undefined
+ ? urlData[variable]
+ : ($module.data(variable) !== undefined
+ ? $module.data(variable)
+ : ($context.data(variable) !== undefined // eslint-disable-line unicorn/no-nested-ternary
+ ? $context.data(variable)
+ : urlData[variable]))
+ ;
+ // optional replacement
+ if (value !== undefined) {
+ module.verbose('Optional variable Found', variable, value);
+ url = url.replace(templatedString, value);
+ } else {
+ module.verbose('Optional variable not found', variable);
+ // remove preceding slash if set
+ url = url.indexOf('/' + templatedString) !== -1
+ ? url.replace('/' + templatedString, '')
+ : url.replace(templatedString, '');
+ }
+ });
+ }
+ }
+
+ return url;
+ },
+ formData: function (data) {
+ var
+ formData = {},
+ hasOtherData,
+ useFormDataApi = settings.serializeForm === 'formdata'
+ ;
+ data = data || originalData || settings.data;
+ hasOtherData = $.isPlainObject(data);
+
+ if (useFormDataApi) {
+ formData = new FormData($form[0]);
+ settings.processData = settings.processData !== undefined ? settings.processData : false;
+ settings.contentType = settings.contentType !== undefined ? settings.contentType : false;
+ } else {
+ var
+ formArray = $form.serializeArray(),
+ pushes = {},
+ pushValues = {},
+ build = function (base, key, value) {
+ base[key] = value;
+
+ return base;
+ }
+ ;
+ // add files
+ $.each($('input[type="file"]', $form), function (i, tag) {
+ $.each($(tag)[0].files, function (j, file) {
+ formArray.push({ name: tag.name, value: file });
+ });
+ });
+ $.each(formArray, function (i, el) {
+ if (!settings.regExp.validate.test(el.name)) {
+ return;
+ }
+ var
+ isCheckbox = $('[name="' + el.name + '"]', $form).attr('type') === 'checkbox',
+ floatValue = parseFloat(el.value),
+ value = (isCheckbox && el.value === 'on')
+ || el.value === 'true'
+ || (String(floatValue) === el.value
+ ? floatValue
+ : (el.value === 'false' ? false : el.value)),
+ nameKeys = el.name.match(settings.regExp.key) || [],
+ pushKey = el.name.replace(/\[]$/, '')
+ ;
+ if (!(pushKey in pushes)) {
+ pushes[pushKey] = 0;
+ pushValues[pushKey] = value;
+ } else if (Array.isArray(pushValues[pushKey])) {
+ pushValues[pushKey].push(value);
+ } else {
+ pushValues[pushKey] = [pushValues[pushKey], value];
+ }
+ if (pushKey.indexOf('[]') === -1) {
+ value = pushValues[pushKey];
+ }
+
+ while (nameKeys.length > 0) {
+ var k = nameKeys.pop();
+
+ if (k === '' && !Array.isArray(value)) { // foo[]
+ value = build([], pushes[pushKey]++, value);
+ } else if (settings.regExp.fixed.test(k)) { // foo[n]
+ value = build([], k, value);
+ } else if (settings.regExp.named.test(k)) { // foo; foo[bar]
+ value = build({}, k, value);
+ }
+ }
+ formData = $.extend(true, formData, value);
+ });
+ }
+
+ if (hasOtherData) {
+ module.debug('Extending existing data with form data', data, formData);
+ if (useFormDataApi) {
+ $.each(Object.keys(data), function (i, el) {
+ formData.append(el, data[el]);
+ });
+ data = formData;
+ } else {
+ data = $.extend(true, {}, data, formData);
+ }
+ } else {
+ module.debug('Adding form data', formData);
+ data = formData;
+ }
+
+ return data;
+ },
+ },
+
+ send: {
+ request: function () {
+ module.set.loading();
+ module.request = module.create.request();
+ if (module.is.mocked()) {
+ module.mockedXHR = module.create.mockedXHR();
+ } else {
+ module.xhr = module.create.xhr();
+ }
+ settings.onRequest.call(context, module.request, module.xhr);
+ },
+ },
+
+ event: {
+ trigger: function (event) {
+ module.query();
+ if (event.type === 'submit' || event.type === 'click') {
+ event.preventDefault();
+ }
+ },
+ xhr: {
+ always: function () {
+ // nothing special
+ },
+ done: function (response, textStatus, xhr) {
+ var
+ context = this,
+ elapsedTime = Date.now() - requestStartTime,
+ timeLeft = settings.loadingDuration - elapsedTime,
+ translatedResponse = isFunction(settings.onResponse)
+ ? (module.is.expectingJSON() && !settings.rawResponse
+ ? settings.onResponse.call(context, $.extend(true, {}, response))
+ : settings.onResponse.call(context, response))
+ : false
+ ;
+ timeLeft = timeLeft > 0
+ ? timeLeft
+ : 0;
+ if (translatedResponse) {
+ module.debug('Modified API response in onResponse callback', settings.onResponse, translatedResponse, response);
+ response = translatedResponse;
+ }
+ if (timeLeft > 0) {
+ module.debug('Response completed early delaying state change by', timeLeft);
+ }
+ setTimeout(function () {
+ if (module.is.validResponse(response)) {
+ module.request.resolveWith(context, [response, xhr]);
+ } else {
+ module.request.rejectWith(context, [xhr, 'invalid']);
+ }
+ }, timeLeft);
+ },
+ fail: function (xhr, status, httpMessage) {
+ var
+ context = this,
+ elapsedTime = Date.now() - requestStartTime,
+ timeLeft = settings.loadingDuration - elapsedTime
+ ;
+ timeLeft = timeLeft > 0
+ ? timeLeft
+ : 0;
+ if (timeLeft > 0) {
+ module.debug('Response completed early delaying state change by', timeLeft);
+ }
+ setTimeout(function () {
+ if (module.is.abortedRequest(xhr)) {
+ module.request.rejectWith(context, [xhr, 'aborted', httpMessage]);
+ } else {
+ module.request.rejectWith(context, [xhr, 'error', status, httpMessage]);
+ }
+ }, timeLeft);
+ },
+ },
+ request: {
+ done: function (response, xhr) {
+ module.debug('Successful API Response', response);
+ if (settings.cache === 'local' && url) {
+ module.write.cachedResponse(url, response);
+ module.debug('Saving server response locally', module.cache);
+ }
+ settings.onSuccess.call(context, response, $module, xhr);
+ },
+ complete: function (firstParameter, secondParameter) {
+ var
+ xhr,
+ response
+ ;
+ // have to guess callback parameters based on request success
+ if (module.was.successful()) {
+ response = firstParameter;
+ xhr = secondParameter;
+ } else {
+ xhr = firstParameter;
+ response = module.get.responseFromXHR(xhr);
+ }
+ module.remove.loading();
+ settings.onComplete.call(context, response, $module, xhr);
+ },
+ fail: function (xhr, status, httpMessage) {
+ var
+ // pull response from xhr if available
+ response = module.get.responseFromXHR(xhr),
+ errorMessage = module.get.errorFromRequest(response, status, httpMessage)
+ ;
+ if (status === 'aborted') {
+ module.debug('XHR Aborted (Most likely caused by page navigation or CORS Policy)', status, httpMessage);
+ settings.onAbort.call(context, status, $module, xhr);
+
+ return true;
+ }
+ if (status === 'invalid') {
+ module.debug('JSON did not pass success test. A server-side error has most likely occurred', response);
+ } else if (status === 'error') {
+ if (xhr !== undefined) {
+ module.debug('XHR produced a server error', status, httpMessage);
+ // make sure we have an error to display to console
+ if ((xhr.status < 200 || xhr.status >= 300) && httpMessage !== undefined && httpMessage !== '') {
+ module.error(error.statusMessage + httpMessage, ajaxSettings.url);
+ }
+ settings.onError.call(context, errorMessage, $module, xhr);
+ }
+ }
+
+ if (settings.errorDuration && status !== 'aborted') {
+ module.debug('Adding error state');
+ module.set.error();
+ if (module.should.removeError()) {
+ setTimeout(module.remove.error, settings.errorDuration);
+ }
+ }
+ module.debug('API Request failed', errorMessage, xhr);
+ settings.onFailure.call(context, response, $module, xhr);
+ },
+ },
+ },
+
+ create: {
+
+ request: function () {
+ // api request promise
+ return $.Deferred()
+ .always(module.event.request.complete)
+ .done(module.event.request.done)
+ .fail(module.event.request.fail)
+ ;
+ },
+
+ mockedXHR: function () {
+ var
+ // xhr does not simulate these properties of xhr but must return them
+ textStatus = false,
+ status = false,
+ httpMessage = false,
+ responder = settings.mockResponse || settings.response,
+ asyncResponder = settings.mockResponseAsync || settings.responseAsync,
+ asyncCallback,
+ response,
+ mockedXHR
+ ;
+
+ mockedXHR = $.Deferred()
+ .always(module.event.xhr.complete)
+ .done(module.event.xhr.done)
+ .fail(module.event.xhr.fail)
+ ;
+
+ if (responder) {
+ if (isFunction(responder)) {
+ module.debug('Using specified synchronous callback', responder);
+ response = responder.call(context, requestSettings);
+ } else {
+ module.debug('Using settings specified response', responder);
+ response = responder;
+ }
+ // simulating response
+ mockedXHR.resolveWith(context, [response, textStatus, { responseText: response }]);
+ } else if (isFunction(asyncResponder)) {
+ asyncCallback = function (response) {
+ module.debug('Async callback returned response', response);
+
+ if (response) {
+ mockedXHR.resolveWith(context, [response, textStatus, { responseText: response }]);
+ } else {
+ mockedXHR.rejectWith(context, [{ responseText: response }, status, httpMessage]);
+ }
+ };
+ module.debug('Using specified async response callback', asyncResponder);
+ asyncResponder.call(context, requestSettings, asyncCallback);
+ }
+
+ return mockedXHR;
+ },
+
+ xhr: function () {
+ var
+ xhr
+ ;
+ // ajax request promise
+ xhr = $.ajax(ajaxSettings)
+ .always(module.event.xhr.always)
+ .done(module.event.xhr.done)
+ .fail(module.event.xhr.fail)
+ ;
+ module.verbose('Created server request', xhr, ajaxSettings);
+
+ return xhr;
+ },
+ },
+
+ set: {
+ error: function () {
+ module.verbose('Adding error state to element', $context);
+ $context.addClass(className.error);
+ },
+ loading: function () {
+ module.verbose('Adding loading state to element', $context);
+ $context.addClass(className.loading);
+ requestStartTime = Date.now();
+ },
+ },
+
+ remove: {
+ error: function () {
+ module.verbose('Removing error state from element', $context);
+ $context.removeClass(className.error);
+ },
+ loading: function () {
+ module.verbose('Removing loading state from element', $context);
+ $context.removeClass(className.loading);
+ },
+ },
+
+ get: {
+ normalizedData: function () {
+ return typeof settings.data === 'string' ? settings.data : JSON.stringify(settings.data, Object.keys(settings.data).sort());
+ },
+ responseFromXHR: function (xhr) {
+ return $.isPlainObject(xhr)
+ ? (module.is.expectingJSON()
+ ? module.decode.json(xhr.responseText)
+ : xhr.responseText)
+ : false;
+ },
+ errorFromRequest: function (response, status, httpMessage) {
+ return $.isPlainObject(response) && response.error !== undefined
+ ? response.error // use json error message
+ : (settings.error[status] !== undefined // use server error message
+ ? settings.error[status]
+ : httpMessage);
+ },
+ request: function () {
+ return module.request || false;
+ },
+ xhr: function () {
+ return module.xhr || false;
+ },
+ settings: function () {
+ var
+ runSettings
+ ;
+ runSettings = settings.beforeSend.call($module, settings);
+ if (runSettings) {
+ if (runSettings.success !== undefined) {
+ module.debug('Legacy success callback detected', runSettings);
+ module.error(error.legacyParameters, runSettings.success);
+ runSettings.onSuccess = runSettings.success;
+ }
+ if (runSettings.failure !== undefined) {
+ module.debug('Legacy failure callback detected', runSettings);
+ module.error(error.legacyParameters, runSettings.failure);
+ runSettings.onFailure = runSettings.failure;
+ }
+ if (runSettings.complete !== undefined) {
+ module.debug('Legacy complete callback detected', runSettings);
+ module.error(error.legacyParameters, runSettings.complete);
+ runSettings.onComplete = runSettings.complete;
+ }
+ }
+ if (runSettings === undefined) {
+ module.error(error.noReturnedValue);
+ }
+ if (runSettings === false) {
+ return runSettings;
+ }
+
+ return runSettings !== undefined
+ ? $.extend(true, {}, runSettings)
+ : $.extend(true, {}, settings);
+ },
+ urlEncodedValue: function (value) {
+ var
+ decodedValue = window.decodeURIComponent(value),
+ encodedValue = window.encodeURIComponent(value),
+ alreadyEncoded = decodedValue !== value
+ ;
+ if (alreadyEncoded) {
+ module.debug('URL value is already encoded, avoiding double encoding', value);
+
+ return value;
+ }
+ module.verbose('Encoding value using encodeURIComponent', value, encodedValue);
+
+ return encodedValue;
+ },
+ defaultData: function () {
+ var
+ data = {}
+ ;
+ if (!isWindow(element)) {
+ if (module.is.input()) {
+ data.value = $module.val();
+ } else if (!module.is.form()) {
+ data.text = $module.text();
+ }
+ }
+
+ return data;
+ },
+ event: function () {
+ if (isWindow(element) || settings.on === 'now') {
+ module.debug('API called without element, no events attached');
+
+ return false;
+ }
+ if (settings.on === 'auto') {
+ if ($module.is('input')) {
+ return element.oninput !== undefined
+ ? 'input'
+ : (element.onpropertychange !== undefined
+ ? 'propertychange'
+ : 'keyup');
+ }
+ if ($module.is('form')) {
+ return 'submit';
+ }
+
+ return 'click';
+ }
+
+ return settings.on;
+ },
+ templatedURL: function (action) {
+ action = action || settings.action || $module.data(metadata.action) || false;
+ url = settings.url || $module.data(metadata.url) || false;
+ if (url) {
+ module.debug('Using specified url', url);
+
+ return url;
+ }
+ if (action) {
+ module.debug('Looking up url for action', action, settings.api);
+ if (settings.api[action] === undefined && !module.is.mocked()) {
+ module.error(error.missingAction, settings.action, settings.api);
+
+ return;
+ }
+ url = settings.api[action];
+ } else if (module.is.form()) {
+ url = $module.attr('action') || $context.attr('action') || false;
+ module.debug('No url or action specified, defaulting to form action', url);
+ }
+
+ return url;
+ },
+ },
+
+ abort: function () {
+ var
+ xhr = module.get.xhr()
;
- url = url.replace(templatedString, value);
- }
- });
- }
- if(optionalVariables) {
- module.debug('Looking for optional URL variables', requiredVariables);
- $.each(optionalVariables, function(index, templatedString) {
- var
- // allow legacy {/$var} style
- variable = (templatedString.indexOf('$') !== -1)
- ? templatedString.slice(3, -1)
- : templatedString.slice(2, -1),
- value = ($.isPlainObject(urlData) && urlData[variable] !== undefined)
- ? urlData[variable]
- : ($module.data(variable) !== undefined)
- ? $module.data(variable)
- : ($context.data(variable) !== undefined)
- ? $context.data(variable)
- : urlData[variable]
- ;
- // optional replacement
- if(value !== undefined) {
- module.verbose('Optional variable Found', variable, value);
- url = url.replace(templatedString, value);
- }
- else {
- module.verbose('Optional variable not found', variable);
- // remove preceding slash if set
- if(url.indexOf('/' + templatedString) !== -1) {
- url = url.replace('/' + templatedString, '');
+ if (xhr && xhr.state() !== 'resolved') {
+ module.debug('Cancelling API request');
+ xhr.abort();
}
- else {
- url = url.replace(templatedString, '');
+ },
+
+ // reset state
+ reset: function () {
+ module.remove.error();
+ module.remove.loading();
+ },
+
+ setting: function (name, value) {
+ module.debug('Changing setting', name, value);
+ if ($.isPlainObject(name)) {
+ $.extend(true, settings, name);
+ } else if (value !== undefined) {
+ if ($.isPlainObject(settings[name])) {
+ $.extend(true, settings[name], value);
+ } else {
+ settings[name] = value;
+ }
+ } else {
+ return settings[name];
+ }
+ },
+ internal: function (name, value) {
+ if ($.isPlainObject(name)) {
+ $.extend(true, module, name);
+ } else if (value !== undefined) {
+ module[name] = value;
+ } else {
+ return module[name];
+ }
+ },
+ debug: function () {
+ if (!settings.silent && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.debug.apply(console, arguments);
+ }
+ }
+ },
+ verbose: function () {
+ if (!settings.silent && settings.verbose && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.verbose.apply(console, arguments);
+ }
+ }
+ },
+ error: function () {
+ if (!settings.silent) {
+ module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
+ module.error.apply(console, arguments);
+ }
+ },
+ performance: {
+ log: function (message) {
+ var
+ currentTime,
+ executionTime,
+ previousTime
+ ;
+ if (settings.performance) {
+ currentTime = Date.now();
+ previousTime = time || currentTime;
+ executionTime = currentTime - previousTime;
+ time = currentTime;
+ performance.push({
+ Name: message[0],
+ Arguments: [].slice.call(message, 1) || '',
+ // 'Element' : element,
+ 'Execution Time': executionTime,
+ });
+ }
+ clearTimeout(module.performance.timer);
+ module.performance.timer = setTimeout(module.performance.display, 500);
+ },
+ display: function () {
+ var
+ title = settings.name + ':',
+ totalTime = 0
+ ;
+ time = false;
+ clearTimeout(module.performance.timer);
+ $.each(performance, function (index, data) {
+ totalTime += data['Execution Time'];
+ });
+ title += ' ' + totalTime + 'ms';
+ if (moduleSelector) {
+ title += ' \'' + moduleSelector + '\'';
+ }
+ if (performance.length > 0) {
+ console.groupCollapsed(title);
+ if (console.table) {
+ console.table(performance);
+ } else {
+ $.each(performance, function (index, data) {
+ console.log(data.Name + ': ' + data['Execution Time'] + 'ms');
+ });
+ }
+ console.groupEnd();
+ }
+ performance = [];
+ },
+ },
+ invoke: function (query, passedArguments, context) {
+ var
+ object = instance,
+ maxDepth,
+ found,
+ response
+ ;
+ passedArguments = passedArguments || queryArguments;
+ context = context || element;
+ if (typeof query === 'string' && object !== undefined) {
+ query = query.split(/[ .]/);
+ maxDepth = query.length - 1;
+ $.each(query, function (depth, value) {
+ var camelCaseValue = depth !== maxDepth
+ ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
+ : query
+ ;
+ if ($.isPlainObject(object[camelCaseValue]) && (depth !== maxDepth)) {
+ object = object[camelCaseValue];
+ } else if (object[camelCaseValue] !== undefined) {
+ found = object[camelCaseValue];
+
+ return false;
+ } else if ($.isPlainObject(object[value]) && (depth !== maxDepth)) {
+ object = object[value];
+ } else if (object[value] !== undefined) {
+ found = object[value];
+
+ return false;
+ } else {
+ module.error(error.method, query);
+
+ return false;
+ }
+ });
+ }
+ if (isFunction(found)) {
+ response = found.apply(context, passedArguments);
+ } else if (found !== undefined) {
+ response = found;
+ }
+ if (Array.isArray(returnedValue)) {
+ returnedValue.push(response);
+ } else if (returnedValue !== undefined) {
+ returnedValue = [returnedValue, response];
+ } else if (response !== undefined) {
+ returnedValue = response;
}
- }
- });
- }
- }
- return url;
- },
- formData: function(data) {
- var
- formData = {},
- hasOtherData,
- useFormDataApi = settings.serializeForm === 'formdata'
- ;
- data = data || originalData || settings.data;
- hasOtherData = $.isPlainObject(data);
- if (useFormDataApi) {
- formData = new FormData($form[0]);
- settings.processData = typeof settings.processData !== 'undefined' ? settings.processData : false;
- settings.contentType = typeof settings.contentType !== 'undefined' ? settings.contentType : false;
- } else {
- var formArray = $form.serializeArray(),
- pushes = {},
- pushValues= {},
- build = function(base, key, value) {
- base[key] = value;
- return base;
- }
- ;
- // add files
- $.each($('input[type="file"]',$form), function(i, tag) {
- $.each($(tag)[0].files, function(j, file) {
- formArray.push({name:tag.name, value: file});
- });
- });
- $.each(formArray, function(i, el) {
- if (!settings.regExp.validate.test(el.name)) return;
- var isCheckbox = $('[name="' + el.name + '"]', $form).attr('type') === 'checkbox',
- floatValue = parseFloat(el.value),
- value = (isCheckbox && el.value === 'on') || el.value === 'true' || (String(floatValue) === el.value ? floatValue : (el.value === 'false' ? false : el.value)),
- nameKeys = el.name.match(settings.regExp.key) || [], k, pushKey= el.name.replace(/\[\]$/,'')
- ;
- if(!(pushKey in pushes)) {
- pushes[pushKey] = 0;
- pushValues[pushKey] = value;
- } else if (Array.isArray(pushValues[pushKey])) {
- pushValues[pushKey].push(value);
- } else {
- pushValues[pushKey] = [pushValues[pushKey] , value];
+ return found;
+ },
+ };
+
+ if (methodInvoked) {
+ if (instance === undefined) {
+ module.initialize();
}
- value = pushValues[pushKey];
-
- while ((k = nameKeys.pop()) !== undefined) {
- // foo[]
- if (k == '' && !Array.isArray(value)){
- value = build([], pushes[pushKey]++, value);
- }
- // foo[n]
- else if (settings.regExp.fixed.test(k)) {
- value = build([], k, value);
- }
- // foo; foo[bar]
- else if (settings.regExp.named.test(k)) {
- value = build({}, k, value);
- }
+ module.invoke(query);
+ } else {
+ if (instance !== undefined) {
+ instance.invoke('destroy');
}
- formData = $.extend(true, formData, value);
- });
+ module.initialize();
}
+ });
- if(hasOtherData) {
- module.debug('Extending existing data with form data', data, formData);
- if(useFormDataApi) {
- $.each(Object.keys(data),function(i, el){
- formData.append(el, data[el]);
- });
- data = formData;
- } else {
- data = $.extend(true, {}, data, formData);
- }
- }
- else {
- module.debug('Adding form data', formData);
- data = formData;
- }
- return data;
- }
- },
+ return returnedValue !== undefined
+ ? returnedValue
+ : this;
+ };
+ $.api = $.fn.api;
- send: {
- request: function() {
- module.set.loading();
- module.request = module.create.request();
- if( module.is.mocked() ) {
- module.mockedXHR = module.create.mockedXHR();
- }
- else {
- module.xhr = module.create.xhr();
- }
- settings.onRequest.call(context, module.request, module.xhr);
- }
- },
+ $.api.settings = {
- event: {
- trigger: function(event) {
- module.query();
- if(event.type == 'submit' || event.type == 'click') {
- event.preventDefault();
- }
- },
- xhr: {
- always: function() {
- // nothing special
- },
- done: function(response, textStatus, xhr) {
- var
- context = this,
- elapsedTime = (new Date().getTime() - requestStartTime),
- timeLeft = (settings.loadingDuration - elapsedTime),
- translatedResponse = ( $.isFunction(settings.onResponse) )
- ? module.is.expectingJSON() && !settings.rawResponse
- ? settings.onResponse.call(context, $.extend(true, {}, response))
- : settings.onResponse.call(context, response)
- : false
- ;
- timeLeft = (timeLeft > 0)
- ? timeLeft
- : 0
- ;
- if(translatedResponse) {
- module.debug('Modified API response in onResponse callback', settings.onResponse, translatedResponse, response);
- response = translatedResponse;
- }
- if(timeLeft > 0) {
- module.debug('Response completed early delaying state change by', timeLeft);
- }
- setTimeout(function() {
- if( module.is.validResponse(response) ) {
- module.request.resolveWith(context, [response, xhr]);
- }
- else {
- module.request.rejectWith(context, [xhr, 'invalid']);
- }
- }, timeLeft);
- },
- fail: function(xhr, status, httpMessage) {
- var
- context = this,
- elapsedTime = (new Date().getTime() - requestStartTime),
- timeLeft = (settings.loadingDuration - elapsedTime)
- ;
- timeLeft = (timeLeft > 0)
- ? timeLeft
- : 0
- ;
- if(timeLeft > 0) {
- module.debug('Response completed early delaying state change by', timeLeft);
- }
- setTimeout(function() {
- if( module.is.abortedRequest(xhr) ) {
- module.request.rejectWith(context, [xhr, 'aborted', httpMessage]);
- }
- else {
- module.request.rejectWith(context, [xhr, 'error', status, httpMessage]);
- }
- }, timeLeft);
- }
- },
- request: {
- done: function(response, xhr) {
- module.debug('Successful API Response', response);
- if(settings.cache === 'local' && url) {
- module.write.cachedResponse(url, response);
- module.debug('Saving server response locally', module.cache);
- }
- settings.onSuccess.call(context, response, $module, xhr);
- },
- complete: function(firstParameter, secondParameter) {
- var
- xhr,
- response
- ;
- // have to guess callback parameters based on request success
- if( module.was.successful() ) {
- response = firstParameter;
- xhr = secondParameter;
- }
- else {
- xhr = firstParameter;
- response = module.get.responseFromXHR(xhr);
- }
- module.remove.loading();
- settings.onComplete.call(context, response, $module, xhr);
- },
- fail: function(xhr, status, httpMessage) {
- var
- // pull response from xhr if available
- response = module.get.responseFromXHR(xhr),
- errorMessage = module.get.errorFromRequest(response, status, httpMessage)
- ;
- if(status == 'aborted') {
- module.debug('XHR Aborted (Most likely caused by page navigation or CORS Policy)', status, httpMessage);
- settings.onAbort.call(context, status, $module, xhr);
- return true;
- }
- else if(status == 'invalid') {
- module.debug('JSON did not pass success test. A server-side error has most likely occurred', response);
- }
- else if(status == 'error') {
- if(xhr !== undefined) {
- module.debug('XHR produced a server error', status, httpMessage);
- // make sure we have an error to display to console
- if( (xhr.status < 200 || xhr.status >= 300) && httpMessage !== undefined && httpMessage !== '') {
- module.error(error.statusMessage + httpMessage, ajaxSettings.url);
- }
- settings.onError.call(context, errorMessage, $module, xhr);
- }
- }
+ name: 'API',
+ namespace: 'api',
- if(settings.errorDuration && status !== 'aborted') {
- module.debug('Adding error state');
- module.set.error();
- if( module.should.removeError() ) {
- setTimeout(module.remove.error, settings.errorDuration);
- }
- }
- module.debug('API Request failed', errorMessage, xhr);
- settings.onFailure.call(context, response, $module, xhr);
- }
- }
- },
+ debug: false,
+ verbose: false,
+ performance: true,
- create: {
+ // object containing all templates endpoints
+ api: {},
- request: function() {
- // api request promise
- return $.Deferred()
- .always(module.event.request.complete)
- .done(module.event.request.done)
- .fail(module.event.request.fail)
- ;
- },
+ // whether to cache responses
+ cache: true,
- mockedXHR: function () {
- var
- // xhr does not simulate these properties of xhr but must return them
- textStatus = false,
- status = false,
- httpMessage = false,
- responder = settings.mockResponse || settings.response,
- asyncResponder = settings.mockResponseAsync || settings.responseAsync,
- asyncCallback,
- response,
- mockedXHR
- ;
+ // whether new requests should abort previous requests
+ interruptRequests: true,
- mockedXHR = $.Deferred()
- .always(module.event.xhr.complete)
- .done(module.event.xhr.done)
- .fail(module.event.xhr.fail)
- ;
+ // event binding
+ on: 'auto',
- if(responder) {
- if( $.isFunction(responder) ) {
- module.debug('Using specified synchronous callback', responder);
- response = responder.call(context, requestSettings);
- }
- else {
- module.debug('Using settings specified response', responder);
- response = responder;
- }
- // simulating response
- mockedXHR.resolveWith(context, [ response, textStatus, { responseText: response }]);
- }
- else if( $.isFunction(asyncResponder) ) {
- asyncCallback = function(response) {
- module.debug('Async callback returned response', response);
+ // context for applying state classes
+ stateContext: false,
- if(response) {
- mockedXHR.resolveWith(context, [ response, textStatus, { responseText: response }]);
- }
- else {
- mockedXHR.rejectWith(context, [{ responseText: response }, status, httpMessage]);
- }
- };
- module.debug('Using specified async response callback', asyncResponder);
- asyncResponder.call(context, requestSettings, asyncCallback);
- }
- return mockedXHR;
- },
+ // duration for loading state
+ loadingDuration: 0,
- xhr: function() {
- var
- xhr
- ;
- // ajax request promise
- xhr = $.ajax(ajaxSettings)
- .always(module.event.xhr.always)
- .done(module.event.xhr.done)
- .fail(module.event.xhr.fail)
- ;
- module.verbose('Created server request', xhr, ajaxSettings);
- return xhr;
- }
- },
+ // whether to hide errors after a period of time
+ hideError: 'auto',
- set: {
- error: function() {
- module.verbose('Adding error state to element', $context);
- $context.addClass(className.error);
- },
- loading: function() {
- module.verbose('Adding loading state to element', $context);
- $context.addClass(className.loading);
- requestStartTime = new Date().getTime();
- }
- },
+ // duration for error state
+ errorDuration: 2000,
- remove: {
- error: function() {
- module.verbose('Removing error state from element', $context);
- $context.removeClass(className.error);
- },
- loading: function() {
- module.verbose('Removing loading state from element', $context);
- $context.removeClass(className.loading);
- }
- },
+ // whether parameters should be encoded with encodeURIComponent
+ encodeParameters: true,
- get: {
- normalizedData: function(){
- return typeof settings.data === "string" ? settings.data : JSON.stringify(settings.data, Object.keys(settings.data).sort());
- },
- responseFromXHR: function(xhr) {
- return $.isPlainObject(xhr)
- ? (module.is.expectingJSON())
- ? module.decode.json(xhr.responseText)
- : xhr.responseText
- : false
- ;
- },
- errorFromRequest: function(response, status, httpMessage) {
- return ($.isPlainObject(response) && response.error !== undefined)
- ? response.error // use json error message
- : (settings.error[status] !== undefined) // use server error message
- ? settings.error[status]
- : httpMessage
- ;
- },
- request: function() {
- return module.request || false;
- },
- xhr: function() {
- return module.xhr || false;
- },
- settings: function() {
- var
- runSettings
- ;
- runSettings = settings.beforeSend.call($module, settings);
- if(runSettings) {
- if(runSettings.success !== undefined) {
- module.debug('Legacy success callback detected', runSettings);
- module.error(error.legacyParameters, runSettings.success);
- runSettings.onSuccess = runSettings.success;
- }
- if(runSettings.failure !== undefined) {
- module.debug('Legacy failure callback detected', runSettings);
- module.error(error.legacyParameters, runSettings.failure);
- runSettings.onFailure = runSettings.failure;
- }
- if(runSettings.complete !== undefined) {
- module.debug('Legacy complete callback detected', runSettings);
- module.error(error.legacyParameters, runSettings.complete);
- runSettings.onComplete = runSettings.complete;
- }
- }
- if(runSettings === undefined) {
- module.error(error.noReturnedValue);
- }
- if(runSettings === false) {
- return runSettings;
- }
- return (runSettings !== undefined)
- ? $.extend(true, {}, runSettings)
- : $.extend(true, {}, settings)
- ;
- },
- urlEncodedValue: function(value) {
- var
- decodedValue = window.decodeURIComponent(value),
- encodedValue = window.encodeURIComponent(value),
- alreadyEncoded = (decodedValue !== value)
- ;
- if(alreadyEncoded) {
- module.debug('URL value is already encoded, avoiding double encoding', value);
- return value;
- }
- module.verbose('Encoding value using encodeURIComponent', value, encodedValue);
- return encodedValue;
- },
- defaultData: function() {
- var
- data = {}
- ;
- if( !$.isWindow(element) ) {
- if( module.is.input() ) {
- data.value = $module.val();
- }
- else if( module.is.form() ) {
-
- }
- else {
- data.text = $module.text();
- }
- }
- return data;
- },
- event: function() {
- if( $.isWindow(element) || settings.on == 'now' ) {
- module.debug('API called without element, no events attached');
- return false;
- }
- else if(settings.on == 'auto') {
- if( $module.is('input') ) {
- return (element.oninput !== undefined)
- ? 'input'
- : (element.onpropertychange !== undefined)
- ? 'propertychange'
- : 'keyup'
- ;
- }
- else if( $module.is('form') ) {
- return 'submit';
- }
- else {
- return 'click';
- }
- }
- else {
- return settings.on;
- }
- },
- templatedURL: function(action) {
- action = action || $module.data(metadata.action) || settings.action || false;
- url = $module.data(metadata.url) || settings.url || false;
- if(url) {
- module.debug('Using specified url', url);
- return url;
- }
- if(action) {
- module.debug('Looking up url for action', action, settings.api);
- if(settings.api[action] === undefined && !module.is.mocked()) {
- module.error(error.missingAction, settings.action, settings.api);
- return;
- }
- url = settings.api[action];
- }
- else if( module.is.form() ) {
- url = $module.attr('action') || $context.attr('action') || false;
- module.debug('No url or action specified, defaulting to form action', url);
- }
- return url;
- }
- },
+ // API action to use
+ action: false,
- abort: function() {
- var
- xhr = module.get.xhr()
- ;
- if( xhr && xhr.state() !== 'resolved') {
- module.debug('Cancelling API request');
- xhr.abort();
- }
- },
+ // templated URL to use
+ url: false,
- // reset state
- reset: function() {
- module.remove.error();
- module.remove.loading();
- },
+ // base URL to apply to all endpoints
+ base: '',
- setting: function(name, value) {
- module.debug('Changing setting', name, value);
- if( $.isPlainObject(name) ) {
- $.extend(true, settings, name);
- }
- else if(value !== undefined) {
- if($.isPlainObject(settings[name])) {
- $.extend(true, settings[name], value);
- }
- else {
- settings[name] = value;
- }
- }
- else {
- return settings[name];
- }
- },
- internal: function(name, value) {
- if( $.isPlainObject(name) ) {
- $.extend(true, module, name);
- }
- else if(value !== undefined) {
- module[name] = value;
- }
- else {
- return module[name];
- }
- },
- debug: function() {
- if(!settings.silent && settings.debug) {
- if(settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.debug.apply(console, arguments);
- }
- }
- },
- verbose: function() {
- if(!settings.silent && settings.verbose && settings.debug) {
- if(settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.verbose.apply(console, arguments);
- }
- }
- },
- error: function() {
- if(!settings.silent) {
- module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
- module.error.apply(console, arguments);
- }
- },
- performance: {
- log: function(message) {
- var
- currentTime,
- executionTime,
- previousTime
- ;
- if(settings.performance) {
- currentTime = new Date().getTime();
- previousTime = time || currentTime;
- executionTime = currentTime - previousTime;
- time = currentTime;
- performance.push({
- 'Name' : message[0],
- 'Arguments' : [].slice.call(message, 1) || '',
- //'Element' : element,
- 'Execution Time' : executionTime
- });
- }
- clearTimeout(module.performance.timer);
- module.performance.timer = setTimeout(module.performance.display, 500);
- },
- display: function() {
- var
- title = settings.name + ':',
- totalTime = 0
- ;
- time = false;
- clearTimeout(module.performance.timer);
- $.each(performance, function(index, data) {
- totalTime += data['Execution Time'];
- });
- title += ' ' + totalTime + 'ms';
- if(moduleSelector) {
- title += ' \'' + moduleSelector + '\'';
- }
- if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) {
- console.groupCollapsed(title);
- if(console.table) {
- console.table(performance);
- }
- else {
- $.each(performance, function(index, data) {
- console.log(data['Name'] + ': ' + data['Execution Time']+'ms');
- });
- }
- console.groupEnd();
- }
- performance = [];
- }
- },
- invoke: function(query, passedArguments, context) {
- var
- object = instance,
- maxDepth,
- found,
- response
- ;
- passedArguments = passedArguments || queryArguments;
- context = context || element;
- if(typeof query == 'string' && object !== undefined) {
- query = query.split(/[\. ]/);
- maxDepth = query.length - 1;
- $.each(query, function(depth, value) {
- var camelCaseValue = (depth != maxDepth)
- ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
- : query
- ;
- if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) {
- object = object[camelCaseValue];
- }
- else if( object[camelCaseValue] !== undefined ) {
- found = object[camelCaseValue];
- return false;
- }
- else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) {
- object = object[value];
- }
- else if( object[value] !== undefined ) {
- found = object[value];
- return false;
- }
- else {
- module.error(error.method, query);
- return false;
- }
- });
- }
- if ( $.isFunction( found ) ) {
- response = found.apply(context, passedArguments);
- }
- else if(found !== undefined) {
- response = found;
- }
- if(Array.isArray(returnedValue)) {
- returnedValue.push(response);
- }
- else if(returnedValue !== undefined) {
- returnedValue = [returnedValue, response];
- }
- else if(response !== undefined) {
- returnedValue = response;
- }
- return found;
- }
- };
-
- if(methodInvoked) {
- if(instance === undefined) {
- module.initialize();
- }
- module.invoke(query);
- }
- else {
- if(instance !== undefined) {
- instance.invoke('destroy');
- }
- module.initialize();
- }
- })
- ;
-
- return (returnedValue !== undefined)
- ? returnedValue
- : this
- ;
-};
-
-$.api.settings = {
-
- name : 'API',
- namespace : 'api',
-
- debug : false,
- verbose : false,
- performance : true,
-
- // object containing all templates endpoints
- api : {},
-
- // whether to cache responses
- cache : true,
-
- // whether new requests should abort previous requests
- interruptRequests : true,
-
- // event binding
- on : 'auto',
-
- // context for applying state classes
- stateContext : false,
-
- // duration for loading state
- loadingDuration : 0,
-
- // whether to hide errors after a period of time
- hideError : 'auto',
-
- // duration for error state
- errorDuration : 2000,
-
- // whether parameters should be encoded with encodeURIComponent
- encodeParameters : true,
-
- // API action to use
- action : false,
-
- // templated URL to use
- url : false,
-
- // base URL to apply to all endpoints
- base : '',
-
- // data that will
- urlData : {},
-
- // whether to add default data to url data
- defaultData : true,
-
- // whether to serialize closest form
- // use true to convert complex named keys like a[b][1][c][] into a nested object
- // use 'formdata' for formdata web api
- serializeForm : false,
-
- // how long to wait before request should occur
- throttle : 0,
-
- // whether to throttle first request or only repeated
- throttleFirstRequest : true,
-
- // standard ajax settings
- method : 'get',
- data : {},
- dataType : 'json',
-
- // mock response
- mockResponse : false,
- mockResponseAsync : false,
-
- // aliases for mock
- response : false,
- responseAsync : false,
-
-// whether onResponse should work with response value without force converting into an object
- rawResponse : true,
-
- // callbacks before request
- beforeSend : function(settings) { return settings; },
- beforeXHR : function(xhr) {},
- onRequest : function(promise, xhr) {},
-
- // after request
- onResponse : false, // function(response) { },
+ // data that will
+ urlData: {},
- // response was successful, if JSON passed validation
- onSuccess : function(response, $module) {},
+ // whether to add default data to url data
+ defaultData: true,
- // request finished without aborting
- onComplete : function(response, $module) {},
+ // whether to serialize closest form
+ // use true to convert complex named keys like a[b][1][c][] into a nested object
+ // use 'formdata' for formdata web api
+ serializeForm: false,
- // failed JSON success test
- onFailure : function(response, $module) {},
+ // how long to wait before request should occur
+ throttle: 0,
- // server error
- onError : function(errorMessage, $module) {},
+ // whether to throttle first request or only repeated
+ throttleFirstRequest: true,
- // request aborted
- onAbort : function(errorMessage, $module) {},
+ // standard ajax settings
+ method: 'get',
+ data: {},
+ dataType: 'json',
- successTest : false,
+ // mock response
+ mockResponse: false,
+ mockResponseAsync: false,
- // errors
- error : {
- beforeSend : 'The before send function has aborted the request',
- error : 'There was an error with your request',
- exitConditions : 'API Request Aborted. Exit conditions met',
- JSONParse : 'JSON could not be parsed during error handling',
- legacyParameters : 'You are using legacy API success callback names',
- method : 'The method you called is not defined',
- missingAction : 'API action used but no url was defined',
- missingURL : 'No URL specified for api event',
- noReturnedValue : 'The beforeSend callback must return a settings object, beforeSend ignored.',
- noStorage : 'Caching responses locally requires session storage',
- parseError : 'There was an error parsing your request',
- requiredParameter : 'Missing a required URL parameter: ',
- statusMessage : 'Server gave an error: ',
- timeout : 'Your request timed out'
- },
+ // aliases for mock
+ response: false,
+ responseAsync: false,
- regExp : {
- required : /\{\$*[a-z0-9]+\}/gi,
- optional : /\{\/\$*[a-z0-9]+\}/gi,
- validate: /^[a-z_][a-z0-9_-]*(?:\[[a-z0-9_-]*\])*$/i,
- key: /[a-z0-9_-]+|(?=\[\])/gi,
- push: /^$/,
- fixed: /^\d+$/,
- named: /^[a-z0-9_-]+$/i
- },
-
- className: {
- loading : 'loading',
- error : 'error'
- },
+ // whether onResponse should work with response value without force converting into an object
+ rawResponse: true,
- selector: {
- disabled : '.disabled',
- form : 'form'
- },
-
- metadata: {
- action : 'action',
- url : 'url'
- }
-};
-
-
-
-})( jQuery, window, document );
+ // callbacks before request
+ beforeSend: function (settings) {
+ return settings;
+ },
+ beforeXHR: function (xhr) {},
+ onRequest: function (promise, xhr) {},
+
+ // after request
+ onResponse: false, // function(response) { },
+
+ // response was successful, if JSON passed validation
+ onSuccess: function (response, $module) {},
+
+ // request finished without aborting
+ onComplete: function (response, $module) {},
+
+ // failed JSON success test
+ onFailure: function (response, $module) {},
+
+ // server error
+ onError: function (errorMessage, $module) {},
+
+ // request aborted
+ onAbort: function (errorMessage, $module) {},
+
+ successTest: false,
+
+ // errors
+ error: {
+ beforeSend: 'The before send function has aborted the request',
+ error: 'There was an error with your request',
+ exitConditions: 'API Request Aborted. Exit conditions met',
+ JSONParse: 'JSON could not be parsed during error handling',
+ legacyParameters: 'You are using legacy API success callback names',
+ method: 'The method you called is not defined',
+ missingAction: 'API action used but no url was defined',
+ missingURL: 'No URL specified for api event',
+ noReturnedValue: 'The beforeSend callback must return a settings object, beforeSend ignored.',
+ noStorage: 'Caching responses locally requires session storage',
+ parseError: 'There was an error parsing your request',
+ requiredParameter: 'Missing a required URL parameter: ',
+ statusMessage: 'Server gave an error: ',
+ timeout: 'Your request timed out',
+ },
+
+ regExp: {
+ required: /{\$*[\da-z]+}/gi,
+ optional: /{\/\$*[\da-z]+}/gi,
+ validate: /^[_a-z][\w-]*(?:\[[\w-]*])*$/i,
+ key: /[\w-]+|(?=\[])/gi,
+ push: /^$/,
+ fixed: /^\d+$/,
+ named: /^[\w-]+$/i,
+ },
+
+ className: {
+ loading: 'loading',
+ error: 'error',
+ },
+
+ selector: {
+ disabled: '.disabled',
+ form: 'form',
+ },
+
+ metadata: {
+ action: 'action',
+ url: 'url',
+ },
+ };
+})(jQuery, window, document);
diff --git a/definitions/behaviors/form.js b/definitions/behaviors/form.js
index 3d2ff00..d459681 100644
--- a/definitions/behaviors/form.js
+++ b/definitions/behaviors/form.js
@@ -1,2077 +1,2095 @@
/*!
* # Fomantic-UI - Form Validation
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-;(function ($, window, document, undefined) {
-
-'use strict';
-
-$.isFunction = $.isFunction || function(obj) {
- return typeof obj === "function" && typeof obj.nodeType !== "number";
-};
-
-window = (typeof window != 'undefined' && window.Math == Math)
- ? window
- : (typeof self != 'undefined' && self.Math == Math)
- ? self
- : Function('return this')()
-;
-
-$.fn.form = function(parameters) {
- var
- $allModules = $(this),
- moduleSelector = $allModules.selector || '',
-
- time = new Date().getTime(),
- performance = [],
-
- query = arguments[0],
- legacyParameters = arguments[1],
- methodInvoked = (typeof query == 'string'),
- queryArguments = [].slice.call(arguments, 1),
- returnedValue
- ;
- $allModules
- .each(function() {
- var
- $module = $(this),
- element = this,
-
- formErrors = [],
- keyHeldDown = false,
-
- // set at run-time
- $field,
- $group,
- $message,
- $prompt,
- $submit,
- $clear,
- $reset,
-
- settings,
- validation,
-
- metadata,
- selector,
- className,
- regExp,
- error,
-
- namespace,
- moduleNamespace,
- eventNamespace,
-
- submitting = false,
- dirty = false,
- history = ['clean', 'clean'],
-
- instance,
- module
- ;
-
- module = {
-
- initialize: function() {
-
- // settings grabbed at run time
- module.get.settings();
- if(methodInvoked) {
- if(instance === undefined) {
- module.instantiate();
- }
- module.invoke(query);
- }
- else {
- if(instance !== undefined) {
- instance.invoke('destroy');
- module.refresh();
- }
- module.verbose('Initializing form validation', $module, settings);
- module.bindEvents();
- module.set.defaults();
- if (settings.autoCheckRequired) {
- module.set.autoCheck();
- }
- module.instantiate();
- }
- },
+(function ($, window, document) {
+ 'use strict';
- instantiate: function() {
- module.verbose('Storing instance of module', module);
- instance = module;
- $module
- .data(moduleNamespace, module)
- ;
- },
+ function isFunction(obj) {
+ return typeof obj === 'function' && typeof obj.nodeType !== 'number';
+ }
- destroy: function() {
- module.verbose('Destroying previous module', instance);
- module.removeEvents();
- $module
- .removeData(moduleNamespace)
- ;
- },
+ window = window !== undefined && window.Math === Math
+ ? window
+ : globalThis;
- refresh: function() {
- module.verbose('Refreshing selector cache');
- $field = $module.find(selector.field);
- $group = $module.find(selector.group);
- $message = $module.find(selector.message);
- $prompt = $module.find(selector.prompt);
+ $.fn.form = function (parameters) {
+ var
+ $allModules = $(this),
+ moduleSelector = $allModules.selector || '',
- $submit = $module.find(selector.submit);
- $clear = $module.find(selector.clear);
- $reset = $module.find(selector.reset);
- },
+ time = Date.now(),
+ performance = [],
- refreshEvents: function() {
- module.removeEvents();
- module.bindEvents();
- },
+ query = arguments[0],
+ methodInvoked = typeof query === 'string',
+ queryArguments = [].slice.call(arguments, 1),
+ returnedValue
+ ;
+ $allModules.each(function () {
+ var
+ $module = $(this),
+ element = this,
+
+ formErrors = [],
+ keyHeldDown = false,
+
+ // set at run-time
+ $field,
+ $group,
+ $message,
+ $prompt,
+ $submit,
+ $clear,
+ $reset,
+
+ settings,
+ validation,
+
+ metadata,
+ selector,
+ className,
+ regExp,
+ error,
+
+ namespace,
+ moduleNamespace,
+ eventNamespace,
+
+ submitting = false,
+ dirty = false,
+ history = ['clean', 'clean'],
+
+ instance,
+ module
+ ;
- submit: function() {
- module.verbose('Submitting form', $module);
- submitting = true;
- $module.submit();
- },
+ module = {
- attachEvents: function(selector, action) {
- action = action || 'submit';
- $(selector).on('click' + eventNamespace, function(event) {
- module[action]();
- event.preventDefault();
- });
- },
+ initialize: function () {
+ // settings grabbed at run time
+ module.get.settings();
+ if (methodInvoked) {
+ if (instance === undefined) {
+ module.instantiate();
+ }
+ module.invoke(query);
+ } else {
+ if (instance !== undefined) {
+ instance.invoke('destroy');
+ module.refresh();
+ }
+ module.verbose('Initializing form validation', $module, settings);
+ module.bindEvents();
+ module.set.defaults();
+ if (settings.autoCheckRequired) {
+ module.set.autoCheck();
+ }
+ module.instantiate();
+ }
+ },
+
+ instantiate: function () {
+ module.verbose('Storing instance of module', module);
+ instance = module;
+ $module
+ .data(moduleNamespace, module)
+ ;
+ },
+
+ destroy: function () {
+ module.verbose('Destroying previous module', instance);
+ module.removeEvents();
+ $module
+ .removeData(moduleNamespace)
+ ;
+ },
+
+ refresh: function () {
+ module.verbose('Refreshing selector cache');
+ $field = $module.find(selector.field);
+ $group = $module.find(selector.group);
+ $message = $module.find(selector.message);
+ $prompt = $module.find(selector.prompt);
+
+ $submit = $module.find(selector.submit);
+ $clear = $module.find(selector.clear);
+ $reset = $module.find(selector.reset);
+ },
+
+ refreshEvents: function () {
+ module.removeEvents();
+ module.bindEvents();
+ },
+
+ submit: function () {
+ module.verbose('Submitting form', $module);
+ submitting = true;
+ $module.trigger('submit');
+ },
+
+ attachEvents: function (selector, action) {
+ if (!action) {
+ action = 'submit';
+ }
- bindEvents: function() {
- module.verbose('Attaching form events');
- $module
- .on('submit' + eventNamespace, module.validate.form)
- .on('blur' + eventNamespace, selector.field, module.event.field.blur)
- .on('click' + eventNamespace, selector.submit, module.submit)
- .on('click' + eventNamespace, selector.reset, module.reset)
- .on('click' + eventNamespace, selector.clear, module.clear)
- ;
- if(settings.keyboardShortcuts) {
- $module.on('keydown' + eventNamespace, selector.field, module.event.field.keydown);
- }
- $field.each(function(index, el) {
- var
- $input = $(el),
- type = $input.prop('type'),
- inputEvent = module.get.changeEvent(type, $input)
- ;
- $input.on(inputEvent + eventNamespace, module.event.field.change);
- });
+ $(selector).on('click' + eventNamespace, function (event) {
+ module[action]();
+ event.preventDefault();
+ });
+ },
+
+ bindEvents: function () {
+ module.verbose('Attaching form events');
+ $module
+ .on('submit' + eventNamespace, module.validate.form)
+ .on('blur' + eventNamespace, selector.field, module.event.field.blur)
+ .on('click' + eventNamespace, selector.submit, module.submit)
+ .on('click' + eventNamespace, selector.reset, module.reset)
+ .on('click' + eventNamespace, selector.clear, module.clear)
+ ;
+ if (settings.keyboardShortcuts) {
+ $module.on('keydown' + eventNamespace, selector.field, module.event.field.keydown);
+ }
+ $field.each(function (index, el) {
+ var
+ $input = $(el),
+ type = $input.prop('type'),
+ inputEvent = module.get.changeEvent(type, $input)
+ ;
+ $input.on(inputEvent + eventNamespace, module.event.field.change);
+ });
+
+ // Dirty events
+ if (settings.preventLeaving) {
+ $(window).on('beforeunload' + eventNamespace, module.event.beforeUnload);
+ }
+
+ $field.on('change click keyup keydown blur', function (e) {
+ module.determine.isDirty();
+ });
+
+ $module.on('dirty' + eventNamespace, function (e) {
+ settings.onDirty.call();
+ });
+
+ $module.on('clean' + eventNamespace, function (e) {
+ settings.onClean.call();
+ });
+ },
+
+ clear: function () {
+ $field.each(function (index, el) {
+ var
+ $field = $(el),
+ $element = $field.parent(),
+ $fieldGroup = $field.closest($group),
+ $prompt = $fieldGroup.find(selector.prompt),
+ $calendar = $field.closest(selector.uiCalendar),
+ defaultValue = $field.data(metadata.defaultValue) || '',
+ isCheckbox = $element.is(selector.uiCheckbox),
+ isDropdown = $element.is(selector.uiDropdown) && module.can.useElement('dropdown'),
+ isCalendar = $calendar.length > 0 && module.can.useElement('calendar'),
+ isErrored = $fieldGroup.hasClass(className.error)
+ ;
+ if (isErrored) {
+ module.verbose('Resetting error on field', $fieldGroup);
+ $fieldGroup.removeClass(className.error);
+ $prompt.remove();
+ }
+ if (isDropdown) {
+ module.verbose('Resetting dropdown value', $element, defaultValue);
+ $element.dropdown('clear', true);
+ } else if (isCheckbox) {
+ $field.prop('checked', false);
+ } else if (isCalendar) {
+ $calendar.calendar('clear');
+ } else {
+ module.verbose('Resetting field value', $field, defaultValue);
+ $field.val('');
+ }
+ });
+ module.remove.states();
+ },
+
+ reset: function () {
+ $field.each(function (index, el) {
+ var
+ $field = $(el),
+ $element = $field.parent(),
+ $fieldGroup = $field.closest($group),
+ $calendar = $field.closest(selector.uiCalendar),
+ $prompt = $fieldGroup.find(selector.prompt),
+ defaultValue = $field.data(metadata.defaultValue),
+ isCheckbox = $element.is(selector.uiCheckbox),
+ isDropdown = $element.is(selector.uiDropdown) && module.can.useElement('dropdown'),
+ isCalendar = $calendar.length > 0 && module.can.useElement('calendar'),
+ isErrored = $fieldGroup.hasClass(className.error)
+ ;
+ if (defaultValue === undefined) {
+ return;
+ }
+ if (isErrored) {
+ module.verbose('Resetting error on field', $fieldGroup);
+ $fieldGroup.removeClass(className.error);
+ $prompt.remove();
+ }
+ if (isDropdown) {
+ module.verbose('Resetting dropdown value', $element, defaultValue);
+ $element.dropdown('restore defaults', true);
+ } else if (isCheckbox) {
+ module.verbose('Resetting checkbox value', $element, defaultValue);
+ $field.prop('checked', defaultValue);
+ } else if (isCalendar) {
+ $calendar.calendar('set date', defaultValue);
+ } else {
+ module.verbose('Resetting field value', $field, defaultValue);
+ $field.val(defaultValue);
+ }
+ });
+ module.remove.states();
+ },
+
+ determine: {
+ isValid: function () {
+ var
+ allValid = true
+ ;
+ $.each(validation, function (fieldName, field) {
+ if (!module.validate.field(field, fieldName, true)) {
+ allValid = false;
+ }
+ });
+
+ return allValid;
+ },
+ isDirty: function (e) {
+ var formIsDirty = false;
+
+ $field.each(function (index, el) {
+ var
+ $el = $(el),
+ isCheckbox = $el.filter(selector.checkbox).length > 0,
+ isDirty
+ ;
+
+ isDirty = isCheckbox
+ ? module.is.checkboxDirty($el)
+ : module.is.fieldDirty($el);
+
+ $el.data(settings.metadata.isDirty, isDirty);
+
+ formIsDirty = formIsDirty || isDirty;
+ });
+
+ if (formIsDirty) {
+ module.set.dirty();
+ } else {
+ module.set.clean();
+ }
+ },
+ },
+
+ is: {
+ bracketedRule: function (rule) {
+ return rule.type && rule.type.match(settings.regExp.bracket);
+ },
+ // duck type rule test
+ shorthandRules: function (rules) {
+ return typeof rules === 'string' || Array.isArray(rules);
+ },
+ empty: function ($field) {
+ if (!$field || $field.length === 0) {
+ return true;
+ }
+ if ($field.is(selector.checkbox)) {
+ return !$field.is(':checked');
+ }
+
+ return module.is.blank($field);
+ },
+ blank: function ($field) {
+ return String($field.val()).trim() === '';
+ },
+ valid: function (field, showErrors) {
+ var
+ allValid = true
+ ;
+ if (field) {
+ module.verbose('Checking if field is valid', field);
+
+ return module.validate.field(validation[field], field, !!showErrors);
+ }
+
+ module.verbose('Checking if form is valid');
+ $.each(validation, function (fieldName, field) {
+ if (!module.is.valid(fieldName, showErrors)) {
+ allValid = false;
+ }
+ });
+
+ return allValid;
+ },
+ dirty: function () {
+ return dirty;
+ },
+ clean: function () {
+ return !dirty;
+ },
+ fieldDirty: function ($el) {
+ var initialValue = $el.data(metadata.defaultValue);
+ // Explicitly check for undefined/null here as value may be `false`, so ($el.data(dataInitialValue) || '') would not work
+ if (initialValue === undefined || initialValue === null) {
+ initialValue = '';
+ } else if (Array.isArray(initialValue)) {
+ initialValue = initialValue.toString();
+ }
+ var currentValue = $el.val();
+ if (currentValue === undefined || currentValue === null) {
+ currentValue = '';
+ } else if (Array.isArray(currentValue)) {
+ // multiple select values are returned as arrays which are never equal, so do string conversion first
+ currentValue = currentValue.toString();
+ }
+ // Boolean values can be encoded as "true/false" or "True/False" depending on underlying frameworks so we need a case insensitive comparison
+ var boolRegex = /^(true|false)$/i;
+ var isBoolValue = boolRegex.test(initialValue) && boolRegex.test(currentValue);
+ if (isBoolValue) {
+ var regex = new RegExp('^' + initialValue + '$', 'i');
+
+ return !regex.test(currentValue);
+ }
+
+ return currentValue !== initialValue;
+ },
+ checkboxDirty: function ($el) {
+ var initialValue = $el.data(metadata.defaultValue);
+ var currentValue = $el.is(':checked');
+
+ return initialValue !== currentValue;
+ },
+ justDirty: function () {
+ return history[0] === 'dirty';
+ },
+ justClean: function () {
+ return history[0] === 'clean';
+ },
+ },
+
+ removeEvents: function () {
+ $module.off(eventNamespace);
+ $field.off(eventNamespace);
+ $submit.off(eventNamespace);
+ },
+
+ event: {
+ field: {
+ keydown: function (event) {
+ var
+ $field = $(this),
+ key = event.which,
+ isInput = $field.is(selector.input),
+ isCheckbox = $field.is(selector.checkbox),
+ isInDropdown = $field.closest(selector.uiDropdown).length > 0,
+ keyCode = {
+ enter: 13,
+ escape: 27,
+ }
+ ;
+ if (key === keyCode.escape) {
+ module.verbose('Escape key pressed blurring field');
+ $field[0]
+ .blur()
+ ;
+ }
+ if (!event.ctrlKey && key === keyCode.enter && isInput && !isInDropdown && !isCheckbox) {
+ if (!keyHeldDown) {
+ $field.one('keyup' + eventNamespace, module.event.field.keyup);
+ module.submit();
+ module.debug('Enter pressed on input submitting form');
+ event.preventDefault();
+ }
+ keyHeldDown = true;
+ }
+ },
+ keyup: function () {
+ keyHeldDown = false;
+ },
+ blur: function (event) {
+ var
+ $field = $(this),
+ $fieldGroup = $field.closest($group),
+ validationRules = module.get.validation($field)
+ ;
+ if (validationRules && (settings.on === 'blur' || ($fieldGroup.hasClass(className.error) && settings.revalidate))) {
+ module.debug('Revalidating field', $field, validationRules);
+ module.validate.field(validationRules);
+ if (!settings.inline) {
+ module.validate.form(false, true);
+ }
+ }
+ },
+ change: function (event) {
+ var
+ $field = $(this),
+ $fieldGroup = $field.closest($group),
+ validationRules = module.get.validation($field)
+ ;
+ if (validationRules && (settings.on === 'change' || ($fieldGroup.hasClass(className.error) && settings.revalidate))) {
+ clearTimeout(module.timer);
+ module.timer = setTimeout(function () {
+ module.debug('Revalidating field', $field, validationRules);
+ module.validate.field(validationRules);
+ if (!settings.inline) {
+ module.validate.form(false, true);
+ }
+ }, settings.delay);
+ }
+ },
+ },
+ beforeUnload: function (event) {
+ if (module.is.dirty() && !submitting) {
+ event = event || window.event;
+
+ // For modern browsers
+ if (event) {
+ event.returnValue = settings.text.leavingMessage;
+ }
+
+ // For olders...
+ return settings.text.leavingMessage;
+ }
+ },
+
+ },
+
+ get: {
+ ancillaryValue: function (rule) {
+ if (!rule.type || (!rule.value && !module.is.bracketedRule(rule))) {
+ return false;
+ }
+
+ return rule.value !== undefined
+ ? rule.value
+ : rule.type.match(settings.regExp.bracket)[1] + '';
+ },
+ ruleName: function (rule) {
+ if (module.is.bracketedRule(rule)) {
+ return rule.type.replace(rule.type.match(settings.regExp.bracket)[0], '');
+ }
+
+ return rule.type;
+ },
+ changeEvent: function (type, $input) {
+ if (type === 'checkbox' || type === 'radio' || type === 'hidden' || $input.is('select')) {
+ return 'change';
+ }
+
+ return module.get.inputEvent();
+ },
+ inputEvent: function () {
+ return document.createElement('input').oninput !== undefined
+ ? 'input'
+ : (document.createElement('input').onpropertychange !== undefined
+ ? 'propertychange'
+ : 'keyup');
+ },
+ fieldsFromShorthand: function (fields) {
+ var
+ fullFields = {}
+ ;
+ $.each(fields, function (name, rules) {
+ if (!Array.isArray(rules) && typeof rules === 'object') {
+ fullFields[name] = rules;
+ } else {
+ if (typeof rules === 'string') {
+ rules = [rules];
+ }
+ fullFields[name] = {
+ rules: [],
+ };
+ $.each(rules, function (index, rule) {
+ fullFields[name].rules.push({ type: rule });
+ });
+ }
+ });
+
+ return fullFields;
+ },
+ prompt: function (rule, field) {
+ var
+ ruleName = module.get.ruleName(rule),
+ ancillary = module.get.ancillaryValue(rule),
+ $field = module.get.field(field.identifier),
+ value = $field.val(),
+ prompt = isFunction(rule.prompt)
+ ? rule.prompt(value)
+ : rule.prompt || settings.prompt[ruleName] || settings.text.unspecifiedRule,
+ requiresValue = prompt.search('{value}') !== -1,
+ requiresName = prompt.search('{name}') !== -1,
+ $label,
+ name,
+ parts,
+ suffixPrompt
+ ;
+ if (ancillary && ['integer', 'decimal', 'number'].indexOf(ruleName) >= 0 && ancillary.indexOf('..') >= 0) {
+ parts = ancillary.split('..', 2);
+ if (!rule.prompt) {
+ suffixPrompt = parts[0] === ''
+ ? settings.prompt.maxValue.replace(/{ruleValue}/g, '{max}')
+ : (parts[1] === ''
+ ? settings.prompt.minValue.replace(/{ruleValue}/g, '{min}')
+ : settings.prompt.range);
+ prompt += suffixPrompt.replace(/{name}/g, ' ' + settings.text.and);
+ }
+ prompt = prompt.replace(/{min}/g, parts[0]);
+ prompt = prompt.replace(/{max}/g, parts[1]);
+ }
+ if (requiresValue) {
+ prompt = prompt.replace(/{value}/g, $field.val());
+ }
+ if (requiresName) {
+ $label = $field.closest(selector.group).find('label').eq(0);
+ name = $label.length === 1
+ ? $label.text()
+ : $field.prop('placeholder') || settings.text.unspecifiedField;
+ prompt = prompt.replace(/{name}/g, name);
+ }
+ prompt = prompt.replace(/{identifier}/g, field.identifier);
+ prompt = prompt.replace(/{ruleValue}/g, ancillary);
+ if (!rule.prompt) {
+ module.verbose('Using default validation prompt for type', prompt, ruleName);
+ }
+
+ return prompt;
+ },
+ settings: function () {
+ if ($.isPlainObject(parameters)) {
+ if (parameters.fields) {
+ parameters.fields = module.get.fieldsFromShorthand(parameters.fields);
+ }
+ settings = $.extend(true, {}, $.fn.form.settings, parameters);
+ validation = $.extend(true, {}, $.fn.form.settings.defaults, settings.fields);
+ module.verbose('Extending settings', validation, settings);
+ } else {
+ settings = $.extend(true, {}, $.fn.form.settings);
+ validation = $.extend(true, {}, $.fn.form.settings.defaults);
+ module.verbose('Using default form validation', validation, settings);
+ }
+
+ // shorthand
+ namespace = settings.namespace;
+ metadata = settings.metadata;
+ selector = settings.selector;
+ className = settings.className;
+ regExp = settings.regExp;
+ error = settings.error;
+ moduleNamespace = 'module-' + namespace;
+ eventNamespace = '.' + namespace;
+
+ // grab instance
+ instance = $module.data(moduleNamespace);
+
+ // refresh selector cache
+ (instance || module).refresh();
+ },
+ field: function (identifier) {
+ module.verbose('Finding field with identifier', identifier);
+ identifier = module.escape.string(identifier);
+ var t;
+ t = $field.filter('#' + identifier);
+ if (t.length > 0) {
+ return t;
+ }
+ t = $field.filter('[name="' + identifier + '"]');
+ if (t.length > 0) {
+ return t;
+ }
+ t = $field.filter('[name="' + identifier + '[]"]');
+ if (t.length > 0) {
+ return t;
+ }
+ t = $field.filter('[data-' + metadata.validate + '="' + identifier + '"]');
+ if (t.length > 0) {
+ return t;
+ }
+ module.error(error.noField.replace('{identifier}', identifier));
+
+ return $('');
+ },
+ fields: function (fields) {
+ var
+ $fields = $()
+ ;
+ $.each(fields, function (index, name) {
+ $fields = $fields.add(module.get.field(name));
+ });
+
+ return $fields;
+ },
+ validation: function ($field) {
+ var
+ fieldValidation,
+ identifier
+ ;
+ if (!validation) {
+ return false;
+ }
+ $.each(validation, function (fieldName, field) {
+ identifier = field.identifier || fieldName;
+ $.each(module.get.field(identifier), function (index, groupField) {
+ if (groupField == $field[0]) {
+ field.identifier = identifier;
+ fieldValidation = field;
+
+ return false;
+ }
+ });
+ });
+
+ return fieldValidation || false;
+ },
+ value: function (field) {
+ var
+ fields = [],
+ results
+ ;
+ fields.push(field);
+ results = module.get.values.call(element, fields);
+
+ return results[field];
+ },
+ values: function (fields) {
+ var
+ $fields = Array.isArray(fields)
+ ? module.get.fields(fields)
+ : $field,
+ values = {}
+ ;
+ $fields.each(function (index, field) {
+ var
+ $field = $(field),
+ $calendar = $field.closest(selector.uiCalendar),
+ name = $field.prop('name'),
+ value = $field.val(),
+ isCheckbox = $field.is(selector.checkbox),
+ isRadio = $field.is(selector.radio),
+ isMultiple = name.indexOf('[]') !== -1,
+ isCalendar = $calendar.length > 0 && module.can.useElement('calendar'),
+ isChecked = isCheckbox
+ ? $field.is(':checked')
+ : false
+ ;
+ if (name) {
+ if (isMultiple) {
+ name = name.replace('[]', '');
+ if (!values[name]) {
+ values[name] = [];
+ }
+ if (isCheckbox) {
+ if (isChecked) {
+ values[name].push(value || true);
+ } else {
+ values[name].push(false);
+ }
+ } else {
+ values[name].push(value);
+ }
+ } else {
+ if (isRadio) {
+ if (values[name] === undefined || values[name] === false) {
+ values[name] = isChecked
+ ? value || true
+ : false;
+ }
+ } else if (isCheckbox) {
+ values[name] = isChecked ? value || true : false;
+ } else if (isCalendar) {
+ var date = $calendar.calendar('get date');
+
+ if (date !== null) {
+ switch (settings.dateHandling) {
+ case 'date': {
+ values[name] = date;
+
+ break;
+ }
+ case 'input': {
+ values[name] = $calendar.calendar('get input date');
+
+ break;
+ }
+ case 'formatter': {
+ var type = $calendar.calendar('setting', 'type');
+
+ switch (type) {
+ case 'date': {
+ values[name] = settings.formatter.date(date);
+
+ break;
+ }
+ case 'datetime': {
+ values[name] = settings.formatter.datetime(date);
+
+ break;
+ }
+ case 'time': {
+ values[name] = settings.formatter.time(date);
+
+ break;
+ }
+ case 'month': {
+ values[name] = settings.formatter.month(date);
+
+ break;
+ }
+ case 'year': {
+ values[name] = settings.formatter.year(date);
+
+ break;
+ }
+ default: {
+ module.debug('Wrong calendar mode', $calendar, type);
+ values[name] = '';
+ }
+ }
+
+ break;
+ }
+ }
+ } else {
+ values[name] = '';
+ }
+ } else {
+ values[name] = value;
+ }
+ }
+ }
+ });
+
+ return values;
+ },
+ dirtyFields: function () {
+ return $field.filter(function (index, e) {
+ return $(e).data(metadata.isDirty);
+ });
+ },
+ },
+
+ has: {
+
+ field: function (identifier) {
+ module.verbose('Checking for existence of a field with identifier', identifier);
+ identifier = module.escape.string(identifier);
+ if (typeof identifier !== 'string') {
+ module.error(error.identifier, identifier);
+ }
+
+ return (
+ $field.filter('#' + identifier).length > 0
+ || $field.filter('[name="' + identifier + '"]').length > 0
+ || $field.filter('[data-' + metadata.validate + '="' + identifier + '"]').length > 0
+ );
+ },
+
+ },
+
+ can: {
+ useElement: function (element) {
+ if ($.fn[element] !== undefined) {
+ return true;
+ }
+ module.error(error.noElement.replace('{element}', element));
+
+ return false;
+ },
+ },
+
+ escape: {
+ string: function (text) {
+ text = String(text);
+
+ return text.replace(regExp.escape, '\\$&');
+ },
+ },
+
+ add: {
+ // alias
+ rule: function (name, rules) {
+ module.add.field(name, rules);
+ },
+ field: function (name, rules) {
+ // Validation should have at least a standard format
+ if (validation[name] === undefined || validation[name].rules === undefined) {
+ validation[name] = {
+ rules: [],
+ };
+ }
+ var
+ newValidation = {
+ rules: [],
+ }
+ ;
+ if (module.is.shorthandRules(rules)) {
+ rules = Array.isArray(rules)
+ ? rules
+ : [rules];
+ $.each(rules, function (_index, rule) {
+ newValidation.rules.push({ type: rule });
+ });
+ } else {
+ newValidation.rules = rules.rules;
+ }
+ // For each new rule, check if there's not already one with the same type
+ $.each(newValidation.rules, function (_index, rule) {
+ if ($.grep(validation[name].rules, function (item) {
+ return item.type === rule.type;
+ }).length === 0) {
+ validation[name].rules.push(rule);
+ }
+ });
+ module.debug('Adding rules', newValidation.rules, validation);
+ module.refreshEvents();
+ },
+ fields: function (fields) {
+ validation = $.extend(true, {}, validation, module.get.fieldsFromShorthand(fields));
+ module.refreshEvents();
+ },
+ prompt: function (identifier, errors, internal) {
+ var
+ $field = module.get.field(identifier),
+ $fieldGroup = $field.closest($group),
+ $prompt = $fieldGroup.children(selector.prompt),
+ promptExists = $prompt.length > 0
+ ;
+ errors = typeof errors === 'string'
+ ? [errors]
+ : errors;
+ module.verbose('Adding field error state', identifier);
+ if (!internal) {
+ $fieldGroup
+ .addClass(className.error)
+ ;
+ }
+ if (settings.inline) {
+ if (!promptExists) {
+ $prompt = $('
').addClass(className.label);
+ $prompt
+ .appendTo($fieldGroup)
+ ;
+ }
+ $prompt
+ .html(settings.templates.prompt(errors))
+ ;
+ if (!promptExists) {
+ if (settings.transition && module.can.useElement('transition') && $module.transition('is supported')) {
+ module.verbose('Displaying error with css transition', settings.transition);
+ $prompt.transition(settings.transition + ' in', settings.duration);
+ } else {
+ module.verbose('Displaying error with fallback javascript animation');
+ $prompt
+ .fadeIn(settings.duration)
+ ;
+ }
+ } else {
+ module.verbose('Inline errors are disabled, no inline error added', identifier);
+ }
+ }
+ },
+ errors: function (errors) {
+ module.debug('Adding form error messages', errors);
+ module.set.error();
+ $message
+ .html(settings.templates.error(errors))
+ ;
+ },
+ },
+
+ remove: {
+ errors: function () {
+ module.debug('Removing form error messages');
+ $message.empty();
+ },
+ states: function () {
+ $module.removeClass(className.error).removeClass(className.success);
+ if (!settings.inline) {
+ module.remove.errors();
+ }
+ module.determine.isDirty();
+ },
+ rule: function (field, rule) {
+ var
+ rules = Array.isArray(rule)
+ ? rule
+ : [rule]
+ ;
+ if (validation[field] === undefined || !Array.isArray(validation[field].rules)) {
+ return;
+ }
+ if (rule === undefined) {
+ module.debug('Removed all rules');
+ if (module.has.field(field)) {
+ validation[field].rules = [];
+ } else {
+ delete validation[field];
+ }
+
+ return;
+ }
+ $.each(validation[field].rules, function (index, rule) {
+ if (rule && rules.indexOf(rule.type) !== -1) {
+ module.debug('Removed rule', rule.type);
+ validation[field].rules.splice(index, 1);
+ }
+ });
+ },
+ field: function (field) {
+ var
+ fields = Array.isArray(field)
+ ? field
+ : [field]
+ ;
+ $.each(fields, function (index, field) {
+ module.remove.rule(field);
+ });
+ module.refreshEvents();
+ },
+ // alias
+ rules: function (field, rules) {
+ if (Array.isArray(field)) {
+ $.each(field, function (index, field) {
+ module.remove.rule(field, rules);
+ });
+ } else {
+ module.remove.rule(field, rules);
+ }
+ },
+ fields: function (fields) {
+ module.remove.field(fields);
+ },
+ prompt: function (identifier) {
+ var
+ $field = module.get.field(identifier),
+ $fieldGroup = $field.closest($group),
+ $prompt = $fieldGroup.children(selector.prompt)
+ ;
+ $fieldGroup
+ .removeClass(className.error)
+ ;
+ if (settings.inline && $prompt.is(':visible')) {
+ module.verbose('Removing prompt for field', identifier);
+ if (settings.transition && module.can.useElement('transition') && $module.transition('is supported')) {
+ $prompt.transition(settings.transition + ' out', settings.duration, function () {
+ $prompt.remove();
+ });
+ } else {
+ $prompt
+ .fadeOut(settings.duration, function () {
+ $prompt.remove();
+ })
+ ;
+ }
+ }
+ },
+ },
+
+ set: {
+ success: function () {
+ $module
+ .removeClass(className.error)
+ .addClass(className.success)
+ ;
+ },
+ defaults: function () {
+ $field.each(function (index, el) {
+ var
+ $el = $(el),
+ $parent = $el.parent(),
+ isCheckbox = $el.filter(selector.checkbox).length > 0,
+ isDropdown = $parent.is(selector.uiDropdown) && module.can.useElement('dropdown'),
+ $calendar = $el.closest(selector.uiCalendar),
+ isCalendar = $calendar.length > 0 && module.can.useElement('calendar'),
+ value = isCheckbox
+ ? $el.is(':checked')
+ : $el.val()
+ ;
+ if (isDropdown) {
+ $parent.dropdown('save defaults');
+ } else if (isCalendar) {
+ $calendar.calendar('refresh');
+ }
+ $el.data(metadata.defaultValue, value);
+ $el.data(metadata.isDirty, false);
+ });
+ },
+ error: function () {
+ $module
+ .removeClass(className.success)
+ .addClass(className.error)
+ ;
+ },
+ value: function (field, value) {
+ var
+ fields = {}
+ ;
+ fields[field] = value;
+
+ return module.set.values.call(element, fields);
+ },
+ values: function (fields) {
+ if ($.isEmptyObject(fields)) {
+ return;
+ }
+ $.each(fields, function (key, value) {
+ var
+ $field = module.get.field(key),
+ $element = $field.parent(),
+ $calendar = $field.closest(selector.uiCalendar),
+ isMultiple = Array.isArray(value),
+ isCheckbox = $element.is(selector.uiCheckbox) && module.can.useElement('checkbox'),
+ isDropdown = $element.is(selector.uiDropdown) && module.can.useElement('dropdown'),
+ isRadio = $field.is(selector.radio) && isCheckbox,
+ isCalendar = $calendar.length > 0 && module.can.useElement('calendar'),
+ fieldExists = $field.length > 0,
+ $multipleField
+ ;
+ if (fieldExists) {
+ if (isMultiple && isCheckbox) {
+ module.verbose('Selecting multiple', value, $field);
+ $element.checkbox('uncheck');
+ $.each(value, function (index, value) {
+ $multipleField = $field.filter('[value="' + value + '"]');
+ $element = $multipleField.parent();
+ if ($multipleField.length > 0) {
+ $element.checkbox('check');
+ }
+ });
+ } else if (isRadio) {
+ module.verbose('Selecting radio value', value, $field);
+ $field.filter('[value="' + value + '"]')
+ .parent(selector.uiCheckbox)
+ .checkbox('check')
+ ;
+ } else if (isCheckbox) {
+ module.verbose('Setting checkbox value', value, $element);
+ if (value === true || value === 1 || value === 'on') {
+ $element.checkbox('check');
+ } else {
+ $element.checkbox('uncheck');
+ }
+ if (typeof value === 'string') {
+ $field.val(value);
+ }
+ } else if (isDropdown) {
+ module.verbose('Setting dropdown value', value, $element);
+ $element.dropdown('set selected', value);
+ } else if (isCalendar) {
+ $calendar.calendar('set date', value);
+ } else {
+ module.verbose('Setting field value', value, $field);
+ $field.val(value);
+ }
+ }
+ });
+ },
+ dirty: function () {
+ module.verbose('Setting state dirty');
+ dirty = true;
+ history[0] = history[1];
+ history[1] = 'dirty';
+
+ if (module.is.justClean()) {
+ $module.trigger('dirty');
+ }
+ },
+ clean: function () {
+ module.verbose('Setting state clean');
+ dirty = false;
+ history[0] = history[1];
+ history[1] = 'clean';
+
+ if (module.is.justDirty()) {
+ $module.trigger('clean');
+ }
+ },
+ asClean: function () {
+ module.set.defaults();
+ module.set.clean();
+ },
+ asDirty: function () {
+ module.set.defaults();
+ module.set.dirty();
+ },
+ autoCheck: function () {
+ module.debug('Enabling auto check on required fields');
+ if (validation) {
+ $.each(validation, function (fieldName) {
+ if (!module.has.field(fieldName)) {
+ module.verbose('Field not found, removing from validation', fieldName);
+ module.remove.field(fieldName);
+ }
+ });
+ }
+ $field.each(function (_index, el) {
+ var
+ $el = $(el),
+ $elGroup = $el.closest($group),
+ isCheckbox = $el.filter(selector.checkbox).length > 0,
+ isRequired = $el.prop('required') || $elGroup.hasClass(className.required) || $elGroup.parent().hasClass(className.required),
+ isDisabled = $el.is(':disabled') || $elGroup.hasClass(className.disabled) || $elGroup.parent().hasClass(className.disabled),
+ validation = module.get.validation($el),
+ hasEmptyRule = validation
+ ? $.grep(validation.rules, function (rule) {
+ return rule.type === 'empty';
+ }) !== 0
+ : false,
+ identifier = validation.identifier || $el.attr('id') || $el.attr('name') || $el.data(metadata.validate)
+ ;
+ if (isRequired && !isDisabled && !hasEmptyRule && identifier !== undefined) {
+ if (isCheckbox) {
+ module.verbose("Adding 'checked' rule on field", identifier);
+ module.add.rule(identifier, 'checked');
+ } else {
+ module.verbose("Adding 'empty' rule on field", identifier);
+ module.add.rule(identifier, 'empty');
+ }
+ }
+ });
+ },
+ optional: function (identifier, bool) {
+ bool = bool !== false;
+ $.each(validation, function (fieldName, field) {
+ if (identifier === fieldName || identifier === field.identifier) {
+ field.optional = bool;
+ }
+ });
+ },
+ },
+
+ validate: {
+
+ form: function (event, ignoreCallbacks) {
+ var values = module.get.values();
+
+ // input keydown event will fire submit repeatedly by browser default
+ if (keyHeldDown) {
+ return false;
+ }
- // Dirty events
- if (settings.preventLeaving) {
- $(window).on('beforeunload' + eventNamespace, module.event.beforeUnload);
- }
+ // reset errors
+ formErrors = [];
+ if (module.determine.isValid()) {
+ module.debug('Form has no validation errors, submitting');
+ module.set.success();
+ if (!settings.inline) {
+ module.remove.errors();
+ }
+ if (ignoreCallbacks !== true) {
+ return settings.onSuccess.call(element, event, values);
+ }
+ } else {
+ module.debug('Form has errors');
+ submitting = false;
+ module.set.error();
+ if (!settings.inline) {
+ module.add.errors(formErrors);
+ }
+ // prevent ajax submit
+ if (event && $module.data('moduleApi') !== undefined) {
+ event.stopImmediatePropagation();
+ }
+ if (settings.errorFocus && ignoreCallbacks !== true) {
+ var
+ $focusElement,
+ hasTabIndex = true
+ ;
+ if (typeof settings.errorFocus === 'string') {
+ $focusElement = $(document).find(settings.errorFocus);
+ hasTabIndex = $focusElement.is('[tabindex]');
+ // to be able to focus/scroll into non input elements we need a tabindex
+ if (!hasTabIndex) {
+ $focusElement.attr('tabindex', -1);
+ }
+ } else {
+ $focusElement = $group.filter('.' + className.error).first().find(selector.field);
+ }
+ $focusElement.trigger('focus');
+ // only remove tabindex if it was dynamically created above
+ if (!hasTabIndex) {
+ $focusElement.removeAttr('tabindex');
+ }
+ }
+ if (ignoreCallbacks !== true) {
+ return settings.onFailure.call(element, formErrors, values);
+ }
+ }
+ },
+
+ // takes a validation object and returns whether field passes validation
+ field: function (field, fieldName, showErrors) {
+ showErrors = showErrors !== undefined
+ ? showErrors
+ : true;
+ if (typeof field === 'string') {
+ module.verbose('Validating field', field);
+ fieldName = field;
+ field = validation[field];
+ }
+ if (!field) {
+ module.debug('Unable to find field validation. Skipping', fieldName);
+
+ return true;
+ }
+ var
+ identifier = field.identifier || fieldName,
+ $field = module.get.field(identifier),
+ $dependsField = field.depends
+ ? module.get.field(field.depends)
+ : false,
+ fieldValid = true,
+ fieldErrors = []
+ ;
+ if (!field.identifier) {
+ module.debug('Using field name as identifier', identifier);
+ field.identifier = identifier;
+ }
+ var isDisabled = $field.filter(':not(:disabled)').length === 0;
+ if (isDisabled) {
+ module.debug('Field is disabled. Skipping', identifier);
+ } else if (field.optional && module.is.blank($field)) {
+ module.debug('Field is optional and blank. Skipping', identifier);
+ } else if (field.depends && module.is.empty($dependsField)) {
+ module.debug('Field depends on another value that is not present or empty. Skipping', $dependsField);
+ } else if (field.rules !== undefined) {
+ if (showErrors) {
+ $field.closest($group).removeClass(className.error);
+ }
+ $.each(field.rules, function (index, rule) {
+ if (module.has.field(identifier)) {
+ var invalidFields = module.validate.rule(field, rule, true) || [];
+ if (invalidFields.length > 0) {
+ module.debug('Field is invalid', identifier, rule.type);
+ fieldErrors.push(module.get.prompt(rule, field));
+ fieldValid = false;
+ if (showErrors) {
+ $(invalidFields).closest($group).addClass(className.error);
+ }
+ }
+ }
+ });
+ }
+ if (fieldValid) {
+ if (showErrors) {
+ module.remove.prompt(identifier, fieldErrors);
+ settings.onValid.call($field);
+ }
+ } else {
+ if (showErrors) {
+ formErrors = formErrors.concat(fieldErrors);
+ module.add.prompt(identifier, fieldErrors, true);
+ settings.onInvalid.call($field, fieldErrors);
+ }
+
+ return false;
+ }
+
+ return true;
+ },
+
+ // takes validation rule and returns whether field passes rule
+ rule: function (field, rule, internal) {
+ var
+ $field = module.get.field(field.identifier),
+ ancillary = module.get.ancillaryValue(rule),
+ ruleName = module.get.ruleName(rule),
+ ruleFunction = settings.rules[ruleName],
+ invalidFields = [],
+ isCheckbox = $field.is(selector.checkbox),
+ isValid = function (field) {
+ var value = isCheckbox ? $(field).filter(':checked').val() : $(field).val();
+ // cast to string avoiding encoding special values
+ value = value === undefined || value === '' || value === null
+ ? ''
+ : ((settings.shouldTrim && rule.shouldTrim !== false) || rule.shouldTrim
+ ? String(value + '').trim()
+ : String(value + ''));
+
+ return ruleFunction.call(field, value, ancillary, $module);
+ }
+ ;
+ if (!isFunction(ruleFunction)) {
+ module.error(error.noRule, ruleName);
+
+ return;
+ }
+ if (isCheckbox) {
+ if (!isValid($field)) {
+ invalidFields = $field;
+ }
+ } else {
+ $.each($field, function (index, field) {
+ if (!isValid(field)) {
+ invalidFields.push(field);
+ }
+ });
+ }
+
+ return internal ? invalidFields : invalidFields.length === 0;
+ },
+ },
+
+ setting: function (name, value) {
+ if ($.isPlainObject(name)) {
+ $.extend(true, settings, name);
+ } else if (value !== undefined) {
+ settings[name] = value;
+ } else {
+ return settings[name];
+ }
+ },
+ internal: function (name, value) {
+ if ($.isPlainObject(name)) {
+ $.extend(true, module, name);
+ } else if (value !== undefined) {
+ module[name] = value;
+ } else {
+ return module[name];
+ }
+ },
+ debug: function () {
+ if (!settings.silent && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.debug.apply(console, arguments);
+ }
+ }
+ },
+ verbose: function () {
+ if (!settings.silent && settings.verbose && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.verbose.apply(console, arguments);
+ }
+ }
+ },
+ error: function () {
+ if (!settings.silent) {
+ module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
+ module.error.apply(console, arguments);
+ }
+ },
+ performance: {
+ log: function (message) {
+ var
+ currentTime,
+ executionTime,
+ previousTime
+ ;
+ if (settings.performance) {
+ currentTime = Date.now();
+ previousTime = time || currentTime;
+ executionTime = currentTime - previousTime;
+ time = currentTime;
+ performance.push({
+ Name: message[0],
+ Arguments: [].slice.call(message, 1) || '',
+ Element: element,
+ 'Execution Time': executionTime,
+ });
+ }
+ clearTimeout(module.performance.timer);
+ module.performance.timer = setTimeout(module.performance.display, 500);
+ },
+ display: function () {
+ var
+ title = settings.name + ':',
+ totalTime = 0
+ ;
+ time = false;
+ clearTimeout(module.performance.timer);
+ $.each(performance, function (index, data) {
+ totalTime += data['Execution Time'];
+ });
+ title += ' ' + totalTime + 'ms';
+ if (moduleSelector) {
+ title += ' \'' + moduleSelector + '\'';
+ }
+ if ($allModules.length > 1) {
+ title += ' (' + $allModules.length + ')';
+ }
+ if (performance.length > 0) {
+ console.groupCollapsed(title);
+ if (console.table) {
+ console.table(performance);
+ } else {
+ $.each(performance, function (index, data) {
+ console.log(data.Name + ': ' + data['Execution Time'] + 'ms');
+ });
+ }
+ console.groupEnd();
+ }
+ performance = [];
+ },
+ },
+ invoke: function (query, passedArguments, context) {
+ var
+ object = instance,
+ maxDepth,
+ found,
+ response
+ ;
+ passedArguments = passedArguments || queryArguments;
+ context = context || element;
+ if (typeof query === 'string' && object !== undefined) {
+ query = query.split(/[ .]/);
+ maxDepth = query.length - 1;
+ $.each(query, function (depth, value) {
+ var camelCaseValue = depth !== maxDepth
+ ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
+ : query;
+ if ($.isPlainObject(object[camelCaseValue]) && (depth !== maxDepth)) {
+ object = object[camelCaseValue];
+ } else if (object[camelCaseValue] !== undefined) {
+ found = object[camelCaseValue];
+
+ return false;
+ } else if ($.isPlainObject(object[value]) && (depth !== maxDepth)) {
+ object = object[value];
+ } else if (object[value] !== undefined) {
+ found = object[value];
+
+ return false;
+ } else {
+ module.error(error.method, query);
+
+ return false;
+ }
+ });
+ }
+ if (isFunction(found)) {
+ response = found.apply(context, passedArguments);
+ } else if (found !== undefined) {
+ response = found;
+ }
+ if (Array.isArray(returnedValue)) {
+ returnedValue.push(response);
+ } else if (returnedValue !== undefined) {
+ returnedValue = [returnedValue, response];
+ } else if (response !== undefined) {
+ returnedValue = response;
+ }
+
+ return found;
+ },
+ };
+ module.initialize();
+ });
+
+ return returnedValue !== undefined
+ ? returnedValue
+ : this;
+ };
+
+ $.fn.form.settings = {
+
+ name: 'Form',
+ namespace: 'form',
+
+ debug: false,
+ verbose: false,
+ performance: true,
+
+ fields: false,
+
+ keyboardShortcuts: true,
+ on: 'submit',
+ inline: false,
+
+ delay: 200,
+ revalidate: true,
+ shouldTrim: true,
+
+ transition: 'scale',
+ duration: 200,
- $field.on('change click keyup keydown blur', function(e) {
- module.determine.isDirty();
- });
+ autoCheckRequired: false,
+ preventLeaving: false,
+ errorFocus: true,
+ dateHandling: 'date', // 'date', 'input', 'formatter'
- $module.on('dirty' + eventNamespace, function(e) {
- settings.onDirty.call();
- });
+ onValid: function () {},
+ onInvalid: function () {},
+ onSuccess: function () {
+ return true;
+ },
+ onFailure: function () {
+ return false;
+ },
+ onDirty: function () {},
+ onClean: function () {},
- $module.on('clean' + eventNamespace, function(e) {
- settings.onClean.call();
- })
+ metadata: {
+ defaultValue: 'default',
+ validate: 'validate',
+ isDirty: 'isDirty',
},
- clear: function() {
- $field.each(function (index, el) {
- var
- $field = $(el),
- $element = $field.parent(),
- $fieldGroup = $field.closest($group),
- $prompt = $fieldGroup.find(selector.prompt),
- $calendar = $field.closest(selector.uiCalendar),
- defaultValue = $field.data(metadata.defaultValue) || '',
- isCheckbox = $element.is(selector.uiCheckbox),
- isDropdown = $element.is(selector.uiDropdown) && module.can.useElement('dropdown'),
- isCalendar = ($calendar.length > 0 && module.can.useElement('calendar')),
- isErrored = $fieldGroup.hasClass(className.error)
- ;
- if(isErrored) {
- module.verbose('Resetting error on field', $fieldGroup);
- $fieldGroup.removeClass(className.error);
- $prompt.remove();
- }
- if(isDropdown) {
- module.verbose('Resetting dropdown value', $element, defaultValue);
- $element.dropdown('clear', true);
- }
- else if(isCheckbox) {
- $field.prop('checked', false);
- }
- else if (isCalendar) {
- $calendar.calendar('clear');
- }
- else {
- module.verbose('Resetting field value', $field, defaultValue);
- $field.val('');
- }
- });
- module.remove.states();
+ regExp: {
+ htmlID: /^[A-Za-z][\w.:-]*$/g,
+ bracket: /\[(.*)]/i,
+ decimal: /^\d+\.?\d*$/,
+ email: /^[\w!#$%&'*+./=?^`{|}~-]+@[\da-z]([\da-z-]*[\da-z])?(\.[\da-z]([\da-z-]*[\da-z])?)*$/i,
+ escape: /[$()*+,./:=?@[\\\]^{|}-]/g,
+ flags: /^\/(.*)\/(.*)?/,
+ integer: /^-?\d+$/,
+ number: /^-?\d*(\.\d+)?$/,
+ url: /(https?:\/\/(?:www\.|(?!www))[^\s.]+\.\S{2,}|www\.\S+\.\S{2,})/i,
},
- reset: function() {
- $field.each(function (index, el) {
- var
- $field = $(el),
- $element = $field.parent(),
- $fieldGroup = $field.closest($group),
- $calendar = $field.closest(selector.uiCalendar),
- $prompt = $fieldGroup.find(selector.prompt),
- defaultValue = $field.data(metadata.defaultValue),
- isCheckbox = $element.is(selector.uiCheckbox),
- isDropdown = $element.is(selector.uiDropdown) && module.can.useElement('dropdown'),
- isCalendar = ($calendar.length > 0 && module.can.useElement('calendar')),
- isErrored = $fieldGroup.hasClass(className.error)
- ;
- if(defaultValue === undefined) {
- return;
- }
- if(isErrored) {
- module.verbose('Resetting error on field', $fieldGroup);
- $fieldGroup.removeClass(className.error);
- $prompt.remove();
- }
- if(isDropdown) {
- module.verbose('Resetting dropdown value', $element, defaultValue);
- $element.dropdown('restore defaults', true);
- }
- else if(isCheckbox) {
- module.verbose('Resetting checkbox value', $element, defaultValue);
- $field.prop('checked', defaultValue);
- }
- else if (isCalendar) {
- $calendar.calendar('set date', defaultValue);
- }
- else {
- module.verbose('Resetting field value', $field, defaultValue);
- $field.val(defaultValue);
- }
- });
- module.remove.states();
+ text: {
+ and: 'and',
+ unspecifiedRule: 'Please enter a valid value',
+ unspecifiedField: 'This field',
+ leavingMessage: 'There are unsaved changes on this page which will be discarded if you continue.',
},
- determine: {
- isValid: function() {
- var
- allValid = true
- ;
- $.each(validation, function(fieldName, field) {
- if( !( module.validate.field(field, fieldName, true) ) ) {
- allValid = false;
- }
- });
- return allValid;
- },
- isDirty: function(e) {
- var formIsDirty = false;
-
- $field.each(function(index, el) {
- var
- $el = $(el),
- isCheckbox = ($el.filter(selector.checkbox).length > 0),
- isDirty
- ;
-
- if (isCheckbox) {
- isDirty = module.is.checkboxDirty($el);
- } else {
- isDirty = module.is.fieldDirty($el);
- }
-
- $el.data(settings.metadata.isDirty, isDirty);
-
- formIsDirty |= isDirty;
- });
-
- if (formIsDirty) {
- module.set.dirty();
- } else {
- module.set.clean();
- }
-
- }
+ prompt: {
+ range: '{name} must be in a range from {min} to {max}',
+ maxValue: '{name} must have a maximum value of {ruleValue}',
+ minValue: '{name} must have a minimum value of {ruleValue}',
+ empty: '{name} must have a value',
+ checked: '{name} must be checked',
+ email: '{name} must be a valid e-mail',
+ url: '{name} must be a valid url',
+ regExp: '{name} is not formatted correctly',
+ integer: '{name} must be an integer',
+ decimal: '{name} must be a decimal number',
+ number: '{name} must be set to a number',
+ is: '{name} must be "{ruleValue}"',
+ isExactly: '{name} must be exactly "{ruleValue}"',
+ not: '{name} cannot be set to "{ruleValue}"',
+ notExactly: '{name} cannot be set to exactly "{ruleValue}"',
+ contain: '{name} must contain "{ruleValue}"',
+ containExactly: '{name} must contain exactly "{ruleValue}"',
+ doesntContain: '{name} cannot contain "{ruleValue}"',
+ doesntContainExactly: '{name} cannot contain exactly "{ruleValue}"',
+ minLength: '{name} must be at least {ruleValue} characters',
+ exactLength: '{name} must be exactly {ruleValue} characters',
+ maxLength: '{name} cannot be longer than {ruleValue} characters',
+ match: '{name} must match {ruleValue} field',
+ different: '{name} must have a different value than {ruleValue} field',
+ creditCard: '{name} must be a valid credit card number',
+ minCount: '{name} must have at least {ruleValue} choices',
+ exactCount: '{name} must have exactly {ruleValue} choices',
+ maxCount: '{name} must have {ruleValue} or less choices',
},
- is: {
- bracketedRule: function(rule) {
- return (rule.type && rule.type.match(settings.regExp.bracket));
- },
- // duck type rule test
- shorthandRules: function(rules) {
- return (typeof rules == 'string' || Array.isArray(rules));
- },
- empty: function($field) {
- if(!$field || $field.length === 0) {
- return true;
- }
- else if($field.is(selector.checkbox)) {
- return !$field.is(':checked');
- }
- else {
- return module.is.blank($field);
- }
- },
- blank: function($field) {
- return String($field.val()).trim() === '';
- },
- valid: function(field, showErrors) {
- var
- allValid = true
- ;
- if(field) {
- module.verbose('Checking if field is valid', field);
- return module.validate.field(validation[field], field, !!showErrors);
- }
- else {
- module.verbose('Checking if form is valid');
- $.each(validation, function(fieldName, field) {
- if( !module.is.valid(fieldName, showErrors) ) {
- allValid = false;
- }
- });
- return allValid;
- }
- },
- dirty: function() {
- return dirty;
- },
- clean: function() {
- return !dirty;
- },
- fieldDirty: function($el) {
- var initialValue = $el.data(metadata.defaultValue);
- // Explicitly check for null/undefined here as value may be `false`, so ($el.data(dataInitialValue) || '') would not work
- if (initialValue == null) { initialValue = ''; }
- else if(Array.isArray(initialValue)) {
- initialValue = initialValue.toString();
- }
- var currentValue = $el.val();
- if (currentValue == null) { currentValue = ''; }
- // multiple select values are returned as arrays which are never equal, so do string conversion first
- else if(Array.isArray(currentValue)) {
- currentValue = currentValue.toString();
- }
- // Boolean values can be encoded as "true/false" or "True/False" depending on underlying frameworks so we need a case insensitive comparison
- var boolRegex = /^(true|false)$/i;
- var isBoolValue = boolRegex.test(initialValue) && boolRegex.test(currentValue);
- if (isBoolValue) {
- var regex = new RegExp("^" + initialValue + "$", "i");
- return !regex.test(currentValue);
- }
-
- return currentValue !== initialValue;
- },
- checkboxDirty: function($el) {
- var initialValue = $el.data(metadata.defaultValue);
- var currentValue = $el.is(":checked");
-
- return initialValue !== currentValue;
- },
- justDirty: function() {
- return (history[0] === 'dirty');
- },
- justClean: function() {
- return (history[0] === 'clean');
- }
+ selector: {
+ checkbox: 'input[type="checkbox"], input[type="radio"]',
+ clear: '.clear',
+ field: 'input:not(.search):not([type="file"]):not([type="reset"]):not([type="button"]):not([type="submit"]), textarea, select',
+ group: '.field',
+ input: 'input:not([type="file"])',
+ message: '.error.message',
+ prompt: '.prompt.label',
+ radio: 'input[type="radio"]',
+ reset: '.reset:not([type="reset"])',
+ submit: '.submit:not([type="submit"])',
+ uiCheckbox: '.ui.checkbox',
+ uiDropdown: '.ui.dropdown',
+ uiCalendar: '.ui.calendar',
},
- removeEvents: function() {
- $module.off(eventNamespace);
- $field.off(eventNamespace);
- $submit.off(eventNamespace);
+ className: {
+ error: 'error',
+ label: 'ui basic red pointing prompt label',
+ pressed: 'down',
+ success: 'success',
+ required: 'required',
+ disabled: 'disabled',
},
- event: {
- field: {
- keydown: function(event) {
- var
- $field = $(this),
- key = event.which,
- isInput = $field.is(selector.input),
- isCheckbox = $field.is(selector.checkbox),
- isInDropdown = ($field.closest(selector.uiDropdown).length > 0),
- keyCode = {
- enter : 13,
- escape : 27
- }
- ;
- if( key == keyCode.escape) {
- module.verbose('Escape key pressed blurring field');
- $field[0]
- .blur()
+ error: {
+ identifier: 'You must specify a string identifier for each field',
+ method: 'The method you called is not defined.',
+ noRule: 'There is no rule matching the one you specified',
+ noField: 'Field identifier {identifier} not found',
+ noElement: 'This module requires ui {element}',
+ },
+
+ templates: {
+
+ // template that produces error message
+ error: function (errors) {
+ var
+ html = ''
;
- }
- if(!event.ctrlKey && key == keyCode.enter && isInput && !isInDropdown && !isCheckbox) {
- if(!keyHeldDown) {
- $field.one('keyup' + eventNamespace, module.event.field.keyup);
- module.submit();
- module.debug('Enter pressed on input submitting form');
- event.preventDefault();
- }
- keyHeldDown = true;
- }
- },
- keyup: function() {
- keyHeldDown = false;
+ $.each(errors, function (index, value) {
+ html += '- ' + value + '
';
+ });
+ html += '
';
+
+ return html;
},
- blur: function(event) {
- var
- $field = $(this),
- $fieldGroup = $field.closest($group),
- validationRules = module.get.validation($field)
- ;
- if(validationRules && (settings.on == 'blur' || ( $fieldGroup.hasClass(className.error) && settings.revalidate) )) {
- module.debug('Revalidating field', $field, validationRules);
- module.validate.field( validationRules );
- if(!settings.inline) {
- module.validate.form(false,true);
+
+ // template that produces label content
+ prompt: function (errors) {
+ if (errors.length === 1) {
+ return errors[0];
}
- }
+ var
+ html = ''
+ ;
+ $.each(errors, function (index, value) {
+ html += '- ' + value + '
';
+ });
+ html += '
';
+
+ return html;
},
- change: function(event) {
- var
- $field = $(this),
- $fieldGroup = $field.closest($group),
- validationRules = module.get.validation($field)
- ;
- if(validationRules && (settings.on == 'change' || ( $fieldGroup.hasClass(className.error) && settings.revalidate) )) {
- clearTimeout(module.timer);
- module.timer = setTimeout(function() {
- module.debug('Revalidating field', $field, validationRules);
- module.validate.field( validationRules );
- if(!settings.inline) {
- module.validate.form(false,true);
- }
- }, settings.delay);
- }
- }
- },
- beforeUnload: function(event) {
- if (module.is.dirty() && !submitting) {
- event = event || window.event;
-
- // For modern browsers
- if (event) {
- event.returnValue = settings.text.leavingMessage;
- }
-
- // For olders...
- return settings.text.leavingMessage;
- }
- }
+ },
+ formatter: {
+ date: function (date) {
+ return Intl.DateTimeFormat('en-GB').format(date);
+ },
+ datetime: function (date) {
+ return Intl.DateTimeFormat('en-GB', {
+ year: 'numeric',
+ month: '2-digit',
+ day: '2-digit',
+ hour: '2-digit',
+ minute: '2-digit',
+ second: '2-digit',
+ }).format(date);
+ },
+ time: function (date) {
+ return Intl.DateTimeFormat('en-GB', {
+ hour: '2-digit',
+ minute: '2-digit',
+ second: '2-digit',
+ }).format(date);
+ },
+ month: function (date) {
+ return Intl.DateTimeFormat('en-GB', {
+ month: '2-digit',
+ year: 'numeric',
+ }).format(date);
+ },
+ year: function (date) {
+ return Intl.DateTimeFormat('en-GB', {
+ year: 'numeric',
+ }).format(date);
+ },
},
- get: {
- ancillaryValue: function(rule) {
- if(!rule.type || (!rule.value && !module.is.bracketedRule(rule))) {
- return false;
- }
- return (rule.value !== undefined)
- ? rule.value
- : rule.type.match(settings.regExp.bracket)[1] + ''
- ;
- },
- ruleName: function(rule) {
- if( module.is.bracketedRule(rule) ) {
- return rule.type.replace(rule.type.match(settings.regExp.bracket)[0], '');
- }
- return rule.type;
- },
- changeEvent: function(type, $input) {
- if(type == 'checkbox' || type == 'radio' || type == 'hidden' || $input.is('select')) {
- return 'change';
- }
- else {
- return module.get.inputEvent();
- }
- },
- inputEvent: function() {
- return (document.createElement('input').oninput !== undefined)
- ? 'input'
- : (document.createElement('input').onpropertychange !== undefined)
- ? 'propertychange'
- : 'keyup'
- ;
- },
- fieldsFromShorthand: function(fields) {
- var
- fullFields = {}
- ;
- $.each(fields, function(name, rules) {
- if (!Array.isArray(rules) && typeof rules === 'object') {
- fullFields[name] = rules;
- } else {
- if (typeof rules == 'string') {
- rules = [rules];
+ rules: {
+
+ // is not empty or blank string
+ empty: function (value) {
+ return !(value === undefined || value === '' || (Array.isArray(value) && value.length === 0));
+ },
+
+ // checkbox checked
+ checked: function () {
+ return $(this).filter(':checked').length > 0;
+ },
+
+ // is most likely an email
+ email: function (value) {
+ return $.fn.form.settings.regExp.email.test(value);
+ },
+
+ // value is most likely url
+ url: function (value) {
+ return $.fn.form.settings.regExp.url.test(value);
+ },
+
+ // matches specified regExp
+ regExp: function (value, regExp) {
+ if (regExp instanceof RegExp) {
+ return value.match(regExp);
}
- fullFields[name] = {
- rules: []
- };
- $.each(rules, function (index, rule) {
- fullFields[name].rules.push({type: rule});
- });
- }
- });
- return fullFields;
- },
- prompt: function(rule, field) {
- var
- ruleName = module.get.ruleName(rule),
- ancillary = module.get.ancillaryValue(rule),
- $field = module.get.field(field.identifier),
- value = $field.val(),
- prompt = $.isFunction(rule.prompt)
- ? rule.prompt(value)
- : rule.prompt || settings.prompt[ruleName] || settings.text.unspecifiedRule,
- requiresValue = (prompt.search('{value}') !== -1),
- requiresName = (prompt.search('{name}') !== -1),
- $label,
- name,
- parts,
- suffixPrompt
- ;
- if(ancillary && ['integer', 'decimal', 'number'].indexOf(ruleName) >= 0 && ancillary.indexOf('..') >= 0) {
- parts = ancillary.split('..', 2);
- if(!rule.prompt) {
- suffixPrompt = (
- parts[0] === '' ? settings.prompt.maxValue.replace(/\{ruleValue\}/g,'{max}') :
- parts[1] === '' ? settings.prompt.minValue.replace(/\{ruleValue\}/g,'{min}') :
- settings.prompt.range
- );
- prompt += suffixPrompt.replace(/\{name\}/g, ' ' + settings.text.and);
- }
- prompt = prompt.replace(/\{min\}/g, parts[0]);
- prompt = prompt.replace(/\{max\}/g, parts[1]);
- }
- if(requiresValue) {
- prompt = prompt.replace(/\{value\}/g, $field.val());
- }
- if(requiresName) {
- $label = $field.closest(selector.group).find('label').eq(0);
- name = ($label.length == 1)
- ? $label.text()
- : $field.prop('placeholder') || settings.text.unspecifiedField
- ;
- prompt = prompt.replace(/\{name\}/g, name);
- }
- prompt = prompt.replace(/\{identifier\}/g, field.identifier);
- prompt = prompt.replace(/\{ruleValue\}/g, ancillary);
- if(!rule.prompt) {
- module.verbose('Using default validation prompt for type', prompt, ruleName);
- }
- return prompt;
- },
- settings: function() {
- if($.isPlainObject(parameters)) {
- var
- keys = Object.keys(parameters),
- isLegacySettings = (keys.length > 0)
- ? (parameters[keys[0]].identifier !== undefined && parameters[keys[0]].rules !== undefined)
- : false
- ;
- if(isLegacySettings) {
- // 1.x (ducktyped)
- settings = $.extend(true, {}, $.fn.form.settings, legacyParameters);
- validation = $.extend(true, {}, $.fn.form.settings.defaults, parameters);
- module.error(settings.error.oldSyntax, element);
- module.verbose('Extending settings from legacy parameters', validation, settings);
- }
- else {
- // 2.x
- if(parameters.fields) {
- parameters.fields = module.get.fieldsFromShorthand(parameters.fields);
+ var
+ regExpParts = regExp.match($.fn.form.settings.regExp.flags),
+ flags
+ ;
+ // regular expression specified as /baz/gi (flags)
+ if (regExpParts) {
+ regExp = regExpParts.length >= 2
+ ? regExpParts[1]
+ : regExp;
+ flags = regExpParts.length >= 3
+ ? regExpParts[2]
+ : '';
}
- settings = $.extend(true, {}, $.fn.form.settings, parameters);
- validation = $.extend(true, {}, $.fn.form.settings.defaults, settings.fields);
- module.verbose('Extending settings', validation, settings);
- }
- }
- else {
- settings = $.extend(true, {}, $.fn.form.settings);
- validation = $.extend(true, {}, $.fn.form.settings.defaults);
- module.verbose('Using default form validation', validation, settings);
- }
-
- // shorthand
- namespace = settings.namespace;
- metadata = settings.metadata;
- selector = settings.selector;
- className = settings.className;
- regExp = settings.regExp;
- error = settings.error;
- moduleNamespace = 'module-' + namespace;
- eventNamespace = '.' + namespace;
-
- // grab instance
- instance = $module.data(moduleNamespace);
-
- // refresh selector cache
- (instance || module).refresh();
- },
- field: function(identifier) {
- module.verbose('Finding field with identifier', identifier);
- identifier = module.escape.string(identifier);
- var t;
- if((t=$field.filter('#' + identifier)).length > 0 ) {
- return t;
- }
- if((t=$field.filter('[name="' + identifier +'"]')).length > 0 ) {
- return t;
- }
- if((t=$field.filter('[name="' + identifier +'[]"]')).length > 0 ) {
- return t;
- }
- if((t=$field.filter('[data-' + metadata.validate + '="'+ identifier +'"]')).length > 0 ) {
- return t;
- }
- module.error(error.noField.replace('{identifier}',identifier));
- return $('');
- },
- fields: function(fields) {
- var
- $fields = $()
- ;
- $.each(fields, function(index, name) {
- $fields = $fields.add( module.get.field(name) );
- });
- return $fields;
- },
- validation: function($field) {
- var
- fieldValidation,
- identifier
- ;
- if(!validation) {
- return false;
- }
- $.each(validation, function(fieldName, field) {
- identifier = field.identifier || fieldName;
- $.each(module.get.field(identifier), function(index, groupField) {
- if(groupField == $field[0]) {
- field.identifier = identifier;
- fieldValidation = field;
- return false;
+
+ return value.match(new RegExp(regExp, flags));
+ },
+ minValue: function (value, range) {
+ return $.fn.form.settings.rules.range(value, range + '..', 'number');
+ },
+ maxValue: function (value, range) {
+ return $.fn.form.settings.rules.range(value, '..' + range, 'number');
+ },
+ // is valid integer or matches range
+ integer: function (value, range) {
+ return $.fn.form.settings.rules.range(value, range, 'integer');
+ },
+ range: function (value, range, regExp) {
+ if (typeof regExp === 'string') {
+ regExp = $.fn.form.settings.regExp[regExp];
}
- });
- });
- return fieldValidation || false;
- },
- value: function (field) {
- var
- fields = [],
- results
- ;
- fields.push(field);
- results = module.get.values.call(element, fields);
- return results[field];
- },
- values: function (fields) {
- var
- $fields = Array.isArray(fields)
- ? module.get.fields(fields)
- : $field,
- values = {}
- ;
- $fields.each(function(index, field) {
- var
- $field = $(field),
- $calendar = $field.closest(selector.uiCalendar),
- name = $field.prop('name'),
- value = $field.val(),
- isCheckbox = $field.is(selector.checkbox),
- isRadio = $field.is(selector.radio),
- isMultiple = (name.indexOf('[]') !== -1),
- isCalendar = ($calendar.length > 0 && module.can.useElement('calendar')),
- isChecked = (isCheckbox)
- ? $field.is(':checked')
- : false
- ;
- if(name) {
- if(isMultiple) {
- name = name.replace('[]', '');
- if(!values[name]) {
- values[name] = [];
- }
- if(isCheckbox) {
- if(isChecked) {
- values[name].push(value || true);
- }
- else {
- values[name].push(false);
- }
- }
- else {
- values[name].push(value);
- }
+ if (!(regExp instanceof RegExp)) {
+ regExp = $.fn.form.settings.regExp.integer;
}
- else {
- if(isRadio) {
- if(values[name] === undefined || values[name] === false) {
- values[name] = (isChecked)
- ? value || true
- : false
- ;
+ var
+ min,
+ max,
+ parts
+ ;
+ if (!range || ['', '..'].indexOf(range) !== -1) {
+
+ // do nothing
+ } else if (range.indexOf('..') === -1) {
+ if (regExp.test(range)) {
+ min = range - 0;
+ max = min;
}
- }
- else if(isCheckbox) {
- if(isChecked) {
- values[name] = value || true;
+ } else {
+ parts = range.split('..', 2);
+ if (regExp.test(parts[0])) {
+ min = parts[0] - 0;
}
- else {
- values[name] = false;
+ if (regExp.test(parts[1])) {
+ max = parts[1] - 0;
}
- }
- else if(isCalendar) {
- var date = $calendar.calendar('get date');
-
- if (date !== null) {
- if (settings.dateHandling == 'date') {
- values[name] = date;
- } else if(settings.dateHandling == 'input') {
- values[name] = $calendar.calendar('get input date')
- } else if (settings.dateHandling == 'formatter') {
- var type = $calendar.calendar('setting', 'type');
-
- switch(type) {
- case 'date':
- values[name] = settings.formatter.date(date);
- break;
-
- case 'datetime':
- values[name] = settings.formatter.datetime(date);
- break;
-
- case 'time':
- values[name] = settings.formatter.time(date);
- break;
-
- case 'month':
- values[name] = settings.formatter.month(date);
- break;
-
- case 'year':
- values[name] = settings.formatter.year(date);
- break;
-
- default:
- module.debug('Wrong calendar mode', $calendar, type);
- values[name] = '';
- }
- }
- } else {
- values[name] = '';
- }
- } else {
- values[name] = value;
- }
}
- }
- });
- return values;
- },
- dirtyFields: function() {
- return $field.filter(function(index, e) {
- return $(e).data(metadata.isDirty);
- });
- }
- },
- has: {
-
- field: function(identifier) {
- module.verbose('Checking for existence of a field with identifier', identifier);
- identifier = module.escape.string(identifier);
- if(typeof identifier !== 'string') {
- module.error(error.identifier, identifier);
- }
- return (
- $field.filter('#' + identifier).length > 0 ||
- $field.filter('[name="' + identifier +'"]').length > 0 ||
- $field.filter('[data-' + metadata.validate + '="'+ identifier +'"]').length > 0
- );
- }
+ return (
+ regExp.test(value)
+ && (min === undefined || value >= min)
+ && (max === undefined || value <= max)
+ );
+ },
- },
+ // is valid number (with decimal)
+ decimal: function (value, range) {
+ return $.fn.form.settings.rules.range(value, range, 'decimal');
+ },
- can: {
- useElement: function(element){
- if ($.fn[element] !== undefined) {
- return true;
- }
- module.error(error.noElement.replace('{element}',element));
- return false;
- }
- },
+ // is valid number
+ number: function (value, range) {
+ return $.fn.form.settings.rules.range(value, range, 'number');
+ },
- escape: {
- string: function(text) {
- text = String(text);
- return text.replace(regExp.escape, '\\$&');
- }
- },
+ // is value (case insensitive)
+ is: function (value, text) {
+ text = typeof text === 'string'
+ ? text.toLowerCase()
+ : text;
+ value = typeof value === 'string'
+ ? value.toLowerCase()
+ : value;
- add: {
- // alias
- rule: function(name, rules) {
- module.add.field(name, rules);
- },
- field: function(name, rules) {
- // Validation should have at least a standard format
- if(validation[name] === undefined || validation[name].rules === undefined) {
- validation[name] = {
- rules: []
- };
- }
- var
- newValidation = {
- rules: []
- }
- ;
- if(module.is.shorthandRules(rules)) {
- rules = Array.isArray(rules)
- ? rules
- : [rules]
- ;
- $.each(rules, function(_index, rule) {
- newValidation.rules.push({ type: rule });
- });
- }
- else {
- newValidation.rules = rules.rules;
- }
- // For each new rule, check if there's not already one with the same type
- $.each(newValidation.rules, function (_index, rule) {
- if ($.grep(validation[name].rules, function(item){ return item.type == rule.type; }).length == 0) {
- validation[name].rules.push(rule);
- }
- });
- module.debug('Adding rules', newValidation.rules, validation);
- module.refreshEvents();
- },
- fields: function(fields) {
- validation = $.extend(true, {}, validation, module.get.fieldsFromShorthand(fields));
- module.refreshEvents();
- },
- prompt: function(identifier, errors, internal) {
- var
- $field = module.get.field(identifier),
- $fieldGroup = $field.closest($group),
- $prompt = $fieldGroup.children(selector.prompt),
- promptExists = ($prompt.length !== 0)
- ;
- errors = (typeof errors == 'string')
- ? [errors]
- : errors
- ;
- module.verbose('Adding field error state', identifier);
- if(!internal) {
- $fieldGroup
- .addClass(className.error)
- ;
- }
- if(settings.inline) {
- if(!promptExists) {
- $prompt = $('').addClass(className.label);
- $prompt
- .appendTo($fieldGroup)
+ return value == text;
+ },
+
+ // is value
+ isExactly: function (value, text) {
+ return value == text;
+ },
+
+ // value is not another value (case insensitive)
+ not: function (value, notValue) {
+ value = typeof value === 'string'
+ ? value.toLowerCase()
+ : value;
+ notValue = typeof notValue === 'string'
+ ? notValue.toLowerCase()
+ : notValue;
+
+ return value != notValue;
+ },
+
+ // value is not another value (case sensitive)
+ notExactly: function (value, notValue) {
+ return value != notValue;
+ },
+
+ // value contains text (insensitive)
+ contains: function (value, text) {
+ // escape regex characters
+ text = text.replace($.fn.form.settings.regExp.escape, '\\$&');
+
+ return value.search(new RegExp(text, 'i')) !== -1;
+ },
+
+ // value contains text (case sensitive)
+ containsExactly: function (value, text) {
+ // escape regex characters
+ text = text.replace($.fn.form.settings.regExp.escape, '\\$&');
+
+ return value.search(new RegExp(text)) !== -1;
+ },
+
+ // value contains text (insensitive)
+ doesntContain: function (value, text) {
+ // escape regex characters
+ text = text.replace($.fn.form.settings.regExp.escape, '\\$&');
+
+ return value.search(new RegExp(text, 'i')) === -1;
+ },
+
+ // value contains text (case sensitive)
+ doesntContainExactly: function (value, text) {
+ // escape regex characters
+ text = text.replace($.fn.form.settings.regExp.escape, '\\$&');
+
+ return value.search(new RegExp(text)) === -1;
+ },
+
+ // is at least string length
+ minLength: function (value, requiredLength) {
+ return value !== undefined
+ ? value.length >= requiredLength
+ : false;
+ },
+
+ // is exactly length
+ exactLength: function (value, requiredLength) {
+ return value !== undefined
+ ? value.length === Number(requiredLength)
+ : false;
+ },
+
+ // is less than length
+ maxLength: function (value, maxLength) {
+ return value !== undefined
+ ? value.length <= maxLength
+ : false;
+ },
+
+ // matches another field
+ match: function (value, identifier, $module) {
+ var
+ matchingValue,
+ matchingElement
;
- }
- $prompt
- .html(settings.templates.prompt(errors))
- ;
- if(!promptExists) {
- if(settings.transition && module.can.useElement('transition') && $module.transition('is supported')) {
- module.verbose('Displaying error with css transition', settings.transition);
- $prompt.transition(settings.transition + ' in', settings.duration);
- }
- else {
- module.verbose('Displaying error with fallback javascript animation');
- $prompt
- .fadeIn(settings.duration)
- ;
+ matchingElement = $module.find('[data-validate="' + identifier + '"]');
+ if (matchingElement.length > 0) {
+ matchingValue = matchingElement.val();
+ } else {
+ matchingElement = $module.find('#' + identifier);
+ if (matchingElement.length > 0) {
+ matchingValue = matchingElement.val();
+ } else {
+ matchingElement = $module.find('[name="' + identifier + '"]');
+ if (matchingElement.length > 0) {
+ matchingValue = matchingElement.val();
+ } else {
+ matchingElement = $module.find('[name="' + identifier + '[]"]');
+ if (matchingElement.length > 0) {
+ matchingValue = matchingElement;
+ }
+ }
+ }
}
- }
- else {
- module.verbose('Inline errors are disabled, no inline error added', identifier);
- }
- }
- },
- errors: function(errors) {
- module.debug('Adding form error messages', errors);
- module.set.error();
- $message
- .html( settings.templates.error(errors) )
- ;
- }
- },
- remove: {
- errors: function() {
- module.debug('Removing form error messages');
- $message.empty();
- },
- states: function() {
- $module.removeClass(className.error).removeClass(className.success);
- if(!settings.inline) {
- module.remove.errors();
- }
- module.determine.isDirty();
- },
- rule: function(field, rule) {
- var
- rules = Array.isArray(rule)
- ? rule
- : [rule]
- ;
- if(validation[field] === undefined || !Array.isArray(validation[field].rules)) {
- return;
- }
- if(rule === undefined) {
- module.debug('Removed all rules');
- validation[field].rules = [];
- return;
- }
- $.each(validation[field].rules, function(index, rule) {
- if(rule && rules.indexOf(rule.type) !== -1) {
- module.debug('Removed rule', rule.type);
- validation[field].rules.splice(index, 1);
- }
- });
- },
- field: function(field) {
- var
- fields = Array.isArray(field)
- ? field
- : [field]
- ;
- $.each(fields, function(index, field) {
- module.remove.rule(field);
- });
- module.refreshEvents();
- },
- // alias
- rules: function(field, rules) {
- if(Array.isArray(field)) {
- $.each(field, function(index, field) {
- module.remove.rule(field, rules);
- });
- }
- else {
- module.remove.rule(field, rules);
- }
- },
- fields: function(fields) {
- module.remove.field(fields);
- },
- prompt: function(identifier) {
- var
- $field = module.get.field(identifier),
- $fieldGroup = $field.closest($group),
- $prompt = $fieldGroup.children(selector.prompt)
- ;
- $fieldGroup
- .removeClass(className.error)
- ;
- if(settings.inline && $prompt.is(':visible')) {
- module.verbose('Removing prompt for field', identifier);
- if(settings.transition && module.can.useElement('transition') && $module.transition('is supported')) {
- $prompt.transition(settings.transition + ' out', settings.duration, function() {
- $prompt.remove();
- });
- }
- else {
- $prompt
- .fadeOut(settings.duration, function(){
- $prompt.remove();
- })
- ;
- }
- }
- }
- },
+ return matchingValue !== undefined
+ ? value.toString() === matchingValue.toString()
+ : false;
+ },
- set: {
- success: function() {
- $module
- .removeClass(className.error)
- .addClass(className.success)
- ;
- },
- defaults: function () {
- $field.each(function (index, el) {
- var
- $el = $(el),
- $parent = $el.parent(),
- isCheckbox = ($el.filter(selector.checkbox).length > 0),
- isDropdown = $parent.is(selector.uiDropdown) && module.can.useElement('dropdown'),
- $calendar = $el.closest(selector.uiCalendar),
- isCalendar = ($calendar.length > 0 && module.can.useElement('calendar')),
- value = (isCheckbox)
- ? $el.is(':checked')
- : $el.val()
- ;
- if (isDropdown) {
- $parent.dropdown('save defaults');
- }
- else if (isCalendar) {
- $calendar.calendar('refresh');
- }
- $el.data(metadata.defaultValue, value);
- $el.data(metadata.isDirty, false);
- });
- },
- error: function() {
- $module
- .removeClass(className.success)
- .addClass(className.error)
- ;
- },
- value: function (field, value) {
- var
- fields = {}
- ;
- fields[field] = value;
- return module.set.values.call(element, fields);
- },
- values: function (fields) {
- if($.isEmptyObject(fields)) {
- return;
- }
- $.each(fields, function(key, value) {
- var
- $field = module.get.field(key),
- $element = $field.parent(),
- $calendar = $field.closest(selector.uiCalendar),
- isMultiple = Array.isArray(value),
- isCheckbox = $element.is(selector.uiCheckbox) && module.can.useElement('checkbox'),
- isDropdown = $element.is(selector.uiDropdown) && module.can.useElement('dropdown'),
- isRadio = ($field.is(selector.radio) && isCheckbox),
- isCalendar = ($calendar.length > 0 && module.can.useElement('calendar')),
- fieldExists = ($field.length > 0),
- $multipleField
- ;
- if(fieldExists) {
- if(isMultiple && isCheckbox) {
- module.verbose('Selecting multiple', value, $field);
- $element.checkbox('uncheck');
- $.each(value, function(index, value) {
- $multipleField = $field.filter('[value="' + value + '"]');
- $element = $multipleField.parent();
- if($multipleField.length > 0) {
- $element.checkbox('check');
+ // different than another field
+ different: function (value, identifier, $module) {
+ // use either id or name of field
+ var
+ matchingValue,
+ matchingElement
+ ;
+ matchingElement = $module.find('[data-validate="' + identifier + '"]');
+ if (matchingElement.length > 0) {
+ matchingValue = matchingElement.val();
+ } else {
+ matchingElement = $module.find('#' + identifier);
+ if (matchingElement.length > 0) {
+ matchingValue = matchingElement.val();
+ } else {
+ matchingElement = $module.find('[name="' + identifier + '"]');
+ if (matchingElement.length > 0) {
+ matchingValue = matchingElement.val();
+ } else {
+ matchingElement = $module.find('[name="' + identifier + '[]"]');
+ if (matchingElement.length > 0) {
+ matchingValue = matchingElement;
+ }
+ }
}
- });
}
- else if(isRadio) {
- module.verbose('Selecting radio value', value, $field);
- $field.filter('[value="' + value + '"]')
- .parent(selector.uiCheckbox)
- .checkbox('check')
- ;
+
+ return matchingValue !== undefined
+ ? value.toString() !== matchingValue.toString()
+ : false;
+ },
+
+ creditCard: function (cardNumber, cardTypes) {
+ var
+ cards = {
+ visa: {
+ pattern: /^4/,
+ length: [16],
+ },
+ amex: {
+ pattern: /^3[47]/,
+ length: [15],
+ },
+ mastercard: {
+ pattern: /^5[1-5]/,
+ length: [16],
+ },
+ discover: {
+ pattern: /^(6011|622(12[6-9]|1[3-9]\d|[2-8]\d{2}|9[01]\d|92[0-5]|64[4-9])|65)/,
+ length: [16],
+ },
+ unionPay: {
+ pattern: /^(62|88)/,
+ length: [16, 17, 18, 19],
+ },
+ jcb: {
+ pattern: /^35(2[89]|[3-8]\d)/,
+ length: [16],
+ },
+ maestro: {
+ pattern: /^(5018|5020|5038|6304|6759|676[1-3])/,
+ length: [12, 13, 14, 15, 16, 17, 18, 19],
+ },
+ dinersClub: {
+ pattern: /^(30[0-5]|^36)/,
+ length: [14],
+ },
+ laser: {
+ pattern: /^(6304|670[69]|6771)/,
+ length: [16, 17, 18, 19],
+ },
+ visaElectron: {
+ pattern: /^(4026|417500|4508|4844|491(3|7))/,
+ length: [16],
+ },
+ },
+ valid = {},
+ validCard = false,
+ requiredTypes = typeof cardTypes === 'string'
+ ? cardTypes.split(',')
+ : false,
+ unionPay,
+ validation
+ ;
+
+ if (typeof cardNumber !== 'string' || cardNumber.length === 0) {
+ return;
}
- else if(isCheckbox) {
- module.verbose('Setting checkbox value', value, $element);
- if(value === true || value === 1 || value === 'on') {
- $element.checkbox('check');
- }
- else {
- $element.checkbox('uncheck');
- }
- if(typeof value === 'string') {
- $field.val(value);
- }
+
+ // allow dashes and spaces in card
+ cardNumber = cardNumber.replace(/[\s-]/g, '');
+
+ // verify card types
+ if (requiredTypes) {
+ $.each(requiredTypes, function (index, type) {
+ // verify each card type
+ validation = cards[type];
+ if (validation) {
+ valid = {
+ length: $.inArray(cardNumber.length, validation.length) !== -1,
+ pattern: cardNumber.search(validation.pattern) !== -1,
+ };
+ if (valid.length > 0 && valid.pattern) {
+ validCard = true;
+ }
+ }
+ });
+
+ if (!validCard) {
+ return false;
+ }
}
- else if(isDropdown) {
- module.verbose('Setting dropdown value', value, $element);
- $element.dropdown('set selected', value);
+
+ // skip luhn for UnionPay
+ unionPay = {
+ number: $.inArray(cardNumber.length, cards.unionPay.length) !== -1,
+ pattern: cardNumber.search(cards.unionPay.pattern) !== -1,
+ };
+ if (unionPay.number && unionPay.pattern) {
+ return true;
}
- else if (isCalendar) {
- $calendar.calendar('set date',value);
+
+ // verify luhn, adapted from
+ var
+ length = cardNumber.length,
+ multiple = 0,
+ producedValue = [
+ [0, 1, 2, 3, 4, 5, 6, 7, 8, 9],
+ [0, 2, 4, 6, 8, 1, 3, 5, 7, 9],
+ ],
+ sum = 0
+ ;
+ while (length--) {
+ sum += producedValue[multiple][parseInt(cardNumber.charAt(length), 10)];
+ multiple ^= 1; // eslint-disable-line no-bitwise
}
- else {
- module.verbose('Setting field value', value, $field);
- $field.val(value);
+
+ return sum % 10 === 0 && sum > 0;
+ },
+
+ minCount: function (value, minCount) {
+ minCount = Number(minCount);
+
+ if (minCount === 0) {
+ return true;
}
- }
- });
- },
- dirty: function() {
- module.verbose('Setting state dirty');
- dirty = true;
- history[0] = history[1];
- history[1] = 'dirty';
-
- if (module.is.justClean()) {
- $module.trigger('dirty');
- }
- },
- clean: function() {
- module.verbose('Setting state clean');
- dirty = false;
- history[0] = history[1];
- history[1] = 'clean';
-
- if (module.is.justDirty()) {
- $module.trigger('clean');
- }
- },
- asClean: function() {
- module.set.defaults();
- module.set.clean();
- },
- asDirty: function() {
- module.set.defaults();
- module.set.dirty();
- },
- autoCheck: function() {
- module.debug('Enabling auto check on required fields');
- $field.each(function (_index, el) {
- var
- $el = $(el),
- $elGroup = $(el).closest($group),
- isCheckbox = ($el.filter(selector.checkbox).length > 0),
- isRequired = $el.prop('required') || $elGroup.hasClass(className.required) || $elGroup.parent().hasClass(className.required),
- isDisabled = $el.is(':disabled') || $elGroup.hasClass(className.disabled) || $elGroup.parent().hasClass(className.disabled),
- validation = module.get.validation($el),
- hasEmptyRule = validation
- ? $.grep(validation.rules, function(rule) { return rule.type == "empty" }) !== 0
- : false,
- identifier = validation.identifier || $el.attr('id') || $el.attr('name') || $el.data(metadata.validate)
- ;
- if (isRequired && !isDisabled && !hasEmptyRule && identifier !== undefined) {
- if (isCheckbox) {
- module.verbose("Adding 'checked' rule on field", identifier);
- module.add.rule(identifier, "checked");
- } else {
- module.verbose("Adding 'empty' rule on field", identifier);
- module.add.rule(identifier, "empty");
+ if (minCount === 1) {
+ return value !== '';
}
- }
- });
- },
- optional: function(identifier, bool) {
- bool = (bool !== false);
- $.each(validation, function(fieldName, field) {
- if (identifier == fieldName || identifier == field.identifier) {
- field.optional = bool;
- }
- });
- }
- },
- validate: {
-
- form: function(event, ignoreCallbacks) {
- var values = module.get.values();
-
- // input keydown event will fire submit repeatedly by browser default
- if(keyHeldDown) {
- return false;
- }
-
- // reset errors
- formErrors = [];
- if( module.determine.isValid() ) {
- module.debug('Form has no validation errors, submitting');
- module.set.success();
- if(!settings.inline) {
- module.remove.errors();
- }
- if(ignoreCallbacks !== true) {
- return settings.onSuccess.call(element, event, values);
- }
- }
- else {
- module.debug('Form has errors');
- submitting = false;
- module.set.error();
- if(!settings.inline) {
- module.add.errors(formErrors);
- }
- // prevent ajax submit
- if(event && $module.data('moduleApi') !== undefined) {
- event.stopImmediatePropagation();
- }
- if(settings.errorFocus && ignoreCallbacks !== true) {
- var focusElement, hasTabIndex = true;
- if (typeof settings.errorFocus === 'string') {
- focusElement = $(document).find(settings.errorFocus);
- hasTabIndex = focusElement.is('[tabindex]');
- // to be able to focus/scroll into non input elements we need a tabindex
- if (!hasTabIndex) {
- focusElement.attr('tabindex',-1);
- }
- } else {
- focusElement = $group.filter('.' + className.error).first().find(selector.field);
- }
- focusElement.focus();
- // only remove tabindex if it was dynamically created above
- if (!hasTabIndex){
- focusElement.removeAttr('tabindex');
+ return value.split(',').length >= minCount;
+ },
+
+ exactCount: function (value, exactCount) {
+ exactCount = Number(exactCount);
+
+ if (exactCount === 0) {
+ return value === '';
}
- }
- if(ignoreCallbacks !== true) {
- return settings.onFailure.call(element, formErrors, values);
- }
- }
- },
-
- // takes a validation object and returns whether field passes validation
- field: function(field, fieldName, showErrors) {
- showErrors = (showErrors !== undefined)
- ? showErrors
- : true
- ;
- if(typeof field == 'string') {
- module.verbose('Validating field', field);
- fieldName = field;
- field = validation[field];
- }
- var
- identifier = field.identifier || fieldName,
- $field = module.get.field(identifier),
- $dependsField = (field.depends)
- ? module.get.field(field.depends)
- : false,
- fieldValid = true,
- fieldErrors = []
- ;
- if(!field.identifier) {
- module.debug('Using field name as identifier', identifier);
- field.identifier = identifier;
- }
- var isDisabled = !$field.filter(':not(:disabled)').length;
- if(isDisabled) {
- module.debug('Field is disabled. Skipping', identifier);
- }
- else if(field.optional && module.is.blank($field)){
- module.debug('Field is optional and blank. Skipping', identifier);
- }
- else if(field.depends && module.is.empty($dependsField)) {
- module.debug('Field depends on another value that is not present or empty. Skipping', $dependsField);
- }
- else if(field.rules !== undefined) {
- if(showErrors) {
- $field.closest($group).removeClass(className.error);
- }
- $.each(field.rules, function(index, rule) {
- if( module.has.field(identifier)) {
- var invalidFields = module.validate.rule(field, rule,true) || [];
- if (invalidFields.length>0){
- module.debug('Field is invalid', identifier, rule.type);
- fieldErrors.push(module.get.prompt(rule, field));
- fieldValid = false;
- if(showErrors){
- $(invalidFields).closest($group).addClass(className.error);
- }
- }
+ if (exactCount === 1) {
+ return value !== '' && value.search(',') === -1;
}
- });
- }
- if(fieldValid) {
- if(showErrors) {
- module.remove.prompt(identifier, fieldErrors);
- settings.onValid.call($field);
- }
- }
- else {
- if(showErrors) {
- formErrors = formErrors.concat(fieldErrors);
- module.add.prompt(identifier, fieldErrors, true);
- settings.onInvalid.call($field, fieldErrors);
- }
- return false;
- }
- return true;
- },
- // takes validation rule and returns whether field passes rule
- rule: function(field, rule, internal) {
- var
- $field = module.get.field(field.identifier),
- ancillary = module.get.ancillaryValue(rule),
- ruleName = module.get.ruleName(rule),
- ruleFunction = settings.rules[ruleName],
- invalidFields = [],
- isCheckbox = $field.is(selector.checkbox),
- isValid = function(field){
- var value = (isCheckbox ? $(field).filter(':checked').val() : $(field).val());
- // cast to string avoiding encoding special values
- value = (value === undefined || value === '' || value === null)
- ? ''
- : (settings.shouldTrim && rule.shouldTrim !== false) || rule.shouldTrim ? String(value + '').trim() : String(value + '')
- ;
- return ruleFunction.call(field, value, ancillary, $module);
- }
- ;
- if( !$.isFunction(ruleFunction) ) {
- module.error(error.noRule, ruleName);
- return;
- }
- if(isCheckbox) {
- if (!isValid($field)) {
- invalidFields = $field;
- }
- } else {
- $.each($field, function (index, field) {
- if (!isValid(field)) {
- invalidFields.push(field);
- }
- });
- }
- return internal ? invalidFields : !(invalidFields.length>0);
- }
- },
+ return value.split(',').length === exactCount;
+ },
- setting: function(name, value) {
- if( $.isPlainObject(name) ) {
- $.extend(true, settings, name);
- }
- else if(value !== undefined) {
- settings[name] = value;
- }
- else {
- return settings[name];
- }
- },
- internal: function(name, value) {
- if( $.isPlainObject(name) ) {
- $.extend(true, module, name);
- }
- else if(value !== undefined) {
- module[name] = value;
- }
- else {
- return module[name];
- }
- },
- debug: function() {
- if(!settings.silent && settings.debug) {
- if(settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.debug.apply(console, arguments);
- }
- }
- },
- verbose: function() {
- if(!settings.silent && settings.verbose && settings.debug) {
- if(settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.verbose.apply(console, arguments);
- }
- }
- },
- error: function() {
- if(!settings.silent) {
- module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
- module.error.apply(console, arguments);
- }
- },
- performance: {
- log: function(message) {
- var
- currentTime,
- executionTime,
- previousTime
- ;
- if(settings.performance) {
- currentTime = new Date().getTime();
- previousTime = time || currentTime;
- executionTime = currentTime - previousTime;
- time = currentTime;
- performance.push({
- 'Name' : message[0],
- 'Arguments' : [].slice.call(message, 1) || '',
- 'Element' : element,
- 'Execution Time' : executionTime
- });
- }
- clearTimeout(module.performance.timer);
- module.performance.timer = setTimeout(module.performance.display, 500);
- },
- display: function() {
- var
- title = settings.name + ':',
- totalTime = 0
- ;
- time = false;
- clearTimeout(module.performance.timer);
- $.each(performance, function(index, data) {
- totalTime += data['Execution Time'];
- });
- title += ' ' + totalTime + 'ms';
- if(moduleSelector) {
- title += ' \'' + moduleSelector + '\'';
- }
- if($allModules.length > 1) {
- title += ' ' + '(' + $allModules.length + ')';
- }
- if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) {
- console.groupCollapsed(title);
- if(console.table) {
- console.table(performance);
- }
- else {
- $.each(performance, function(index, data) {
- console.log(data['Name'] + ': ' + data['Execution Time']+'ms');
- });
- }
- console.groupEnd();
- }
- performance = [];
- }
- },
- invoke: function(query, passedArguments, context) {
- var
- object = instance,
- maxDepth,
- found,
- response
- ;
- passedArguments = passedArguments || queryArguments;
- context = context || element;
- if(typeof query == 'string' && object !== undefined) {
- query = query.split(/[\. ]/);
- maxDepth = query.length - 1;
- $.each(query, function(depth, value) {
- var camelCaseValue = (depth != maxDepth)
- ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
- : query
- ;
- if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) {
- object = object[camelCaseValue];
- }
- else if( object[camelCaseValue] !== undefined ) {
- found = object[camelCaseValue];
- return false;
- }
- else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) {
- object = object[value];
- }
- else if( object[value] !== undefined ) {
- found = object[value];
- return false;
- }
- else {
- return false;
- }
- });
- }
- if( $.isFunction( found ) ) {
- response = found.apply(context, passedArguments);
- }
- else if(found !== undefined) {
- response = found;
- }
- if(Array.isArray(returnedValue)) {
- returnedValue.push(response);
- }
- else if(returnedValue !== undefined) {
- returnedValue = [returnedValue, response];
- }
- else if(response !== undefined) {
- returnedValue = response;
- }
- return found;
- }
- };
- module.initialize();
- })
- ;
-
- return (returnedValue !== undefined)
- ? returnedValue
- : this
- ;
-};
-
-$.fn.form.settings = {
-
- name : 'Form',
- namespace : 'form',
-
- debug : false,
- verbose : false,
- performance : true,
-
- fields : false,
-
- keyboardShortcuts : true,
- on : 'submit',
- inline : false,
-
- delay : 200,
- revalidate : true,
- shouldTrim : true,
-
- transition : 'scale',
- duration : 200,
-
- autoCheckRequired : false,
- preventLeaving : false,
- errorFocus : true,
- dateHandling : 'date', // 'date', 'input', 'formatter'
-
- onValid : function() {},
- onInvalid : function() {},
- onSuccess : function() { return true; },
- onFailure : function() { return false; },
- onDirty : function() {},
- onClean : function() {},
-
- metadata : {
- defaultValue : 'default',
- validate : 'validate',
- isDirty : 'isDirty'
- },
-
- regExp: {
- htmlID : /^[a-zA-Z][\w:.-]*$/g,
- bracket : /\[(.*)\]/i,
- decimal : /^\d+\.?\d*$/,
- email : /^[a-z0-9!#$%&'*+\/=?^_`{|}~.-]+@[a-z0-9]([a-z0-9-]*[a-z0-9])?(\.[a-z0-9]([a-z0-9-]*[a-z0-9])?)*$/i,
- escape : /[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|:,=@]/g,
- flags : /^\/(.*)\/(.*)?/,
- integer : /^\-?\d+$/,
- number : /^\-?\d*(\.\d+)?$/,
- url : /(https?:\/\/(?:www\.|(?!www))[^\s\.]+\.[^\s]{2,}|www\.[^\s]+\.[^\s]{2,})/i
- },
-
- text: {
- and : 'and',
- unspecifiedRule : 'Please enter a valid value',
- unspecifiedField : 'This field',
- leavingMessage : 'There are unsaved changes on this page which will be discarded if you continue.'
- },
-
- prompt: {
- range : '{name} must be in a range from {min} to {max}',
- maxValue : '{name} must have a maximum value of {ruleValue}',
- minValue : '{name} must have a minimum value of {ruleValue}',
- empty : '{name} must have a value',
- checked : '{name} must be checked',
- email : '{name} must be a valid e-mail',
- url : '{name} must be a valid url',
- regExp : '{name} is not formatted correctly',
- integer : '{name} must be an integer',
- decimal : '{name} must be a decimal number',
- number : '{name} must be set to a number',
- is : '{name} must be "{ruleValue}"',
- isExactly : '{name} must be exactly "{ruleValue}"',
- not : '{name} cannot be set to "{ruleValue}"',
- notExactly : '{name} cannot be set to exactly "{ruleValue}"',
- contain : '{name} must contain "{ruleValue}"',
- containExactly : '{name} must contain exactly "{ruleValue}"',
- doesntContain : '{name} cannot contain "{ruleValue}"',
- doesntContainExactly : '{name} cannot contain exactly "{ruleValue}"',
- minLength : '{name} must be at least {ruleValue} characters',
- exactLength : '{name} must be exactly {ruleValue} characters',
- maxLength : '{name} cannot be longer than {ruleValue} characters',
- match : '{name} must match {ruleValue} field',
- different : '{name} must have a different value than {ruleValue} field',
- creditCard : '{name} must be a valid credit card number',
- minCount : '{name} must have at least {ruleValue} choices',
- exactCount : '{name} must have exactly {ruleValue} choices',
- maxCount : '{name} must have {ruleValue} or less choices'
- },
-
- selector : {
- checkbox : 'input[type="checkbox"], input[type="radio"]',
- clear : '.clear',
- field : 'input:not(.search):not([type="file"]):not([type="reset"]):not([type="button"]):not([type="submit"]), textarea, select',
- group : '.field',
- input : 'input:not([type="file"])',
- message : '.error.message',
- prompt : '.prompt.label',
- radio : 'input[type="radio"]',
- reset : '.reset:not([type="reset"])',
- submit : '.submit:not([type="submit"])',
- uiCheckbox : '.ui.checkbox',
- uiDropdown : '.ui.dropdown',
- uiCalendar : '.ui.calendar'
- },
-
- className : {
- error : 'error',
- label : 'ui basic red pointing prompt label',
- pressed : 'down',
- success : 'success',
- required : 'required',
- disabled : 'disabled'
- },
-
- error: {
- identifier : 'You must specify a string identifier for each field',
- method : 'The method you called is not defined.',
- noRule : 'There is no rule matching the one you specified',
- oldSyntax : 'Starting in 2.0 forms now only take a single settings object. Validation settings converted to new syntax automatically.',
- noField : 'Field identifier {identifier} not found',
- noElement : 'This module requires ui {element}'
- },
-
- templates: {
-
- // template that produces error message
- error: function(errors) {
- var
- html = ''
- ;
- $.each(errors, function(index, value) {
- html += '- ' + value + '
';
- });
- html += '
';
- return html;
- },
-
- // template that produces label content
- prompt: function(errors) {
- if(errors.length === 1){
- return errors[0];
- }
- var
- html = ''
- ;
- $.each(errors, function(index, value) {
- html += '- ' + value + '
';
- });
- html += '
';
- return html;
- }
- },
-
- formatter: {
- date: function(date) {
- return Intl.DateTimeFormat('en-GB').format(date);
- },
- datetime: function(date) {
- return Intl.DateTimeFormat('en-GB', {
- year: "numeric",
- month: "2-digit",
- day: "2-digit",
- hour: '2-digit',
- minute: '2-digit',
- second: '2-digit'
- }).format(date);
- },
- time: function(date) {
- return Intl.DateTimeFormat('en-GB', {
- hour: '2-digit',
- minute: '2-digit',
- second: '2-digit'
- }).format(date);
- },
- month: function(date) {
- return Intl.DateTimeFormat('en-GB', {
- month: '2-digit',
- year: 'numeric'
- }).format(date);
- },
- year: function(date) {
- return Intl.DateTimeFormat('en-GB', {
- year: 'numeric'
- }).format(date);
- }
- },
-
- rules: {
-
- // is not empty or blank string
- empty: function(value) {
- return !(value === undefined || '' === value || Array.isArray(value) && value.length === 0);
- },
-
- // checkbox checked
- checked: function() {
- return ($(this).filter(':checked').length > 0);
- },
-
- // is most likely an email
- email: function(value){
- return $.fn.form.settings.regExp.email.test(value);
- },
-
- // value is most likely url
- url: function(value) {
- return $.fn.form.settings.regExp.url.test(value);
- },
-
- // matches specified regExp
- regExp: function(value, regExp) {
- if(regExp instanceof RegExp) {
- return value.match(regExp);
- }
- var
- regExpParts = regExp.match($.fn.form.settings.regExp.flags),
- flags
- ;
- // regular expression specified as /baz/gi (flags)
- if(regExpParts) {
- regExp = (regExpParts.length >= 2)
- ? regExpParts[1]
- : regExp
- ;
- flags = (regExpParts.length >= 3)
- ? regExpParts[2]
- : ''
- ;
- }
- return value.match( new RegExp(regExp, flags) );
- },
- minValue: function(value, range) {
- return $.fn.form.settings.rules.range(value, range+'..', 'number');
- },
- maxValue: function(value, range) {
- return $.fn.form.settings.rules.range(value, '..'+range, 'number');
- },
- // is valid integer or matches range
- integer: function(value, range) {
- return $.fn.form.settings.rules.range(value, range, 'integer');
- },
- range: function(value, range, regExp) {
- if(typeof regExp == "string") {
- regExp = $.fn.form.settings.regExp[regExp];
- }
- if(!(regExp instanceof RegExp)) {
- regExp = $.fn.form.settings.regExp.integer;
- }
- var
- min,
- max,
- parts
- ;
- if( !range || ['', '..'].indexOf(range) !== -1) {
- // do nothing
- }
- else if(range.indexOf('..') == -1) {
- if(regExp.test(range)) {
- min = max = range - 0;
- }
- }
- else {
- parts = range.split('..', 2);
- if(regExp.test(parts[0])) {
- min = parts[0] - 0;
- }
- if(regExp.test(parts[1])) {
- max = parts[1] - 0;
- }
- }
- return (
- regExp.test(value) &&
- (min === undefined || value >= min) &&
- (max === undefined || value <= max)
- );
- },
-
- // is valid number (with decimal)
- decimal: function(value, range) {
- return $.fn.form.settings.rules.range(value, range, 'decimal');
- },
-
- // is valid number
- number: function(value, range) {
- return $.fn.form.settings.rules.range(value, range, 'number');
- },
-
- // is value (case insensitive)
- is: function(value, text) {
- text = (typeof text == 'string')
- ? text.toLowerCase()
- : text
- ;
- value = (typeof value == 'string')
- ? value.toLowerCase()
- : value
- ;
- return (value == text);
- },
-
- // is value
- isExactly: function(value, text) {
- return (value == text);
- },
-
- // value is not another value (case insensitive)
- not: function(value, notValue) {
- value = (typeof value == 'string')
- ? value.toLowerCase()
- : value
- ;
- notValue = (typeof notValue == 'string')
- ? notValue.toLowerCase()
- : notValue
- ;
- return (value != notValue);
- },
-
- // value is not another value (case sensitive)
- notExactly: function(value, notValue) {
- return (value != notValue);
- },
-
- // value contains text (insensitive)
- contains: function(value, text) {
- // escape regex characters
- text = text.replace($.fn.form.settings.regExp.escape, "\\$&");
- return (value.search( new RegExp(text, 'i') ) !== -1);
- },
-
- // value contains text (case sensitive)
- containsExactly: function(value, text) {
- // escape regex characters
- text = text.replace($.fn.form.settings.regExp.escape, "\\$&");
- return (value.search( new RegExp(text) ) !== -1);
- },
-
- // value contains text (insensitive)
- doesntContain: function(value, text) {
- // escape regex characters
- text = text.replace($.fn.form.settings.regExp.escape, "\\$&");
- return (value.search( new RegExp(text, 'i') ) === -1);
- },
-
- // value contains text (case sensitive)
- doesntContainExactly: function(value, text) {
- // escape regex characters
- text = text.replace($.fn.form.settings.regExp.escape, "\\$&");
- return (value.search( new RegExp(text) ) === -1);
- },
-
- // is at least string length
- minLength: function(value, requiredLength) {
- return (value !== undefined)
- ? (value.length >= requiredLength)
- : false
- ;
- },
-
- // is exactly length
- exactLength: function(value, requiredLength) {
- return (value !== undefined)
- ? (value.length == requiredLength)
- : false
- ;
- },
-
- // is less than length
- maxLength: function(value, maxLength) {
- return (value !== undefined)
- ? (value.length <= maxLength)
- : false
- ;
- },
-
- // matches another field
- match: function(value, identifier, $module) {
- var
- matchingValue,
- matchingElement
- ;
- if((matchingElement = $module.find('[data-validate="'+ identifier +'"]')).length > 0 ) {
- matchingValue = matchingElement.val();
- }
- else if((matchingElement = $module.find('#' + identifier)).length > 0) {
- matchingValue = matchingElement.val();
- }
- else if((matchingElement = $module.find('[name="' + identifier +'"]')).length > 0) {
- matchingValue = matchingElement.val();
- }
- else if((matchingElement = $module.find('[name="' + identifier +'[]"]')).length > 0 ) {
- matchingValue = matchingElement;
- }
- return (matchingValue !== undefined)
- ? ( value.toString() == matchingValue.toString() )
- : false
- ;
- },
-
- // different than another field
- different: function(value, identifier, $module) {
- // use either id or name of field
- var
- matchingValue,
- matchingElement
- ;
- if((matchingElement = $module.find('[data-validate="'+ identifier +'"]')).length > 0 ) {
- matchingValue = matchingElement.val();
- }
- else if((matchingElement = $module.find('#' + identifier)).length > 0) {
- matchingValue = matchingElement.val();
- }
- else if((matchingElement = $module.find('[name="' + identifier +'"]')).length > 0) {
- matchingValue = matchingElement.val();
- }
- else if((matchingElement = $module.find('[name="' + identifier +'[]"]')).length > 0 ) {
- matchingValue = matchingElement;
- }
- return (matchingValue !== undefined)
- ? ( value.toString() !== matchingValue.toString() )
- : false
- ;
- },
-
- creditCard: function(cardNumber, cardTypes) {
- var
- cards = {
- visa: {
- pattern : /^4/,
- length : [16]
- },
- amex: {
- pattern : /^3[47]/,
- length : [15]
- },
- mastercard: {
- pattern : /^5[1-5]/,
- length : [16]
- },
- discover: {
- pattern : /^(6011|622(12[6-9]|1[3-9][0-9]|[2-8][0-9]{2}|9[0-1][0-9]|92[0-5]|64[4-9])|65)/,
- length : [16]
- },
- unionPay: {
- pattern : /^(62|88)/,
- length : [16, 17, 18, 19]
- },
- jcb: {
- pattern : /^35(2[89]|[3-8][0-9])/,
- length : [16]
- },
- maestro: {
- pattern : /^(5018|5020|5038|6304|6759|676[1-3])/,
- length : [12, 13, 14, 15, 16, 17, 18, 19]
- },
- dinersClub: {
- pattern : /^(30[0-5]|^36)/,
- length : [14]
- },
- laser: {
- pattern : /^(6304|670[69]|6771)/,
- length : [16, 17, 18, 19]
- },
- visaElectron: {
- pattern : /^(4026|417500|4508|4844|491(3|7))/,
- length : [16]
- }
- },
- valid = {},
- validCard = false,
- requiredTypes = (typeof cardTypes == 'string')
- ? cardTypes.split(',')
- : false,
- unionPay,
- validation
- ;
-
- if(typeof cardNumber !== 'string' || cardNumber.length === 0) {
- return;
- }
-
- // allow dashes and spaces in card
- cardNumber = cardNumber.replace(/[\s\-]/g, '');
-
- // verify card types
- if(requiredTypes) {
- $.each(requiredTypes, function(index, type){
- // verify each card type
- validation = cards[type];
- if(validation) {
- valid = {
- length : ($.inArray(cardNumber.length, validation.length) !== -1),
- pattern : (cardNumber.search(validation.pattern) !== -1)
- };
- if(valid.length && valid.pattern) {
- validCard = true;
- }
- }
- });
+ maxCount: function (value, maxCount) {
+ maxCount = Number(maxCount);
- if(!validCard) {
- return false;
- }
- }
-
- // skip luhn for UnionPay
- unionPay = {
- number : ($.inArray(cardNumber.length, cards.unionPay.length) !== -1),
- pattern : (cardNumber.search(cards.unionPay.pattern) !== -1)
- };
- if(unionPay.number && unionPay.pattern) {
- return true;
- }
-
- // verify luhn, adapted from
- var
- length = cardNumber.length,
- multiple = 0,
- producedValue = [
- [0, 1, 2, 3, 4, 5, 6, 7, 8, 9],
- [0, 2, 4, 6, 8, 1, 3, 5, 7, 9]
- ],
- sum = 0
- ;
- while (length--) {
- sum += producedValue[multiple][parseInt(cardNumber.charAt(length), 10)];
- multiple ^= 1;
- }
- return (sum % 10 === 0 && sum > 0);
- },
-
- minCount: function(value, minCount) {
- if(minCount == 0) {
- return true;
- }
- if(minCount == 1) {
- return (value !== '');
- }
- return (value.split(',').length >= minCount);
- },
-
- exactCount: function(value, exactCount) {
- if(exactCount == 0) {
- return (value === '');
- }
- if(exactCount == 1) {
- return (value !== '' && value.search(',') === -1);
- }
- return (value.split(',').length == exactCount);
- },
-
- maxCount: function(value, maxCount) {
- if(maxCount == 0) {
- return false;
- }
- if(maxCount == 1) {
- return (value.search(',') === -1);
- }
- return (value.split(',').length <= maxCount);
- }
- }
+ if (maxCount === 0) {
+ return false;
+ }
+ if (maxCount === 1) {
+ return value.search(',') === -1;
+ }
-};
+ return value.split(',').length <= maxCount;
+ },
+ },
-})( jQuery, window, document );
+ };
+})(jQuery, window, document);
diff --git a/definitions/behaviors/state.js b/definitions/behaviors/state.js
index 84cf48a..58d3a88 100644
--- a/definitions/behaviors/state.js
+++ b/definitions/behaviors/state.js
@@ -1,711 +1,692 @@
/*!
* # Fomantic-UI - State
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-;(function ($, window, document, undefined) {
+(function ($, window, document) {
+ 'use strict';
-"use strict";
-
-$.isFunction = $.isFunction || function(obj) {
- return typeof obj === "function" && typeof obj.nodeType !== "number";
-};
-
-window = (typeof window != 'undefined' && window.Math == Math)
- ? window
- : (typeof self != 'undefined' && self.Math == Math)
- ? self
- : Function('return this')()
-;
-
-$.fn.state = function(parameters) {
- var
- $allModules = $(this),
-
- moduleSelector = $allModules.selector || '',
+ function isFunction(obj) {
+ return typeof obj === 'function' && typeof obj.nodeType !== 'number';
+ }
- time = new Date().getTime(),
- performance = [],
+ window = window !== undefined && window.Math === Math
+ ? window
+ : globalThis;
- query = arguments[0],
- methodInvoked = (typeof query == 'string'),
- queryArguments = [].slice.call(arguments, 1),
+ $.fn.state = function (parameters) {
+ var
+ $allModules = $(this),
- returnedValue
- ;
- $allModules
- .each(function() {
- var
- settings = ( $.isPlainObject(parameters) )
- ? $.extend(true, {}, $.fn.state.settings, parameters)
- : $.extend({}, $.fn.state.settings),
+ moduleSelector = $allModules.selector || '',
- error = settings.error,
- metadata = settings.metadata,
- className = settings.className,
- namespace = settings.namespace,
- states = settings.states,
- text = settings.text,
+ time = Date.now(),
+ performance = [],
- eventNamespace = '.' + namespace,
- moduleNamespace = namespace + '-module',
+ query = arguments[0],
+ methodInvoked = typeof query === 'string',
+ queryArguments = [].slice.call(arguments, 1),
- $module = $(this),
+ returnedValue
+ ;
+ $allModules.each(function () {
+ var
+ settings = $.isPlainObject(parameters)
+ ? $.extend(true, {}, $.fn.state.settings, parameters)
+ : $.extend({}, $.fn.state.settings),
- element = this,
- instance = $module.data(moduleNamespace),
+ error = settings.error,
+ metadata = settings.metadata,
+ className = settings.className,
+ namespace = settings.namespace,
+ states = settings.states,
+ text = settings.text,
- module
- ;
- module = {
+ eventNamespace = '.' + namespace,
+ moduleNamespace = namespace + '-module',
- initialize: function() {
- module.verbose('Initializing module');
+ $module = $(this),
- // allow module to guess desired state based on element
- if(settings.automatic) {
- module.add.defaults();
- }
+ element = this,
+ instance = $module.data(moduleNamespace),
- // bind events with delegated events
- if(settings.context && moduleSelector !== '') {
- ([window,document].indexOf(settings.context) < 0 ? $(document).find(settings.context) : $(settings.context))
- .on(moduleSelector, 'mouseenter' + eventNamespace, module.change.text)
- .on(moduleSelector, 'mouseleave' + eventNamespace, module.reset.text)
- .on(moduleSelector, 'click' + eventNamespace, module.toggle.state)
+ module
;
- }
- else {
- $module
- .on('mouseenter' + eventNamespace, module.change.text)
- .on('mouseleave' + eventNamespace, module.reset.text)
- .on('click' + eventNamespace, module.toggle.state)
- ;
- }
- module.instantiate();
- },
-
- instantiate: function() {
- module.verbose('Storing instance of module', module);
- instance = module;
- $module
- .data(moduleNamespace, module)
- ;
- },
-
- destroy: function() {
- module.verbose('Destroying previous module', instance);
- $module
- .off(eventNamespace)
- .removeData(moduleNamespace)
- ;
- },
+ module = {
+
+ initialize: function () {
+ module.verbose('Initializing module');
+
+ // allow module to guess desired state based on element
+ if (settings.automatic) {
+ module.add.defaults();
+ }
+
+ // bind events with delegated events
+ if (settings.context && moduleSelector !== '') {
+ ([window, document].indexOf(settings.context) < 0 ? $(document).find(settings.context) : $(settings.context))
+ .on(moduleSelector, 'mouseenter' + eventNamespace, module.change.text)
+ .on(moduleSelector, 'mouseleave' + eventNamespace, module.reset.text)
+ .on(moduleSelector, 'click' + eventNamespace, module.toggle.state)
+ ;
+ } else {
+ $module
+ .on('mouseenter' + eventNamespace, module.change.text)
+ .on('mouseleave' + eventNamespace, module.reset.text)
+ .on('click' + eventNamespace, module.toggle.state)
+ ;
+ }
+ module.instantiate();
+ },
+
+ instantiate: function () {
+ module.verbose('Storing instance of module', module);
+ instance = module;
+ $module
+ .data(moduleNamespace, module)
+ ;
+ },
+
+ destroy: function () {
+ module.verbose('Destroying previous module', instance);
+ $module
+ .off(eventNamespace)
+ .removeData(moduleNamespace)
+ ;
+ },
+
+ refresh: function () {
+ module.verbose('Refreshing selector cache');
+ $module = $(element);
+ },
+
+ add: {
+ defaults: function () {
+ var
+ userStates = parameters && $.isPlainObject(parameters.states)
+ ? parameters.states
+ : {}
+ ;
+ $.each(settings.defaults, function (type, typeStates) {
+ if (module.is[type] !== undefined && module.is[type]()) {
+ module.verbose('Adding default states', type, element);
+ $.extend(settings.states, typeStates, userStates);
+ }
+ });
+ },
+ },
+
+ is: {
+
+ active: function () {
+ return $module.hasClass(className.active);
+ },
+ loading: function () {
+ return $module.hasClass(className.loading);
+ },
+ inactive: function () {
+ return !$module.hasClass(className.active);
+ },
+ state: function (state) {
+ if (className[state] === undefined) {
+ return false;
+ }
+
+ return $module.hasClass(className[state]);
+ },
+
+ enabled: function () {
+ return !$module.is(settings.filter.active);
+ },
+ disabled: function () {
+ return $module.is(settings.filter.active);
+ },
+ textEnabled: function () {
+ return !$module.is(settings.filter.text);
+ },
+
+ // definitions for automatic type detection
+ button: function () {
+ return $module.is('.button:not(a, .submit)');
+ },
+ input: function () {
+ return $module.is('input');
+ },
+ progress: function () {
+ return $module.is('.ui.progress');
+ },
+ },
+
+ allow: function (state) {
+ module.debug('Now allowing state', state);
+ states[state] = true;
+ },
+ disallow: function (state) {
+ module.debug('No longer allowing', state);
+ states[state] = false;
+ },
+
+ allows: function (state) {
+ return states[state] || false;
+ },
+
+ enable: function () {
+ $module.removeClass(className.disabled);
+ },
+
+ disable: function () {
+ $module.addClass(className.disabled);
+ },
+
+ setState: function (state) {
+ if (module.allows(state)) {
+ $module.addClass(className[state]);
+ }
+ },
+
+ removeState: function (state) {
+ if (module.allows(state)) {
+ $module.removeClass(className[state]);
+ }
+ },
+
+ toggle: {
+ state: function () {
+ var
+ apiRequest,
+ requestCancelled
+ ;
+ if (module.allows('active') && module.is.enabled()) {
+ module.refresh();
+ if ($.fn.api !== undefined) {
+ apiRequest = $module.api('get request');
+ requestCancelled = $module.api('was cancelled');
+ if (requestCancelled) {
+ module.debug('API Request cancelled by beforesend');
+ settings.activateTest = function () {
+ return false;
+ };
+ settings.deactivateTest = function () {
+ return false;
+ };
+ } else if (apiRequest) {
+ module.listenTo(apiRequest);
+
+ return;
+ }
+ }
+ module.change.state();
+ }
+ },
+ },
+
+ listenTo: function (apiRequest) {
+ module.debug('API request detected, waiting for state signal', apiRequest);
+ if (apiRequest) {
+ if (text.loading) {
+ module.update.text(text.loading);
+ }
+ $.when(apiRequest)
+ .then(function () {
+ if (apiRequest.state() === 'resolved') {
+ module.debug('API request succeeded');
+ settings.activateTest = function () {
+ return true;
+ };
+ settings.deactivateTest = function () {
+ return true;
+ };
+ } else {
+ module.debug('API request failed');
+ settings.activateTest = function () {
+ return false;
+ };
+ settings.deactivateTest = function () {
+ return false;
+ };
+ }
+ module.change.state();
+ })
+ ;
+ }
+ },
+
+ // checks whether active/inactive state can be given
+ change: {
+
+ state: function () {
+ module.debug('Determining state change direction');
+ // inactive to active change
+ if (module.is.inactive()) {
+ module.activate();
+ } else {
+ module.deactivate();
+ }
+ if (settings.sync) {
+ module.sync();
+ }
+ settings.onChange.call(element);
+ },
+
+ text: function () {
+ if (module.is.textEnabled()) {
+ if (module.is.disabled()) {
+ module.verbose('Changing text to disabled text', text.hover);
+ module.update.text(text.disabled);
+ } else if (module.is.active()) {
+ if (text.hover) {
+ module.verbose('Changing text to hover text', text.hover);
+ module.update.text(text.hover);
+ } else if (text.deactivate) {
+ module.verbose('Changing text to deactivating text', text.deactivate);
+ module.update.text(text.deactivate);
+ }
+ } else {
+ if (text.hover) {
+ module.verbose('Changing text to hover text', text.hover);
+ module.update.text(text.hover);
+ } else if (text.activate) {
+ module.verbose('Changing text to activating text', text.activate);
+ module.update.text(text.activate);
+ }
+ }
+ }
+ },
+
+ },
+
+ activate: function () {
+ if (settings.activateTest.call(element)) {
+ module.debug('Setting state to active');
+ $module
+ .addClass(className.active)
+ ;
+ module.update.text(text.active);
+ settings.onActivate.call(element);
+ }
+ },
+
+ deactivate: function () {
+ if (settings.deactivateTest.call(element)) {
+ module.debug('Setting state to inactive');
+ $module
+ .removeClass(className.active)
+ ;
+ module.update.text(text.inactive);
+ settings.onDeactivate.call(element);
+ }
+ },
+
+ sync: function () {
+ module.verbose('Syncing other buttons to current state');
+ if (module.is.active()) {
+ $allModules
+ .not($module)
+ .state('activate')
+ ;
+ } else {
+ $allModules
+ .not($module)
+ .state('deactivate')
+ ;
+ }
+ },
+
+ get: {
+ text: function () {
+ return settings.selector.text
+ ? $module.find(settings.selector.text).text()
+ : $module.html();
+ },
+ textFor: function (state) {
+ return text[state] || false;
+ },
+ },
+
+ flash: {
+ text: function (text, duration, callback) {
+ var
+ previousText = module.get.text();
+ module.debug('Flashing text message', text, duration);
+ text = text || settings.text.flash;
+ duration = duration || settings.flashDuration;
+ callback = callback || function () {};
+ module.update.text(text);
+ setTimeout(function () {
+ module.update.text(previousText);
+ callback.call(element);
+ }, duration);
+ },
+ },
+
+ reset: {
+ // on mouseout sets text to previous value
+ text: function () {
+ var
+ activeText = text.active || $module.data(metadata.storedText),
+ inactiveText = text.inactive || $module.data(metadata.storedText)
+ ;
+ if (module.is.textEnabled()) {
+ if (module.is.active() && activeText) {
+ module.verbose('Resetting active text', activeText);
+ module.update.text(activeText);
+ } else if (inactiveText) {
+ module.verbose('Resetting inactive text', activeText);
+ module.update.text(inactiveText);
+ }
+ }
+ },
+ },
+
+ update: {
+ text: function (text) {
+ var
+ currentText = module.get.text();
+ if (text && text !== currentText) {
+ module.debug('Updating text', text);
+ if (settings.selector.text) {
+ $module
+ .data(metadata.storedText, text)
+ .find(settings.selector.text)
+ .text(text)
+ ;
+ } else {
+ $module
+ .data(metadata.storedText, text)
+ .html(text)
+ ;
+ }
+ } else {
+ module.debug('Text is already set, ignoring update', text);
+ }
+ },
+ },
+
+ setting: function (name, value) {
+ module.debug('Changing setting', name, value);
+ if ($.isPlainObject(name)) {
+ $.extend(true, settings, name);
+ } else if (value !== undefined) {
+ if ($.isPlainObject(settings[name])) {
+ $.extend(true, settings[name], value);
+ } else {
+ settings[name] = value;
+ }
+ } else {
+ return settings[name];
+ }
+ },
+ internal: function (name, value) {
+ if ($.isPlainObject(name)) {
+ $.extend(true, module, name);
+ } else if (value !== undefined) {
+ module[name] = value;
+ } else {
+ return module[name];
+ }
+ },
+ debug: function () {
+ if (!settings.silent && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.debug.apply(console, arguments);
+ }
+ }
+ },
+ verbose: function () {
+ if (!settings.silent && settings.verbose && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.verbose.apply(console, arguments);
+ }
+ }
+ },
+ error: function () {
+ if (!settings.silent) {
+ module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
+ module.error.apply(console, arguments);
+ }
+ },
+ performance: {
+ log: function (message) {
+ var
+ currentTime,
+ executionTime,
+ previousTime
+ ;
+ if (settings.performance) {
+ currentTime = Date.now();
+ previousTime = time || currentTime;
+ executionTime = currentTime - previousTime;
+ time = currentTime;
+ performance.push({
+ Name: message[0],
+ Arguments: [].slice.call(message, 1) || '',
+ Element: element,
+ 'Execution Time': executionTime,
+ });
+ }
+ clearTimeout(module.performance.timer);
+ module.performance.timer = setTimeout(module.performance.display, 500);
+ },
+ display: function () {
+ var
+ title = settings.name + ':',
+ totalTime = 0
+ ;
+ time = false;
+ clearTimeout(module.performance.timer);
+ $.each(performance, function (index, data) {
+ totalTime += data['Execution Time'];
+ });
+ title += ' ' + totalTime + 'ms';
+ if (moduleSelector) {
+ title += ' \'' + moduleSelector + '\'';
+ }
+ if (performance.length > 0) {
+ console.groupCollapsed(title);
+ if (console.table) {
+ console.table(performance);
+ } else {
+ $.each(performance, function (index, data) {
+ console.log(data.Name + ': ' + data['Execution Time'] + 'ms');
+ });
+ }
+ console.groupEnd();
+ }
+ performance = [];
+ },
+ },
+ invoke: function (query, passedArguments, context) {
+ var
+ object = instance,
+ maxDepth,
+ found,
+ response
+ ;
+ passedArguments = passedArguments || queryArguments;
+ context = context || element;
+ if (typeof query === 'string' && object !== undefined) {
+ query = query.split(/[ .]/);
+ maxDepth = query.length - 1;
+ $.each(query, function (depth, value) {
+ var camelCaseValue = depth !== maxDepth
+ ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
+ : query
+ ;
+ if ($.isPlainObject(object[camelCaseValue]) && (depth !== maxDepth)) {
+ object = object[camelCaseValue];
+ } else if (object[camelCaseValue] !== undefined) {
+ found = object[camelCaseValue];
+
+ return false;
+ } else if ($.isPlainObject(object[value]) && (depth !== maxDepth)) {
+ object = object[value];
+ } else if (object[value] !== undefined) {
+ found = object[value];
+
+ return false;
+ } else {
+ module.error(error.method, query);
+
+ return false;
+ }
+ });
+ }
+ if (isFunction(found)) {
+ response = found.apply(context, passedArguments);
+ } else if (found !== undefined) {
+ response = found;
+ }
+ if (Array.isArray(returnedValue)) {
+ returnedValue.push(response);
+ } else if (returnedValue !== undefined) {
+ returnedValue = [returnedValue, response];
+ } else if (response !== undefined) {
+ returnedValue = response;
+ }
+
+ return found;
+ },
+ };
+
+ if (methodInvoked) {
+ if (instance === undefined) {
+ module.initialize();
+ }
+ module.invoke(query);
+ } else {
+ if (instance !== undefined) {
+ instance.invoke('destroy');
+ }
+ module.initialize();
+ }
+ });
- refresh: function() {
- module.verbose('Refreshing selector cache');
- $module = $(element);
- },
+ return returnedValue !== undefined
+ ? returnedValue
+ : this;
+ };
- add: {
- defaults: function() {
- var
- userStates = parameters && $.isPlainObject(parameters.states)
- ? parameters.states
- : {}
- ;
- $.each(settings.defaults, function(type, typeStates) {
- if( module.is[type] !== undefined && module.is[type]() ) {
- module.verbose('Adding default states', type, element);
- $.extend(settings.states, typeStates, userStates);
- }
- });
- }
- },
+ $.fn.state.settings = {
- is: {
-
- active: function() {
- return $module.hasClass(className.active);
- },
- loading: function() {
- return $module.hasClass(className.loading);
- },
- inactive: function() {
- return !( $module.hasClass(className.active) );
- },
- state: function(state) {
- if(className[state] === undefined) {
- return false;
- }
- return $module.hasClass( className[state] );
- },
-
- enabled: function() {
- return !( $module.is(settings.filter.active) );
- },
- disabled: function() {
- return ( $module.is(settings.filter.active) );
- },
- textEnabled: function() {
- return !( $module.is(settings.filter.text) );
- },
-
- // definitions for automatic type detection
- button: function() {
- return $module.is('.button:not(a, .submit)');
- },
- input: function() {
- return $module.is('input');
- },
- progress: function() {
- return $module.is('.ui.progress');
- }
- },
+ // module info
+ name: 'State',
- allow: function(state) {
- module.debug('Now allowing state', state);
- states[state] = true;
- },
- disallow: function(state) {
- module.debug('No longer allowing', state);
- states[state] = false;
- },
+ // debug output
+ debug: false,
- allows: function(state) {
- return states[state] || false;
- },
+ // verbose debug output
+ verbose: false,
- enable: function() {
- $module.removeClass(className.disabled);
- },
+ // namespace for events
+ namespace: 'state',
- disable: function() {
- $module.addClass(className.disabled);
- },
+ // debug data includes performance
+ performance: true,
- setState: function(state) {
- if(module.allows(state)) {
- $module.addClass( className[state] );
- }
- },
+ // callback occurs on state change
+ onActivate: function () {},
+ onDeactivate: function () {},
+ onChange: function () {},
- removeState: function(state) {
- if(module.allows(state)) {
- $module.removeClass( className[state] );
- }
+ // state test functions
+ activateTest: function () {
+ return true;
},
-
- toggle: {
- state: function() {
- var
- apiRequest,
- requestCancelled
- ;
- if( module.allows('active') && module.is.enabled() ) {
- module.refresh();
- if($.fn.api !== undefined) {
- apiRequest = $module.api('get request');
- requestCancelled = $module.api('was cancelled');
- if( requestCancelled ) {
- module.debug('API Request cancelled by beforesend');
- settings.activateTest = function(){ return false; };
- settings.deactivateTest = function(){ return false; };
- }
- else if(apiRequest) {
- module.listenTo(apiRequest);
- return;
- }
- }
- module.change.state();
- }
- }
+ deactivateTest: function () {
+ return true;
},
- listenTo: function(apiRequest) {
- module.debug('API request detected, waiting for state signal', apiRequest);
- if(apiRequest) {
- if(text.loading) {
- module.update.text(text.loading);
- }
- $.when(apiRequest)
- .then(function() {
- if(apiRequest.state() == 'resolved') {
- module.debug('API request succeeded');
- settings.activateTest = function(){ return true; };
- settings.deactivateTest = function(){ return true; };
- }
- else {
- module.debug('API request failed');
- settings.activateTest = function(){ return false; };
- settings.deactivateTest = function(){ return false; };
- }
- module.change.state();
- })
- ;
- }
- },
+ // whether to automatically map default states
+ automatic: true,
- // checks whether active/inactive state can be given
- change: {
+ // activate / deactivate changes all elements instantiated at same time
+ sync: false,
- state: function() {
- module.debug('Determining state change direction');
- // inactive to active change
- if( module.is.inactive() ) {
- module.activate();
- }
- else {
- module.deactivate();
- }
- if(settings.sync) {
- module.sync();
- }
- settings.onChange.call(element);
- },
-
- text: function() {
- if( module.is.textEnabled() ) {
- if(module.is.disabled() ) {
- module.verbose('Changing text to disabled text', text.hover);
- module.update.text(text.disabled);
- }
- else if( module.is.active() ) {
- if(text.hover) {
- module.verbose('Changing text to hover text', text.hover);
- module.update.text(text.hover);
- }
- else if(text.deactivate) {
- module.verbose('Changing text to deactivating text', text.deactivate);
- module.update.text(text.deactivate);
- }
- }
- else {
- if(text.hover) {
- module.verbose('Changing text to hover text', text.hover);
- module.update.text(text.hover);
- }
- else if(text.activate){
- module.verbose('Changing text to activating text', text.activate);
- module.update.text(text.activate);
- }
- }
- }
- }
+ // default flash text duration, used for temporarily changing text of an element
+ flashDuration: 1000,
+ // selector filter
+ filter: {
+ text: '.loading, .disabled',
+ active: '.disabled',
},
- activate: function() {
- if( settings.activateTest.call(element) ) {
- module.debug('Setting state to active');
- $module
- .addClass(className.active)
- ;
- module.update.text(text.active);
- settings.onActivate.call(element);
- }
- },
+ context: false,
- deactivate: function() {
- if( settings.deactivateTest.call(element) ) {
- module.debug('Setting state to inactive');
- $module
- .removeClass(className.active)
- ;
- module.update.text(text.inactive);
- settings.onDeactivate.call(element);
- }
+ // error
+ error: {
+ method: 'The method you called is not defined.',
},
- sync: function() {
- module.verbose('Syncing other buttons to current state');
- if( module.is.active() ) {
- $allModules
- .not($module)
- .state('activate');
- }
- else {
- $allModules
- .not($module)
- .state('deactivate')
- ;
- }
+ // metadata
+ metadata: {
+ promise: 'promise',
+ storedText: 'stored-text',
},
- get: {
- text: function() {
- return (settings.selector.text)
- ? $module.find(settings.selector.text).text()
- : $module.html()
- ;
- },
- textFor: function(state) {
- return text[state] || false;
- }
+ // change class on state
+ className: {
+ active: 'active',
+ disabled: 'disabled',
+ error: 'error',
+ loading: 'loading',
+ success: 'success',
+ warning: 'warning',
},
- flash: {
- text: function(text, duration, callback) {
- var
- previousText = module.get.text()
- ;
- module.debug('Flashing text message', text, duration);
- text = text || settings.text.flash;
- duration = duration || settings.flashDuration;
- callback = callback || function() {};
- module.update.text(text);
- setTimeout(function(){
- module.update.text(previousText);
- callback.call(element);
- }, duration);
- }
+ selector: {
+ // selector for text node
+ text: false,
},
- reset: {
- // on mouseout sets text to previous value
- text: function() {
- var
- activeText = text.active || $module.data(metadata.storedText),
- inactiveText = text.inactive || $module.data(metadata.storedText)
- ;
- if( module.is.textEnabled() ) {
- if( module.is.active() && activeText) {
- module.verbose('Resetting active text', activeText);
- module.update.text(activeText);
- }
- else if(inactiveText) {
- module.verbose('Resetting inactive text', activeText);
- module.update.text(inactiveText);
- }
- }
- }
+ defaults: {
+ input: {
+ disabled: true,
+ loading: true,
+ active: true,
+ },
+ button: {
+ disabled: true,
+ loading: true,
+ active: true,
+ },
+ progress: {
+ active: true,
+ success: true,
+ warning: true,
+ error: true,
+ },
},
- update: {
- text: function(text) {
- var
- currentText = module.get.text()
- ;
- if(text && text !== currentText) {
- module.debug('Updating text', text);
- if(settings.selector.text) {
- $module
- .data(metadata.storedText, text)
- .find(settings.selector.text)
- .text(text)
- ;
- }
- else {
- $module
- .data(metadata.storedText, text)
- .html(text)
- ;
- }
- }
- else {
- module.debug('Text is already set, ignoring update', text);
- }
- }
+ states: {
+ active: true,
+ disabled: true,
+ error: true,
+ loading: true,
+ success: true,
+ warning: true,
},
- setting: function(name, value) {
- module.debug('Changing setting', name, value);
- if( $.isPlainObject(name) ) {
- $.extend(true, settings, name);
- }
- else if(value !== undefined) {
- if($.isPlainObject(settings[name])) {
- $.extend(true, settings[name], value);
- }
- else {
- settings[name] = value;
- }
- }
- else {
- return settings[name];
- }
- },
- internal: function(name, value) {
- if( $.isPlainObject(name) ) {
- $.extend(true, module, name);
- }
- else if(value !== undefined) {
- module[name] = value;
- }
- else {
- return module[name];
- }
+ text: {
+ disabled: false,
+ flash: false,
+ hover: false,
+ active: false,
+ inactive: false,
+ activate: false,
+ deactivate: false,
},
- debug: function() {
- if(!settings.silent && settings.debug) {
- if(settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.debug.apply(console, arguments);
- }
- }
- },
- verbose: function() {
- if(!settings.silent && settings.verbose && settings.debug) {
- if(settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.verbose.apply(console, arguments);
- }
- }
- },
- error: function() {
- if(!settings.silent) {
- module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
- module.error.apply(console, arguments);
- }
- },
- performance: {
- log: function(message) {
- var
- currentTime,
- executionTime,
- previousTime
- ;
- if(settings.performance) {
- currentTime = new Date().getTime();
- previousTime = time || currentTime;
- executionTime = currentTime - previousTime;
- time = currentTime;
- performance.push({
- 'Name' : message[0],
- 'Arguments' : [].slice.call(message, 1) || '',
- 'Element' : element,
- 'Execution Time' : executionTime
- });
- }
- clearTimeout(module.performance.timer);
- module.performance.timer = setTimeout(module.performance.display, 500);
- },
- display: function() {
- var
- title = settings.name + ':',
- totalTime = 0
- ;
- time = false;
- clearTimeout(module.performance.timer);
- $.each(performance, function(index, data) {
- totalTime += data['Execution Time'];
- });
- title += ' ' + totalTime + 'ms';
- if(moduleSelector) {
- title += ' \'' + moduleSelector + '\'';
- }
- if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) {
- console.groupCollapsed(title);
- if(console.table) {
- console.table(performance);
- }
- else {
- $.each(performance, function(index, data) {
- console.log(data['Name'] + ': ' + data['Execution Time']+'ms');
- });
- }
- console.groupEnd();
- }
- performance = [];
- }
- },
- invoke: function(query, passedArguments, context) {
- var
- object = instance,
- maxDepth,
- found,
- response
- ;
- passedArguments = passedArguments || queryArguments;
- context = context || element;
- if(typeof query == 'string' && object !== undefined) {
- query = query.split(/[\. ]/);
- maxDepth = query.length - 1;
- $.each(query, function(depth, value) {
- var camelCaseValue = (depth != maxDepth)
- ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
- : query
- ;
- if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) {
- object = object[camelCaseValue];
- }
- else if( object[camelCaseValue] !== undefined ) {
- found = object[camelCaseValue];
- return false;
- }
- else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) {
- object = object[value];
- }
- else if( object[value] !== undefined ) {
- found = object[value];
- return false;
- }
- else {
- module.error(error.method, query);
- return false;
- }
- });
- }
- if ( $.isFunction( found ) ) {
- response = found.apply(context, passedArguments);
- }
- else if(found !== undefined) {
- response = found;
- }
- if(Array.isArray(returnedValue)) {
- returnedValue.push(response);
- }
- else if(returnedValue !== undefined) {
- returnedValue = [returnedValue, response];
- }
- else if(response !== undefined) {
- returnedValue = response;
- }
- return found;
- }
- };
-
- if(methodInvoked) {
- if(instance === undefined) {
- module.initialize();
- }
- module.invoke(query);
- }
- else {
- if(instance !== undefined) {
- instance.invoke('destroy');
- }
- module.initialize();
- }
- })
- ;
-
- return (returnedValue !== undefined)
- ? returnedValue
- : this
- ;
-};
-
-$.fn.state.settings = {
-
- // module info
- name : 'State',
-
- // debug output
- debug : false,
-
- // verbose debug output
- verbose : false,
-
- // namespace for events
- namespace : 'state',
-
- // debug data includes performance
- performance : true,
-
- // callback occurs on state change
- onActivate : function() {},
- onDeactivate : function() {},
- onChange : function() {},
-
- // state test functions
- activateTest : function() { return true; },
- deactivateTest : function() { return true; },
-
- // whether to automatically map default states
- automatic : true,
-
- // activate / deactivate changes all elements instantiated at same time
- sync : false,
-
- // default flash text duration, used for temporarily changing text of an element
- flashDuration : 1000,
-
- // selector filter
- filter : {
- text : '.loading, .disabled',
- active : '.disabled'
- },
-
- context : false,
-
- // error
- error: {
- beforeSend : 'The before send function has cancelled state change',
- method : 'The method you called is not defined.'
- },
-
- // metadata
- metadata: {
- promise : 'promise',
- storedText : 'stored-text'
- },
-
- // change class on state
- className: {
- active : 'active',
- disabled : 'disabled',
- error : 'error',
- loading : 'loading',
- success : 'success',
- warning : 'warning'
- },
-
- selector: {
- // selector for text node
- text: false
- },
-
- defaults : {
- input: {
- disabled : true,
- loading : true,
- active : true
- },
- button: {
- disabled : true,
- loading : true,
- active : true,
- },
- progress: {
- active : true,
- success : true,
- warning : true,
- error : true
- }
- },
-
- states : {
- active : true,
- disabled : true,
- error : true,
- loading : true,
- success : true,
- warning : true
- },
-
- text : {
- disabled : false,
- flash : false,
- hover : false,
- active : false,
- inactive : false,
- activate : false,
- deactivate : false
- }
-
-};
-
-
-})( jQuery, window, document );
+ };
+})(jQuery, window, document);
diff --git a/definitions/behaviors/visibility.js b/definitions/behaviors/visibility.js
index 32defce..ec67324 100644
--- a/definitions/behaviors/visibility.js
+++ b/definitions/behaviors/visibility.js
@@ -1,1313 +1,1281 @@
/*!
* # Fomantic-UI - Visibility
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-;(function ($, window, document, undefined) {
+(function ($, window, document) {
+ 'use strict';
-'use strict';
+ function isFunction(obj) {
+ return typeof obj === 'function' && typeof obj.nodeType !== 'number';
+ }
-$.isFunction = $.isFunction || function(obj) {
- return typeof obj === "function" && typeof obj.nodeType !== "number";
-};
+ window = window !== undefined && window.Math === Math
+ ? window
+ : globalThis;
-window = (typeof window != 'undefined' && window.Math == Math)
- ? window
- : (typeof self != 'undefined' && self.Math == Math)
- ? self
- : Function('return this')()
-;
+ $.fn.visibility = function (parameters) {
+ var
+ $allModules = $(this),
+ moduleSelector = $allModules.selector || '',
-$.fn.visibility = function(parameters) {
- var
- $allModules = $(this),
- moduleSelector = $allModules.selector || '',
+ time = Date.now(),
+ performance = [],
- time = new Date().getTime(),
- performance = [],
+ query = arguments[0],
+ methodInvoked = typeof query === 'string',
+ queryArguments = [].slice.call(arguments, 1),
+ returnedValue,
- query = arguments[0],
- methodInvoked = (typeof query == 'string'),
- queryArguments = [].slice.call(arguments, 1),
- returnedValue,
+ moduleCount = $allModules.length,
+ loadedCount = 0
+ ;
- moduleCount = $allModules.length,
- loadedCount = 0
- ;
-
- $allModules
- .each(function() {
- var
- settings = ( $.isPlainObject(parameters) )
- ? $.extend(true, {}, $.fn.visibility.settings, parameters)
- : $.extend({}, $.fn.visibility.settings),
-
- className = settings.className,
- namespace = settings.namespace,
- error = settings.error,
- metadata = settings.metadata,
-
- eventNamespace = '.' + namespace,
- moduleNamespace = 'module-' + namespace,
-
- $window = $(window),
-
- $module = $(this),
- $context = [window,document].indexOf(settings.context) < 0 ? $(document).find(settings.context) : $(settings.context),
-
- $placeholder,
-
- instance = $module.data(moduleNamespace),
-
- requestAnimationFrame = window.requestAnimationFrame
- || window.mozRequestAnimationFrame
- || window.webkitRequestAnimationFrame
- || window.msRequestAnimationFrame
- || function(callback) { setTimeout(callback, 0); },
+ $allModules.each(function () {
+ var
+ settings = $.isPlainObject(parameters)
+ ? $.extend(true, {}, $.fn.visibility.settings, parameters)
+ : $.extend({}, $.fn.visibility.settings),
- element = this,
- disabled = false,
+ className = settings.className,
+ namespace = settings.namespace,
+ error = settings.error,
+ metadata = settings.metadata,
- contextObserver,
- observer,
- module
- ;
+ eventNamespace = '.' + namespace,
+ moduleNamespace = 'module-' + namespace,
- module = {
+ $window = $(window),
- initialize: function() {
- module.debug('Initializing', settings);
+ $module = $(this),
+ $context = [window, document].indexOf(settings.context) < 0 ? $(document).find(settings.context) : $(settings.context),
- module.setup.cache();
+ $placeholder,
- if( module.should.trackChanges() ) {
+ instance = $module.data(moduleNamespace),
- if(settings.type == 'image') {
- module.setup.image();
- }
- if(settings.type == 'fixed') {
- module.setup.fixed();
- }
-
- if(settings.observeChanges) {
- module.observeChanges();
- }
- module.bind.events();
- }
-
- module.save.position();
- if( !module.is.visible() ) {
- module.error(error.visible, $module);
- }
-
- if(settings.initialCheck) {
- module.checkVisibility();
- }
- module.instantiate();
- },
+ element = this,
+ disabled = false,
- instantiate: function() {
- module.debug('Storing instance', module);
- $module
- .data(moduleNamespace, module)
- ;
- instance = module;
- },
-
- destroy: function() {
- module.verbose('Destroying previous module');
- if(observer) {
- observer.disconnect();
- }
- if(contextObserver) {
- contextObserver.disconnect();
- }
- $window
- .off('load' + eventNamespace, module.event.load)
- .off('resize' + eventNamespace, module.event.resize)
- ;
- $context
- .off('scroll' + eventNamespace, module.event.scroll)
- .off('scrollchange' + eventNamespace, module.event.scrollchange)
- ;
- if(settings.type == 'fixed') {
- module.resetFixed();
- module.remove.placeholder();
- }
- $module
- .off(eventNamespace)
- .removeData(moduleNamespace)
- ;
- },
-
- observeChanges: function() {
- if('MutationObserver' in window) {
- contextObserver = new MutationObserver(module.event.contextChanged);
- observer = new MutationObserver(module.event.changed);
- contextObserver.observe(document, {
- childList : true,
- subtree : true
- });
- observer.observe(element, {
- childList : true,
- subtree : true
- });
- module.debug('Setting up mutation observer', observer);
- }
- },
-
- bind: {
- events: function() {
- module.verbose('Binding visibility events to scroll and resize');
- if(settings.refreshOnLoad) {
- $window
- .on('load' + eventNamespace, module.event.load)
- ;
- }
- $window
- .on('resize' + eventNamespace, module.event.resize)
+ contextObserver,
+ observer,
+ module
;
- // pub/sub pattern
- $context
- .off('scroll' + eventNamespace)
- .on('scroll' + eventNamespace, module.event.scroll)
- .on('scrollchange' + eventNamespace, module.event.scrollchange)
- ;
- }
- },
- event: {
- changed: function(mutations) {
- module.verbose('DOM tree modified, updating visibility calculations');
- module.timer = setTimeout(function() {
- module.verbose('DOM tree modified, updating sticky menu');
- module.refresh();
- }, 100);
- },
- contextChanged: function(mutations) {
- [].forEach.call(mutations, function(mutation) {
- if(mutation.removedNodes) {
- [].forEach.call(mutation.removedNodes, function(node) {
- if(node == element || $(node).find(element).length > 0) {
- module.debug('Element removed from DOM, tearing down events');
- module.destroy();
- }
- });
- }
- });
- },
- resize: function() {
- module.debug('Window resized');
- if(settings.refreshOnResize) {
- requestAnimationFrame(module.refresh);
- }
- },
- load: function() {
- module.debug('Page finished loading');
- requestAnimationFrame(module.refresh);
- },
- // publishes scrollchange event on one scroll
- scroll: function() {
- if(settings.throttle) {
- clearTimeout(module.timer);
- module.timer = setTimeout(function() {
- $context.triggerHandler('scrollchange' + eventNamespace, [ $context.scrollTop() ]);
- }, settings.throttle);
- }
- else {
- requestAnimationFrame(function() {
- $context.triggerHandler('scrollchange' + eventNamespace, [ $context.scrollTop() ]);
- });
- }
- },
- // subscribes to scrollchange
- scrollchange: function(event, scrollPosition) {
- module.checkVisibility(scrollPosition);
- },
- },
+ module = {
- precache: function(images, callback) {
- if (!(images instanceof Array)) {
- images = [images];
- }
- var
- imagesLength = images.length,
- loadedCounter = 0,
- cache = [],
- cacheImage = document.createElement('img'),
- handleLoad = function() {
- loadedCounter++;
- if (loadedCounter >= images.length) {
- if ($.isFunction(callback)) {
- callback();
- }
- }
- }
- ;
- while (imagesLength--) {
- cacheImage = document.createElement('img');
- cacheImage.onload = handleLoad;
- cacheImage.onerror = handleLoad;
- cacheImage.src = images[imagesLength];
- cache.push(cacheImage);
- }
- },
+ initialize: function () {
+ module.debug('Initializing', settings);
- enableCallbacks: function() {
- module.debug('Allowing callbacks to occur');
- disabled = false;
- },
+ module.setup.cache();
- disableCallbacks: function() {
- module.debug('Disabling all callbacks temporarily');
- disabled = true;
- },
+ if (module.should.trackChanges()) {
+ if (settings.type === 'image') {
+ module.setup.image();
+ }
+ if (settings.type === 'fixed') {
+ module.setup.fixed();
+ }
- should: {
- trackChanges: function() {
- if(methodInvoked) {
- module.debug('One time query, no need to bind events');
- return false;
- }
- module.debug('Callbacks being attached');
- return true;
- }
- },
+ if (settings.observeChanges) {
+ module.observeChanges();
+ }
+ module.bind.events();
+ }
- setup: {
- cache: function() {
- module.cache = {
- occurred : {},
- screen : {},
- element : {},
- };
- },
- image: function() {
- var
- src = $module.data(metadata.src)
- ;
- if(src) {
- module.verbose('Lazy loading image', src);
- settings.once = true;
- settings.observeChanges = false;
-
- // show when top visible
- settings.onOnScreen = function() {
- module.debug('Image on screen', element);
- module.precache(src, function() {
- module.set.image(src, function() {
- loadedCount++;
- if(loadedCount == moduleCount) {
- settings.onAllLoaded.call(this);
+ module.save.position();
+ if (!module.is.visible()) {
+ module.error(error.visible, $module);
}
- settings.onLoad.call(this);
- });
- });
- };
- }
- },
- fixed: function() {
- module.debug('Setting up fixed');
- settings.once = false;
- settings.observeChanges = false;
- settings.initialCheck = true;
- settings.refreshOnLoad = true;
- if(!parameters.transition) {
- settings.transition = false;
- }
- module.create.placeholder();
- module.debug('Added placeholder', $placeholder);
- settings.onTopPassed = function() {
- module.debug('Element passed, adding fixed position', $module);
- module.show.placeholder();
- module.set.fixed();
- if(settings.transition) {
- if($.fn.transition !== undefined) {
- $module.transition(settings.transition, settings.duration);
- }
- }
- };
- settings.onTopPassedReverse = function() {
- module.debug('Element returned to position, removing fixed', $module);
- module.hide.placeholder();
- module.remove.fixed();
- };
- }
- },
- create: {
- placeholder: function() {
- module.verbose('Creating fixed position placeholder');
- $placeholder = $module
- .clone(false)
- .css('display', 'none')
- .addClass(className.placeholder)
- .insertAfter($module)
- ;
- }
- },
+ if (settings.initialCheck) {
+ module.checkVisibility();
+ }
+ module.instantiate();
+ },
+
+ instantiate: function () {
+ module.debug('Storing instance', module);
+ $module
+ .data(moduleNamespace, module)
+ ;
+ instance = module;
+ },
+
+ destroy: function () {
+ module.verbose('Destroying previous module');
+ if (observer) {
+ observer.disconnect();
+ }
+ if (contextObserver) {
+ contextObserver.disconnect();
+ }
+ $window
+ .off('load' + eventNamespace, module.event.load)
+ .off('resize' + eventNamespace, module.event.resize)
+ ;
+ $context
+ .off('scroll' + eventNamespace, module.event.scroll)
+ .off('scrollchange' + eventNamespace, module.event.scrollchange)
+ ;
+ if (settings.type === 'fixed') {
+ module.resetFixed();
+ module.remove.placeholder();
+ }
+ $module
+ .off(eventNamespace)
+ .removeData(moduleNamespace)
+ ;
+ },
+
+ observeChanges: function () {
+ if ('MutationObserver' in window) {
+ contextObserver = new MutationObserver(module.event.contextChanged);
+ observer = new MutationObserver(module.event.changed);
+ contextObserver.observe(document, {
+ childList: true,
+ subtree: true,
+ });
+ observer.observe(element, {
+ childList: true,
+ subtree: true,
+ });
+ module.debug('Setting up mutation observer', observer);
+ }
+ },
+
+ bind: {
+ events: function () {
+ module.verbose('Binding visibility events to scroll and resize');
+ if (settings.refreshOnLoad) {
+ $window
+ .on('load' + eventNamespace, module.event.load)
+ ;
+ }
+ $window
+ .on('resize' + eventNamespace, module.event.resize)
+ ;
+ // pub/sub pattern
+ $context
+ .off('scroll' + eventNamespace)
+ .on('scroll' + eventNamespace, module.event.scroll)
+ .on('scrollchange' + eventNamespace, module.event.scrollchange)
+ ;
+ },
+ },
+
+ event: {
+ changed: function (mutations) {
+ module.verbose('DOM tree modified, updating visibility calculations');
+ module.timer = setTimeout(function () {
+ module.verbose('DOM tree modified, updating sticky menu');
+ module.refresh();
+ }, 100);
+ },
+ contextChanged: function (mutations) {
+ [].forEach.call(mutations, function (mutation) {
+ if (mutation.removedNodes) {
+ [].forEach.call(mutation.removedNodes, function (node) {
+ if (node === element || $(node).find(element).length > 0) {
+ module.debug('Element removed from DOM, tearing down events');
+ module.destroy();
+ }
+ });
+ }
+ });
+ },
+ resize: function () {
+ module.debug('Window resized');
+ if (settings.refreshOnResize) {
+ requestAnimationFrame(module.refresh);
+ }
+ },
+ load: function () {
+ module.debug('Page finished loading');
+ requestAnimationFrame(module.refresh);
+ },
+ // publishes scrollchange event on one scroll
+ scroll: function () {
+ if (settings.throttle) {
+ clearTimeout(module.timer);
+ module.timer = setTimeout(function () {
+ $context.triggerHandler('scrollchange' + eventNamespace, [$context.scrollTop()]);
+ }, settings.throttle);
+ } else {
+ requestAnimationFrame(function () {
+ $context.triggerHandler('scrollchange' + eventNamespace, [$context.scrollTop()]);
+ });
+ }
+ },
+ // subscribes to scrollchange
+ scrollchange: function (event, scrollPosition) {
+ module.checkVisibility(scrollPosition);
+ },
+ },
+
+ precache: function (images, callback) {
+ if (!Array.isArray(images)) {
+ images = [images];
+ }
+ var
+ imagesLength = images.length,
+ loadedCounter = 0,
+ cache = [],
+ cacheImage = document.createElement('img'),
+ handleLoad = function () {
+ loadedCounter++;
+ if (loadedCounter >= images.length) {
+ if (isFunction(callback)) {
+ callback();
+ }
+ }
+ }
+ ;
+ while (imagesLength--) {
+ cacheImage = document.createElement('img');
+ cacheImage.addEventListener('load', handleLoad);
+ cacheImage.addEventListener('error', handleLoad);
+ cacheImage.src = images[imagesLength];
+ cache.push(cacheImage);
+ }
+ },
+
+ enableCallbacks: function () {
+ module.debug('Allowing callbacks to occur');
+ disabled = false;
+ },
+
+ disableCallbacks: function () {
+ module.debug('Disabling all callbacks temporarily');
+ disabled = true;
+ },
+
+ should: {
+ trackChanges: function () {
+ if (methodInvoked) {
+ module.debug('One time query, no need to bind events');
+
+ return false;
+ }
+ module.debug('Callbacks being attached');
+
+ return true;
+ },
+ },
+
+ setup: {
+ cache: function () {
+ module.cache = {
+ occurred: {},
+ screen: {},
+ element: {},
+ };
+ },
+ image: function () {
+ var
+ src = $module.data(metadata.src)
+ ;
+ if (src) {
+ module.verbose('Lazy loading image', src);
+ settings.once = true;
+ settings.observeChanges = false;
+
+ // show when top visible
+ settings.onOnScreen = function () {
+ module.debug('Image on screen', element);
+ module.precache(src, function () {
+ module.set.image(src, function () {
+ loadedCount++;
+ if (loadedCount === moduleCount) {
+ settings.onAllLoaded.call(this);
+ }
+ settings.onLoad.call(this);
+ });
+ });
+ };
+ }
+ },
+ fixed: function () {
+ module.debug('Setting up fixed');
+ settings.once = false;
+ settings.observeChanges = false;
+ settings.initialCheck = true;
+ settings.refreshOnLoad = true;
+ if (!parameters.transition) {
+ settings.transition = false;
+ }
+ module.create.placeholder();
+ module.debug('Added placeholder', $placeholder);
+ settings.onTopPassed = function () {
+ module.debug('Element passed, adding fixed position', $module);
+ module.show.placeholder();
+ module.set.fixed();
+ if (settings.transition) {
+ if ($.fn.transition !== undefined) {
+ $module.transition(settings.transition, settings.duration);
+ }
+ }
+ };
+ settings.onTopPassedReverse = function () {
+ module.debug('Element returned to position, removing fixed', $module);
+ module.hide.placeholder();
+ module.remove.fixed();
+ };
+ },
+ },
+
+ create: {
+ placeholder: function () {
+ module.verbose('Creating fixed position placeholder');
+ $placeholder = $module
+ .clone(false)
+ .css('display', 'none')
+ .addClass(className.placeholder)
+ .insertAfter($module)
+ ;
+ },
+ },
+
+ show: {
+ placeholder: function () {
+ module.verbose('Showing placeholder');
+ $placeholder
+ .css('display', 'block')
+ .css('visibility', 'hidden')
+ ;
+ },
+ },
+ hide: {
+ placeholder: function () {
+ module.verbose('Hiding placeholder');
+ $placeholder
+ .css('display', 'none')
+ .css('visibility', '')
+ ;
+ },
+ },
+
+ set: {
+ fixed: function () {
+ module.verbose('Setting element to fixed position');
+ $module
+ .addClass(className.fixed)
+ .css({
+ position: 'fixed',
+ top: settings.offset + 'px',
+ left: 'auto',
+ zIndex: settings.zIndex,
+ })
+ ;
+ settings.onFixed.call(element);
+ },
+ image: function (src, callback) {
+ $module
+ .attr('src', src)
+ ;
+ if (settings.transition) {
+ if ($.fn.transition !== undefined) {
+ if ($module.hasClass(className.visible)) {
+ module.debug('Transition already occurred on this image, skipping animation');
+
+ return;
+ }
+ $module.transition(settings.transition, settings.duration, callback);
+ } else {
+ $module.fadeIn(settings.duration, callback);
+ }
+ } else {
+ $module.show();
+ }
+ },
+ },
+
+ is: {
+ onScreen: function () {
+ var
+ calculations = module.get.elementCalculations()
+ ;
+
+ return calculations.onScreen;
+ },
+ offScreen: function () {
+ var
+ calculations = module.get.elementCalculations()
+ ;
+
+ return calculations.offScreen;
+ },
+ visible: function () {
+ if (module.cache && module.cache.element) {
+ return !(module.cache.element.width === 0 && module.cache.element.offset.top === 0);
+ }
+
+ return false;
+ },
+ verticallyScrollableContext: function () {
+ var
+ overflowY = $context[0] !== window
+ ? $context.css('overflow-y')
+ : false
+ ;
+
+ return overflowY === 'auto' || overflowY === 'scroll';
+ },
+ horizontallyScrollableContext: function () {
+ var
+ overflowX = $context[0] !== window
+ ? $context.css('overflow-x')
+ : false
+ ;
+
+ return overflowX === 'auto' || overflowX === 'scroll';
+ },
+ },
+
+ refresh: function () {
+ module.debug('Refreshing constants (width/height)');
+ if (settings.type === 'fixed') {
+ module.resetFixed();
+ }
+ module.reset();
+ module.save.position();
+ if (settings.checkOnRefresh) {
+ module.checkVisibility();
+ }
+ settings.onRefresh.call(element);
+ },
+
+ resetFixed: function () {
+ module.remove.fixed();
+ module.remove.occurred();
+ },
+
+ reset: function () {
+ module.verbose('Resetting all cached values');
+ if ($.isPlainObject(module.cache)) {
+ module.cache.screen = {};
+ module.cache.element = {};
+ }
+ },
+
+ checkVisibility: function (scroll) {
+ module.verbose('Checking visibility of element', module.cache.element);
+
+ if (!disabled && module.is.visible()) {
+ // save scroll position
+ module.save.scroll(scroll);
+
+ // update calculations derived from scroll
+ module.save.calculations();
+
+ // percentage
+ module.passed();
+
+ // reverse (must be first)
+ module.passingReverse();
+ module.topVisibleReverse();
+ module.bottomVisibleReverse();
+ module.topPassedReverse();
+ module.bottomPassedReverse();
+
+ // one time
+ module.onScreen();
+ module.offScreen();
+ module.passing();
+ module.topVisible();
+ module.bottomVisible();
+ module.topPassed();
+ module.bottomPassed();
+
+ // on update callback
+ if (settings.onUpdate) {
+ settings.onUpdate.call(element, module.get.elementCalculations());
+ }
+ }
+ },
+
+ passed: function (amount, newCallback) {
+ var
+ calculations = module.get.elementCalculations()
+ ;
+ // assign callback
+ if (amount && newCallback) {
+ settings.onPassed[amount] = newCallback;
+ } else if (amount !== undefined) {
+ return module.get.pixelsPassed(amount) > calculations.pixelsPassed;
+ } else if (calculations.passing) {
+ $.each(settings.onPassed, function (amount, callback) {
+ if (calculations.bottomVisible || calculations.pixelsPassed > module.get.pixelsPassed(amount)) {
+ module.execute(callback, amount);
+ } else if (!settings.once) {
+ module.remove.occurred(callback);
+ }
+ });
+ }
+ },
+
+ onScreen: function (newCallback) {
+ var
+ calculations = module.get.elementCalculations(),
+ callback = newCallback || settings.onOnScreen,
+ callbackName = 'onScreen'
+ ;
+ if (newCallback) {
+ module.debug('Adding callback for onScreen', newCallback);
+ settings.onOnScreen = newCallback;
+ }
+ if (calculations.onScreen) {
+ module.execute(callback, callbackName);
+ } else if (!settings.once) {
+ module.remove.occurred(callbackName);
+ }
+ if (newCallback !== undefined) {
+ return calculations.onOnScreen;
+ }
+ },
+
+ offScreen: function (newCallback) {
+ var
+ calculations = module.get.elementCalculations(),
+ callback = newCallback || settings.onOffScreen,
+ callbackName = 'offScreen'
+ ;
+ if (newCallback) {
+ module.debug('Adding callback for offScreen', newCallback);
+ settings.onOffScreen = newCallback;
+ }
+ if (calculations.offScreen) {
+ module.execute(callback, callbackName);
+ } else if (!settings.once) {
+ module.remove.occurred(callbackName);
+ }
+ if (newCallback !== undefined) {
+ return calculations.onOffScreen;
+ }
+ },
+
+ passing: function (newCallback) {
+ var
+ calculations = module.get.elementCalculations(),
+ callback = newCallback || settings.onPassing,
+ callbackName = 'passing'
+ ;
+ if (newCallback) {
+ module.debug('Adding callback for passing', newCallback);
+ settings.onPassing = newCallback;
+ }
+ if (calculations.passing) {
+ module.execute(callback, callbackName);
+ } else if (!settings.once) {
+ module.remove.occurred(callbackName);
+ }
+ if (newCallback !== undefined) {
+ return calculations.passing;
+ }
+ },
+
+ topVisible: function (newCallback) {
+ var
+ calculations = module.get.elementCalculations(),
+ callback = newCallback || settings.onTopVisible,
+ callbackName = 'topVisible'
+ ;
+ if (newCallback) {
+ module.debug('Adding callback for top visible', newCallback);
+ settings.onTopVisible = newCallback;
+ }
+ if (calculations.topVisible) {
+ module.execute(callback, callbackName);
+ } else if (!settings.once) {
+ module.remove.occurred(callbackName);
+ }
+ if (newCallback === undefined) {
+ return calculations.topVisible;
+ }
+ },
+
+ bottomVisible: function (newCallback) {
+ var
+ calculations = module.get.elementCalculations(),
+ callback = newCallback || settings.onBottomVisible,
+ callbackName = 'bottomVisible'
+ ;
+ if (newCallback) {
+ module.debug('Adding callback for bottom visible', newCallback);
+ settings.onBottomVisible = newCallback;
+ }
+ if (calculations.bottomVisible) {
+ module.execute(callback, callbackName);
+ } else if (!settings.once) {
+ module.remove.occurred(callbackName);
+ }
+ if (newCallback === undefined) {
+ return calculations.bottomVisible;
+ }
+ },
+
+ topPassed: function (newCallback) {
+ var
+ calculations = module.get.elementCalculations(),
+ callback = newCallback || settings.onTopPassed,
+ callbackName = 'topPassed'
+ ;
+ if (newCallback) {
+ module.debug('Adding callback for top passed', newCallback);
+ settings.onTopPassed = newCallback;
+ }
+ if (calculations.topPassed) {
+ module.execute(callback, callbackName);
+ } else if (!settings.once) {
+ module.remove.occurred(callbackName);
+ }
+ if (newCallback === undefined) {
+ return calculations.topPassed;
+ }
+ },
+
+ bottomPassed: function (newCallback) {
+ var
+ calculations = module.get.elementCalculations(),
+ callback = newCallback || settings.onBottomPassed,
+ callbackName = 'bottomPassed'
+ ;
+ if (newCallback) {
+ module.debug('Adding callback for bottom passed', newCallback);
+ settings.onBottomPassed = newCallback;
+ }
+ if (calculations.bottomPassed) {
+ module.execute(callback, callbackName);
+ } else if (!settings.once) {
+ module.remove.occurred(callbackName);
+ }
+ if (newCallback === undefined) {
+ return calculations.bottomPassed;
+ }
+ },
+
+ passingReverse: function (newCallback) {
+ var
+ calculations = module.get.elementCalculations(),
+ callback = newCallback || settings.onPassingReverse,
+ callbackName = 'passingReverse'
+ ;
+ if (newCallback) {
+ module.debug('Adding callback for passing reverse', newCallback);
+ settings.onPassingReverse = newCallback;
+ }
+ if (!calculations.passing) {
+ if (module.get.occurred('passing')) {
+ module.execute(callback, callbackName);
+ }
+ } else if (!settings.once) {
+ module.remove.occurred(callbackName);
+ }
+ if (newCallback !== undefined) {
+ return !calculations.passing;
+ }
+ },
+
+ topVisibleReverse: function (newCallback) {
+ var
+ calculations = module.get.elementCalculations(),
+ callback = newCallback || settings.onTopVisibleReverse,
+ callbackName = 'topVisibleReverse'
+ ;
+ if (newCallback) {
+ module.debug('Adding callback for top visible reverse', newCallback);
+ settings.onTopVisibleReverse = newCallback;
+ }
+ if (!calculations.topVisible) {
+ if (module.get.occurred('topVisible')) {
+ module.execute(callback, callbackName);
+ }
+ } else if (!settings.once) {
+ module.remove.occurred(callbackName);
+ }
+ if (newCallback === undefined) {
+ return !calculations.topVisible;
+ }
+ },
+
+ bottomVisibleReverse: function (newCallback) {
+ var
+ calculations = module.get.elementCalculations(),
+ callback = newCallback || settings.onBottomVisibleReverse,
+ callbackName = 'bottomVisibleReverse'
+ ;
+ if (newCallback) {
+ module.debug('Adding callback for bottom visible reverse', newCallback);
+ settings.onBottomVisibleReverse = newCallback;
+ }
+ if (!calculations.bottomVisible) {
+ if (module.get.occurred('bottomVisible')) {
+ module.execute(callback, callbackName);
+ }
+ } else if (!settings.once) {
+ module.remove.occurred(callbackName);
+ }
+ if (newCallback === undefined) {
+ return !calculations.bottomVisible;
+ }
+ },
+
+ topPassedReverse: function (newCallback) {
+ var
+ calculations = module.get.elementCalculations(),
+ callback = newCallback || settings.onTopPassedReverse,
+ callbackName = 'topPassedReverse'
+ ;
+ if (newCallback) {
+ module.debug('Adding callback for top passed reverse', newCallback);
+ settings.onTopPassedReverse = newCallback;
+ }
+ if (!calculations.topPassed) {
+ if (module.get.occurred('topPassed')) {
+ module.execute(callback, callbackName);
+ }
+ } else if (!settings.once) {
+ module.remove.occurred(callbackName);
+ }
+ if (newCallback === undefined) {
+ return !calculations.onTopPassed;
+ }
+ },
+
+ bottomPassedReverse: function (newCallback) {
+ var
+ calculations = module.get.elementCalculations(),
+ callback = newCallback || settings.onBottomPassedReverse,
+ callbackName = 'bottomPassedReverse'
+ ;
+ if (newCallback) {
+ module.debug('Adding callback for bottom passed reverse', newCallback);
+ settings.onBottomPassedReverse = newCallback;
+ }
+ if (!calculations.bottomPassed) {
+ if (module.get.occurred('bottomPassed')) {
+ module.execute(callback, callbackName);
+ }
+ } else if (!settings.once) {
+ module.remove.occurred(callbackName);
+ }
+ if (newCallback === undefined) {
+ return !calculations.bottomPassed;
+ }
+ },
+
+ execute: function (callback, callbackName) {
+ var
+ calculations = module.get.elementCalculations(),
+ screen = module.get.screenCalculations()
+ ;
+ callback = callback || false;
+ if (callback) {
+ if (settings.continuous) {
+ module.debug('Callback being called continuously', callbackName, calculations);
+ callback.call(element, calculations, screen);
+ } else if (!module.get.occurred(callbackName)) {
+ module.debug('Conditions met', callbackName, calculations);
+ callback.call(element, calculations, screen);
+ }
+ }
+ module.save.occurred(callbackName);
+ },
+
+ remove: {
+ fixed: function () {
+ module.debug('Removing fixed position');
+ $module
+ .removeClass(className.fixed)
+ .css({
+ position: '',
+ top: '',
+ left: '',
+ zIndex: '',
+ })
+ ;
+ settings.onUnfixed.call(element);
+ },
+ placeholder: function () {
+ module.debug('Removing placeholder content');
+ if ($placeholder) {
+ $placeholder.remove();
+ }
+ },
+ occurred: function (callback) {
+ if (callback) {
+ var
+ occurred = module.cache.occurred
+ ;
+ if (occurred[callback] !== undefined && occurred[callback] === true) {
+ module.debug('Callback can now be called again', callback);
+ module.cache.occurred[callback] = false;
+ }
+ } else {
+ module.cache.occurred = {};
+ }
+ },
+ },
+
+ save: {
+ calculations: function () {
+ module.verbose('Saving all calculations necessary to determine positioning');
+ module.save.direction();
+ module.save.screenCalculations();
+ module.save.elementCalculations();
+ },
+ occurred: function (callback) {
+ if (callback) {
+ if (module.cache.occurred[callback] === undefined || (module.cache.occurred[callback] !== true)) {
+ module.verbose('Saving callback occurred', callback);
+ module.cache.occurred[callback] = true;
+ }
+ }
+ },
+ scroll: function (scrollPosition) {
+ scrollPosition = scrollPosition + settings.offset || $context.scrollTop() + settings.offset;
+ module.cache.scroll = scrollPosition;
+ },
+ direction: function () {
+ var
+ scroll = module.get.scroll(),
+ lastScroll = module.get.lastScroll(),
+ direction
+ ;
+ if (scroll > lastScroll && lastScroll) {
+ direction = 'down';
+ } else if (scroll < lastScroll && lastScroll) {
+ direction = 'up';
+ } else {
+ direction = 'static';
+ }
+ module.cache.direction = direction;
+
+ return module.cache.direction;
+ },
+ elementPosition: function () {
+ var
+ element = module.cache.element,
+ screen = module.get.screenSize()
+ ;
+ module.verbose('Saving element position');
+ // (quicker than $.extend)
+ element.fits = element.height < screen.height;
+ element.offset = $module.offset();
+ element.width = $module.outerWidth();
+ element.height = $module.outerHeight();
+ // compensate for scroll in context
+ if (module.is.verticallyScrollableContext()) {
+ element.offset.top += $context.scrollTop() - $context.offset().top;
+ }
+ if (module.is.horizontallyScrollableContext()) {
+ element.offset.left += $context.scrollLeft() - $context.offset().left;
+ }
+ // store
+ module.cache.element = element;
+
+ return element;
+ },
+ elementCalculations: function () {
+ var
+ screen = module.get.screenCalculations(),
+ element = module.get.elementPosition()
+ ;
+ // offset
+ if (settings.includeMargin) {
+ element.margin = {};
+ element.margin.top = parseInt($module.css('margin-top'), 10);
+ element.margin.bottom = parseInt($module.css('margin-bottom'), 10);
+ element.top = element.offset.top - element.margin.top;
+ element.bottom = element.offset.top + element.height + element.margin.bottom;
+ } else {
+ element.top = element.offset.top;
+ element.bottom = element.offset.top + element.height;
+ }
+
+ // visibility
+ element.topPassed = screen.top >= element.top;
+ element.bottomPassed = screen.top >= element.bottom;
+ element.topVisible = (screen.bottom >= element.top) && !element.topPassed;
+ element.bottomVisible = (screen.bottom >= element.bottom) && !element.bottomPassed;
+ element.pixelsPassed = 0;
+ element.percentagePassed = 0;
+
+ // meta calculations
+ element.onScreen = (element.topVisible || element.passing) && !element.bottomPassed;
+ element.passing = element.topPassed && !element.bottomPassed;
+ element.offScreen = !element.onScreen;
+
+ // passing calculations
+ if (element.passing) {
+ element.pixelsPassed = screen.top - element.top;
+ element.percentagePassed = (screen.top - element.top) / element.height;
+ }
+ module.cache.element = element;
+ module.verbose('Updated element calculations', element);
+
+ return element;
+ },
+ screenCalculations: function () {
+ var
+ scroll = module.get.scroll()
+ ;
+ module.save.direction();
+ module.cache.screen.top = scroll;
+ module.cache.screen.bottom = scroll + module.cache.screen.height;
+
+ return module.cache.screen;
+ },
+ screenSize: function () {
+ module.verbose('Saving window position');
+ module.cache.screen = {
+ height: $context.height(),
+ };
+ },
+ position: function () {
+ module.save.screenSize();
+ module.save.elementPosition();
+ },
+ },
+
+ get: {
+ pixelsPassed: function (amount) {
+ var
+ element = module.get.elementCalculations()
+ ;
+ if (amount.search('%') > -1) {
+ return element.height * (parseInt(amount, 10) / 100);
+ }
+
+ return parseInt(amount, 10);
+ },
+ occurred: function (callback) {
+ return module.cache.occurred !== undefined
+ ? module.cache.occurred[callback] || false
+ : false;
+ },
+ direction: function () {
+ if (module.cache.direction === undefined) {
+ module.save.direction();
+ }
+
+ return module.cache.direction;
+ },
+ elementPosition: function () {
+ if (module.cache.element === undefined) {
+ module.save.elementPosition();
+ }
+
+ return module.cache.element;
+ },
+ elementCalculations: function () {
+ if (module.cache.element === undefined) {
+ module.save.elementCalculations();
+ }
+
+ return module.cache.element;
+ },
+ screenCalculations: function () {
+ if (module.cache.screen === undefined) {
+ module.save.screenCalculations();
+ }
+
+ return module.cache.screen;
+ },
+ screenSize: function () {
+ if (module.cache.screen === undefined) {
+ module.save.screenSize();
+ }
+
+ return module.cache.screen;
+ },
+ scroll: function () {
+ if (module.cache.scroll === undefined) {
+ module.save.scroll();
+ }
+
+ return module.cache.scroll;
+ },
+ lastScroll: function () {
+ if (module.cache.screen === undefined) {
+ module.debug('First scroll event, no last scroll could be found');
+
+ return false;
+ }
+
+ return module.cache.screen.top;
+ },
+ },
+
+ setting: function (name, value) {
+ if ($.isPlainObject(name)) {
+ $.extend(true, settings, name);
+ } else if (value !== undefined) {
+ settings[name] = value;
+ } else {
+ return settings[name];
+ }
+ },
+ internal: function (name, value) {
+ if ($.isPlainObject(name)) {
+ $.extend(true, module, name);
+ } else if (value !== undefined) {
+ module[name] = value;
+ } else {
+ return module[name];
+ }
+ },
+ debug: function () {
+ if (!settings.silent && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.debug.apply(console, arguments);
+ }
+ }
+ },
+ verbose: function () {
+ if (!settings.silent && settings.verbose && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.verbose.apply(console, arguments);
+ }
+ }
+ },
+ error: function () {
+ if (!settings.silent) {
+ module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
+ module.error.apply(console, arguments);
+ }
+ },
+ performance: {
+ log: function (message) {
+ var
+ currentTime,
+ executionTime,
+ previousTime
+ ;
+ if (settings.performance) {
+ currentTime = Date.now();
+ previousTime = time || currentTime;
+ executionTime = currentTime - previousTime;
+ time = currentTime;
+ performance.push({
+ Name: message[0],
+ Arguments: [].slice.call(message, 1) || '',
+ Element: element,
+ 'Execution Time': executionTime,
+ });
+ }
+ clearTimeout(module.performance.timer);
+ module.performance.timer = setTimeout(module.performance.display, 500);
+ },
+ display: function () {
+ var
+ title = settings.name + ':',
+ totalTime = 0
+ ;
+ time = false;
+ clearTimeout(module.performance.timer);
+ $.each(performance, function (index, data) {
+ totalTime += data['Execution Time'];
+ });
+ title += ' ' + totalTime + 'ms';
+ if (moduleSelector) {
+ title += ' \'' + moduleSelector + '\'';
+ }
+ if (performance.length > 0) {
+ console.groupCollapsed(title);
+ if (console.table) {
+ console.table(performance);
+ } else {
+ $.each(performance, function (index, data) {
+ console.log(data.Name + ': ' + data['Execution Time'] + 'ms');
+ });
+ }
+ console.groupEnd();
+ }
+ performance = [];
+ },
+ },
+ invoke: function (query, passedArguments, context) {
+ var
+ object = instance,
+ maxDepth,
+ found,
+ response
+ ;
+ passedArguments = passedArguments || queryArguments;
+ context = context || element;
+ if (typeof query === 'string' && object !== undefined) {
+ query = query.split(/[ .]/);
+ maxDepth = query.length - 1;
+ $.each(query, function (depth, value) {
+ var camelCaseValue = depth !== maxDepth
+ ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
+ : query
+ ;
+ if ($.isPlainObject(object[camelCaseValue]) && (depth !== maxDepth)) {
+ object = object[camelCaseValue];
+ } else if (object[camelCaseValue] !== undefined) {
+ found = object[camelCaseValue];
+
+ return false;
+ } else if ($.isPlainObject(object[value]) && (depth !== maxDepth)) {
+ object = object[value];
+ } else if (object[value] !== undefined) {
+ found = object[value];
+
+ return false;
+ } else {
+ module.error(error.method, query);
+
+ return false;
+ }
+ });
+ }
+ if (isFunction(found)) {
+ response = found.apply(context, passedArguments);
+ } else if (found !== undefined) {
+ response = found;
+ }
+ if (Array.isArray(returnedValue)) {
+ returnedValue.push(response);
+ } else if (returnedValue !== undefined) {
+ returnedValue = [returnedValue, response];
+ } else if (response !== undefined) {
+ returnedValue = response;
+ }
- show: {
- placeholder: function() {
- module.verbose('Showing placeholder');
- $placeholder
- .css('display', 'block')
- .css('visibility', 'hidden')
- ;
- }
- },
- hide: {
- placeholder: function() {
- module.verbose('Hiding placeholder');
- $placeholder
- .css('display', 'none')
- .css('visibility', '')
- ;
- }
- },
+ return found;
+ },
+ };
- set: {
- fixed: function() {
- module.verbose('Setting element to fixed position');
- $module
- .addClass(className.fixed)
- .css({
- position : 'fixed',
- top : settings.offset + 'px',
- left : 'auto',
- zIndex : settings.zIndex
- })
- ;
- settings.onFixed.call(element);
- },
- image: function(src, callback) {
- $module
- .attr('src', src)
- ;
- if(settings.transition) {
- if( $.fn.transition !== undefined) {
- if($module.hasClass(className.visible)) {
- module.debug('Transition already occurred on this image, skipping animation');
- return;
+ if (methodInvoked) {
+ if (instance === undefined) {
+ module.initialize();
}
- $module.transition(settings.transition, settings.duration, callback);
- }
- else {
- $module.fadeIn(settings.duration, callback);
- }
- }
- else {
- $module.show();
- }
- }
- },
-
- is: {
- onScreen: function() {
- var
- calculations = module.get.elementCalculations()
- ;
- return calculations.onScreen;
- },
- offScreen: function() {
- var
- calculations = module.get.elementCalculations()
- ;
- return calculations.offScreen;
- },
- visible: function() {
- if(module.cache && module.cache.element) {
- return !(module.cache.element.width === 0 && module.cache.element.offset.top === 0);
+ instance.save.scroll();
+ instance.save.calculations();
+ module.invoke(query);
+ } else {
+ if (instance !== undefined) {
+ instance.invoke('destroy');
+ }
+ module.initialize();
}
- return false;
- },
- verticallyScrollableContext: function() {
- var
- overflowY = ($context[0] !== window)
- ? $context.css('overflow-y')
- : false
- ;
- return (overflowY == 'auto' || overflowY == 'scroll');
- },
- horizontallyScrollableContext: function() {
- var
- overflowX = ($context[0] !== window)
- ? $context.css('overflow-x')
- : false
- ;
- return (overflowX == 'auto' || overflowX == 'scroll');
- }
- },
-
- refresh: function() {
- module.debug('Refreshing constants (width/height)');
- if(settings.type == 'fixed') {
- module.resetFixed();
- }
- module.reset();
- module.save.position();
- if(settings.checkOnRefresh) {
- module.checkVisibility();
- }
- settings.onRefresh.call(element);
- },
-
- resetFixed: function () {
- module.remove.fixed();
- module.remove.occurred();
- },
-
- reset: function() {
- module.verbose('Resetting all cached values');
- if( $.isPlainObject(module.cache) ) {
- module.cache.screen = {};
- module.cache.element = {};
- }
- },
-
- checkVisibility: function(scroll) {
- module.verbose('Checking visibility of element', module.cache.element);
+ });
- if( !disabled && module.is.visible() ) {
+ return returnedValue !== undefined
+ ? returnedValue
+ : this;
+ };
- // save scroll position
- module.save.scroll(scroll);
+ $.fn.visibility.settings = {
- // update calculations derived from scroll
- module.save.calculations();
+ name: 'Visibility',
+ namespace: 'visibility',
- // percentage
- module.passed();
+ debug: false,
+ verbose: false,
+ performance: true,
- // reverse (must be first)
- module.passingReverse();
- module.topVisibleReverse();
- module.bottomVisibleReverse();
- module.topPassedReverse();
- module.bottomPassedReverse();
+ // whether to use mutation observers to follow changes
+ observeChanges: true,
- // one time
- module.onScreen();
- module.offScreen();
- module.passing();
- module.topVisible();
- module.bottomVisible();
- module.topPassed();
- module.bottomPassed();
+ // check position immediately on init
+ initialCheck: true,
- // on update callback
- if(settings.onUpdate) {
- settings.onUpdate.call(element, module.get.elementCalculations());
- }
- }
- },
+ // whether to refresh calculations after all page images load
+ refreshOnLoad: true,
- passed: function(amount, newCallback) {
- var
- calculations = module.get.elementCalculations()
- ;
- // assign callback
- if(amount && newCallback) {
- settings.onPassed[amount] = newCallback;
- }
- else if(amount !== undefined) {
- return (module.get.pixelsPassed(amount) > calculations.pixelsPassed);
- }
- else if(calculations.passing) {
- $.each(settings.onPassed, function(amount, callback) {
- if(calculations.bottomVisible || calculations.pixelsPassed > module.get.pixelsPassed(amount)) {
- module.execute(callback, amount);
- }
- else if(!settings.once) {
- module.remove.occurred(callback);
- }
- });
- }
- },
+ // whether to refresh calculations after page resize event
+ refreshOnResize: true,
- onScreen: function(newCallback) {
- var
- calculations = module.get.elementCalculations(),
- callback = newCallback || settings.onOnScreen,
- callbackName = 'onScreen'
- ;
- if(newCallback) {
- module.debug('Adding callback for onScreen', newCallback);
- settings.onOnScreen = newCallback;
- }
- if(calculations.onScreen) {
- module.execute(callback, callbackName);
- }
- else if(!settings.once) {
- module.remove.occurred(callbackName);
- }
- if(newCallback !== undefined) {
- return calculations.onOnScreen;
- }
- },
+ // should call callbacks on refresh event (resize, etc)
+ checkOnRefresh: true,
- offScreen: function(newCallback) {
- var
- calculations = module.get.elementCalculations(),
- callback = newCallback || settings.onOffScreen,
- callbackName = 'offScreen'
- ;
- if(newCallback) {
- module.debug('Adding callback for offScreen', newCallback);
- settings.onOffScreen = newCallback;
- }
- if(calculations.offScreen) {
- module.execute(callback, callbackName);
- }
- else if(!settings.once) {
- module.remove.occurred(callbackName);
- }
- if(newCallback !== undefined) {
- return calculations.onOffScreen;
- }
- },
+ // callback should only occur one time
+ once: true,
- passing: function(newCallback) {
- var
- calculations = module.get.elementCalculations(),
- callback = newCallback || settings.onPassing,
- callbackName = 'passing'
- ;
- if(newCallback) {
- module.debug('Adding callback for passing', newCallback);
- settings.onPassing = newCallback;
- }
- if(calculations.passing) {
- module.execute(callback, callbackName);
- }
- else if(!settings.once) {
- module.remove.occurred(callbackName);
- }
- if(newCallback !== undefined) {
- return calculations.passing;
- }
- },
+ // callback should fire continuously when evaluates to true
+ continuous: false,
+ // offset to use with scroll top
+ offset: 0,
- topVisible: function(newCallback) {
- var
- calculations = module.get.elementCalculations(),
- callback = newCallback || settings.onTopVisible,
- callbackName = 'topVisible'
- ;
- if(newCallback) {
- module.debug('Adding callback for top visible', newCallback);
- settings.onTopVisible = newCallback;
- }
- if(calculations.topVisible) {
- module.execute(callback, callbackName);
- }
- else if(!settings.once) {
- module.remove.occurred(callbackName);
- }
- if(newCallback === undefined) {
- return calculations.topVisible;
- }
- },
+ // whether to include margin in elements position
+ includeMargin: false,
- bottomVisible: function(newCallback) {
- var
- calculations = module.get.elementCalculations(),
- callback = newCallback || settings.onBottomVisible,
- callbackName = 'bottomVisible'
- ;
- if(newCallback) {
- module.debug('Adding callback for bottom visible', newCallback);
- settings.onBottomVisible = newCallback;
- }
- if(calculations.bottomVisible) {
- module.execute(callback, callbackName);
- }
- else if(!settings.once) {
- module.remove.occurred(callbackName);
- }
- if(newCallback === undefined) {
- return calculations.bottomVisible;
- }
- },
-
- topPassed: function(newCallback) {
- var
- calculations = module.get.elementCalculations(),
- callback = newCallback || settings.onTopPassed,
- callbackName = 'topPassed'
- ;
- if(newCallback) {
- module.debug('Adding callback for top passed', newCallback);
- settings.onTopPassed = newCallback;
- }
- if(calculations.topPassed) {
- module.execute(callback, callbackName);
- }
- else if(!settings.once) {
- module.remove.occurred(callbackName);
- }
- if(newCallback === undefined) {
- return calculations.topPassed;
- }
- },
+ // scroll context for visibility checks
+ context: window,
- bottomPassed: function(newCallback) {
- var
- calculations = module.get.elementCalculations(),
- callback = newCallback || settings.onBottomPassed,
- callbackName = 'bottomPassed'
- ;
- if(newCallback) {
- module.debug('Adding callback for bottom passed', newCallback);
- settings.onBottomPassed = newCallback;
- }
- if(calculations.bottomPassed) {
- module.execute(callback, callbackName);
- }
- else if(!settings.once) {
- module.remove.occurred(callbackName);
- }
- if(newCallback === undefined) {
- return calculations.bottomPassed;
- }
- },
+ // visibility check delay in ms (defaults to animationFrame)
+ throttle: false,
- passingReverse: function(newCallback) {
- var
- calculations = module.get.elementCalculations(),
- callback = newCallback || settings.onPassingReverse,
- callbackName = 'passingReverse'
- ;
- if(newCallback) {
- module.debug('Adding callback for passing reverse', newCallback);
- settings.onPassingReverse = newCallback;
- }
- if(!calculations.passing) {
- if(module.get.occurred('passing')) {
- module.execute(callback, callbackName);
- }
- }
- else if(!settings.once) {
- module.remove.occurred(callbackName);
- }
- if(newCallback !== undefined) {
- return !calculations.passing;
- }
- },
+ // special visibility type (image, fixed)
+ type: false,
+ // z-index to use with visibility 'fixed'
+ zIndex: '10',
- topVisibleReverse: function(newCallback) {
- var
- calculations = module.get.elementCalculations(),
- callback = newCallback || settings.onTopVisibleReverse,
- callbackName = 'topVisibleReverse'
- ;
- if(newCallback) {
- module.debug('Adding callback for top visible reverse', newCallback);
- settings.onTopVisibleReverse = newCallback;
- }
- if(!calculations.topVisible) {
- if(module.get.occurred('topVisible')) {
- module.execute(callback, callbackName);
- }
- }
- else if(!settings.once) {
- module.remove.occurred(callbackName);
- }
- if(newCallback === undefined) {
- return !calculations.topVisible;
- }
- },
+ // image only animation settings
+ transition: 'fade in',
+ duration: 1000,
- bottomVisibleReverse: function(newCallback) {
- var
- calculations = module.get.elementCalculations(),
- callback = newCallback || settings.onBottomVisibleReverse,
- callbackName = 'bottomVisibleReverse'
- ;
- if(newCallback) {
- module.debug('Adding callback for bottom visible reverse', newCallback);
- settings.onBottomVisibleReverse = newCallback;
- }
- if(!calculations.bottomVisible) {
- if(module.get.occurred('bottomVisible')) {
- module.execute(callback, callbackName);
- }
- }
- else if(!settings.once) {
- module.remove.occurred(callbackName);
- }
- if(newCallback === undefined) {
- return !calculations.bottomVisible;
- }
- },
+ // array of callbacks for percentage
+ onPassed: {},
- topPassedReverse: function(newCallback) {
- var
- calculations = module.get.elementCalculations(),
- callback = newCallback || settings.onTopPassedReverse,
- callbackName = 'topPassedReverse'
- ;
- if(newCallback) {
- module.debug('Adding callback for top passed reverse', newCallback);
- settings.onTopPassedReverse = newCallback;
- }
- if(!calculations.topPassed) {
- if(module.get.occurred('topPassed')) {
- module.execute(callback, callbackName);
- }
- }
- else if(!settings.once) {
- module.remove.occurred(callbackName);
- }
- if(newCallback === undefined) {
- return !calculations.onTopPassed;
- }
- },
+ // standard callbacks
+ onOnScreen: false,
+ onOffScreen: false,
+ onPassing: false,
+ onTopVisible: false,
+ onBottomVisible: false,
+ onTopPassed: false,
+ onBottomPassed: false,
- bottomPassedReverse: function(newCallback) {
- var
- calculations = module.get.elementCalculations(),
- callback = newCallback || settings.onBottomPassedReverse,
- callbackName = 'bottomPassedReverse'
- ;
- if(newCallback) {
- module.debug('Adding callback for bottom passed reverse', newCallback);
- settings.onBottomPassedReverse = newCallback;
- }
- if(!calculations.bottomPassed) {
- if(module.get.occurred('bottomPassed')) {
- module.execute(callback, callbackName);
- }
- }
- else if(!settings.once) {
- module.remove.occurred(callbackName);
- }
- if(newCallback === undefined) {
- return !calculations.bottomPassed;
- }
- },
+ // reverse callbacks
+ onPassingReverse: false,
+ onTopVisibleReverse: false,
+ onBottomVisibleReverse: false,
+ onTopPassedReverse: false,
+ onBottomPassedReverse: false,
- execute: function(callback, callbackName) {
- var
- calculations = module.get.elementCalculations(),
- screen = module.get.screenCalculations()
- ;
- callback = callback || false;
- if(callback) {
- if(settings.continuous) {
- module.debug('Callback being called continuously', callbackName, calculations);
- callback.call(element, calculations, screen);
- }
- else if(!module.get.occurred(callbackName)) {
- module.debug('Conditions met', callbackName, calculations);
- callback.call(element, calculations, screen);
- }
- }
- module.save.occurred(callbackName);
- },
+ // special callbacks for image
+ onLoad: function () {},
+ onAllLoaded: function () {},
- remove: {
- fixed: function() {
- module.debug('Removing fixed position');
- $module
- .removeClass(className.fixed)
- .css({
- position : '',
- top : '',
- left : '',
- zIndex : ''
- })
- ;
- settings.onUnfixed.call(element);
- },
- placeholder: function() {
- module.debug('Removing placeholder content');
- if($placeholder) {
- $placeholder.remove();
- }
- },
- occurred: function(callback) {
- if(callback) {
- var
- occurred = module.cache.occurred
- ;
- if(occurred[callback] !== undefined && occurred[callback] === true) {
- module.debug('Callback can now be called again', callback);
- module.cache.occurred[callback] = false;
- }
- }
- else {
- module.cache.occurred = {};
- }
- }
- },
+ // special callbacks for fixed position
+ onFixed: function () {},
+ onUnfixed: function () {},
- save: {
- calculations: function() {
- module.verbose('Saving all calculations necessary to determine positioning');
- module.save.direction();
- module.save.screenCalculations();
- module.save.elementCalculations();
- },
- occurred: function(callback) {
- if(callback) {
- if(module.cache.occurred[callback] === undefined || (module.cache.occurred[callback] !== true)) {
- module.verbose('Saving callback occurred', callback);
- module.cache.occurred[callback] = true;
- }
- }
- },
- scroll: function(scrollPosition) {
- scrollPosition = scrollPosition + settings.offset || $context.scrollTop() + settings.offset;
- module.cache.scroll = scrollPosition;
- },
- direction: function() {
- var
- scroll = module.get.scroll(),
- lastScroll = module.get.lastScroll(),
- direction
- ;
- if(scroll > lastScroll && lastScroll) {
- direction = 'down';
- }
- else if(scroll < lastScroll && lastScroll) {
- direction = 'up';
- }
- else {
- direction = 'static';
- }
- module.cache.direction = direction;
- return module.cache.direction;
- },
- elementPosition: function() {
- var
- element = module.cache.element,
- screen = module.get.screenSize()
- ;
- module.verbose('Saving element position');
- // (quicker than $.extend)
- element.fits = (element.height < screen.height);
- element.offset = $module.offset();
- element.width = $module.outerWidth();
- element.height = $module.outerHeight();
- // compensate for scroll in context
- if(module.is.verticallyScrollableContext()) {
- element.offset.top += $context.scrollTop() - $context.offset().top;
- }
- if(module.is.horizontallyScrollableContext()) {
- element.offset.left += $context.scrollLeft() - $context.offset().left;
- }
- // store
- module.cache.element = element;
- return element;
- },
- elementCalculations: function() {
- var
- screen = module.get.screenCalculations(),
- element = module.get.elementPosition()
- ;
- // offset
- if(settings.includeMargin) {
- element.margin = {};
- element.margin.top = parseInt($module.css('margin-top'), 10);
- element.margin.bottom = parseInt($module.css('margin-bottom'), 10);
- element.top = element.offset.top - element.margin.top;
- element.bottom = element.offset.top + element.height + element.margin.bottom;
- }
- else {
- element.top = element.offset.top;
- element.bottom = element.offset.top + element.height;
- }
+ // utility callbacks
+ onUpdate: false, // disabled by default for performance
+ onRefresh: function () {},
- // visibility
- element.topPassed = (screen.top >= element.top);
- element.bottomPassed = (screen.top >= element.bottom);
- element.topVisible = (screen.bottom >= element.top) && !element.topPassed;
- element.bottomVisible = (screen.bottom >= element.bottom) && !element.bottomPassed;
- element.pixelsPassed = 0;
- element.percentagePassed = 0;
-
- // meta calculations
- element.onScreen = ((element.topVisible || element.passing) && !element.bottomPassed);
- element.passing = (element.topPassed && !element.bottomPassed);
- element.offScreen = (!element.onScreen);
-
- // passing calculations
- if(element.passing) {
- element.pixelsPassed = (screen.top - element.top);
- element.percentagePassed = (screen.top - element.top) / element.height;
- }
- module.cache.element = element;
- module.verbose('Updated element calculations', element);
- return element;
- },
- screenCalculations: function() {
- var
- scroll = module.get.scroll()
- ;
- module.save.direction();
- module.cache.screen.top = scroll;
- module.cache.screen.bottom = scroll + module.cache.screen.height;
- return module.cache.screen;
- },
- screenSize: function() {
- module.verbose('Saving window position');
- module.cache.screen = {
- height: $context.height()
- };
- },
- position: function() {
- module.save.screenSize();
- module.save.elementPosition();
- }
+ metadata: {
+ src: 'src',
},
- get: {
- pixelsPassed: function(amount) {
- var
- element = module.get.elementCalculations()
- ;
- if(amount.search('%') > -1) {
- return ( element.height * (parseInt(amount, 10) / 100) );
- }
- return parseInt(amount, 10);
- },
- occurred: function(callback) {
- return (module.cache.occurred !== undefined)
- ? module.cache.occurred[callback] || false
- : false
- ;
- },
- direction: function() {
- if(module.cache.direction === undefined) {
- module.save.direction();
- }
- return module.cache.direction;
- },
- elementPosition: function() {
- if(module.cache.element === undefined) {
- module.save.elementPosition();
- }
- return module.cache.element;
- },
- elementCalculations: function() {
- if(module.cache.element === undefined) {
- module.save.elementCalculations();
- }
- return module.cache.element;
- },
- screenCalculations: function() {
- if(module.cache.screen === undefined) {
- module.save.screenCalculations();
- }
- return module.cache.screen;
- },
- screenSize: function() {
- if(module.cache.screen === undefined) {
- module.save.screenSize();
- }
- return module.cache.screen;
- },
- scroll: function() {
- if(module.cache.scroll === undefined) {
- module.save.scroll();
- }
- return module.cache.scroll;
- },
- lastScroll: function() {
- if(module.cache.screen === undefined) {
- module.debug('First scroll event, no last scroll could be found');
- return false;
- }
- return module.cache.screen.top;
- }
+ className: {
+ fixed: 'fixed',
+ placeholder: 'constraint',
+ visible: 'visible',
},
- setting: function(name, value) {
- if( $.isPlainObject(name) ) {
- $.extend(true, settings, name);
- }
- else if(value !== undefined) {
- settings[name] = value;
- }
- else {
- return settings[name];
- }
- },
- internal: function(name, value) {
- if( $.isPlainObject(name) ) {
- $.extend(true, module, name);
- }
- else if(value !== undefined) {
- module[name] = value;
- }
- else {
- return module[name];
- }
- },
- debug: function() {
- if(!settings.silent && settings.debug) {
- if(settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.debug.apply(console, arguments);
- }
- }
- },
- verbose: function() {
- if(!settings.silent && settings.verbose && settings.debug) {
- if(settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.verbose.apply(console, arguments);
- }
- }
+ error: {
+ method: 'The method you called is not defined.',
+ visible: 'Element is hidden, you must call refresh after element becomes visible',
},
- error: function() {
- if(!settings.silent) {
- module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
- module.error.apply(console, arguments);
- }
- },
- performance: {
- log: function(message) {
- var
- currentTime,
- executionTime,
- previousTime
- ;
- if(settings.performance) {
- currentTime = new Date().getTime();
- previousTime = time || currentTime;
- executionTime = currentTime - previousTime;
- time = currentTime;
- performance.push({
- 'Name' : message[0],
- 'Arguments' : [].slice.call(message, 1) || '',
- 'Element' : element,
- 'Execution Time' : executionTime
- });
- }
- clearTimeout(module.performance.timer);
- module.performance.timer = setTimeout(module.performance.display, 500);
- },
- display: function() {
- var
- title = settings.name + ':',
- totalTime = 0
- ;
- time = false;
- clearTimeout(module.performance.timer);
- $.each(performance, function(index, data) {
- totalTime += data['Execution Time'];
- });
- title += ' ' + totalTime + 'ms';
- if(moduleSelector) {
- title += ' \'' + moduleSelector + '\'';
- }
- if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) {
- console.groupCollapsed(title);
- if(console.table) {
- console.table(performance);
- }
- else {
- $.each(performance, function(index, data) {
- console.log(data['Name'] + ': ' + data['Execution Time']+'ms');
- });
- }
- console.groupEnd();
- }
- performance = [];
- }
- },
- invoke: function(query, passedArguments, context) {
- var
- object = instance,
- maxDepth,
- found,
- response
- ;
- passedArguments = passedArguments || queryArguments;
- context = context || element;
- if(typeof query == 'string' && object !== undefined) {
- query = query.split(/[\. ]/);
- maxDepth = query.length - 1;
- $.each(query, function(depth, value) {
- var camelCaseValue = (depth != maxDepth)
- ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
- : query
- ;
- if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) {
- object = object[camelCaseValue];
- }
- else if( object[camelCaseValue] !== undefined ) {
- found = object[camelCaseValue];
- return false;
- }
- else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) {
- object = object[value];
- }
- else if( object[value] !== undefined ) {
- found = object[value];
- return false;
- }
- else {
- module.error(error.method, query);
- return false;
- }
- });
- }
- if ( $.isFunction( found ) ) {
- response = found.apply(context, passedArguments);
- }
- else if(found !== undefined) {
- response = found;
- }
- if(Array.isArray(returnedValue)) {
- returnedValue.push(response);
- }
- else if(returnedValue !== undefined) {
- returnedValue = [returnedValue, response];
- }
- else if(response !== undefined) {
- returnedValue = response;
- }
- return found;
- }
- };
-
- if(methodInvoked) {
- if(instance === undefined) {
- module.initialize();
- }
- instance.save.scroll();
- instance.save.calculations();
- module.invoke(query);
- }
- else {
- if(instance !== undefined) {
- instance.invoke('destroy');
- }
- module.initialize();
- }
- })
- ;
-
- return (returnedValue !== undefined)
- ? returnedValue
- : this
- ;
-};
-
-$.fn.visibility.settings = {
-
- name : 'Visibility',
- namespace : 'visibility',
-
- debug : false,
- verbose : false,
- performance : true,
-
- // whether to use mutation observers to follow changes
- observeChanges : true,
-
- // check position immediately on init
- initialCheck : true,
-
- // whether to refresh calculations after all page images load
- refreshOnLoad : true,
-
- // whether to refresh calculations after page resize event
- refreshOnResize : true,
-
- // should call callbacks on refresh event (resize, etc)
- checkOnRefresh : true,
-
- // callback should only occur one time
- once : true,
-
- // callback should fire continuously when evaluates to true
- continuous : false,
-
- // offset to use with scroll top
- offset : 0,
-
- // whether to include margin in elements position
- includeMargin : false,
-
- // scroll context for visibility checks
- context : window,
-
- // visibility check delay in ms (defaults to animationFrame)
- throttle : false,
-
- // special visibility type (image, fixed)
- type : false,
-
- // z-index to use with visibility 'fixed'
- zIndex : '10',
-
- // image only animation settings
- transition : 'fade in',
- duration : 1000,
-
- // array of callbacks for percentage
- onPassed : {},
-
- // standard callbacks
- onOnScreen : false,
- onOffScreen : false,
- onPassing : false,
- onTopVisible : false,
- onBottomVisible : false,
- onTopPassed : false,
- onBottomPassed : false,
-
- // reverse callbacks
- onPassingReverse : false,
- onTopVisibleReverse : false,
- onBottomVisibleReverse : false,
- onTopPassedReverse : false,
- onBottomPassedReverse : false,
-
- // special callbacks for image
- onLoad : function() {},
- onAllLoaded : function() {},
-
- // special callbacks for fixed position
- onFixed : function() {},
- onUnfixed : function() {},
-
- // utility callbacks
- onUpdate : false, // disabled by default for performance
- onRefresh : function(){},
-
- metadata : {
- src: 'src'
- },
-
- className: {
- fixed : 'fixed',
- placeholder : 'constraint',
- visible : 'visible'
- },
-
- error : {
- method : 'The method you called is not defined.',
- visible : 'Element is hidden, you must call refresh after element becomes visible'
- }
-
-};
-})( jQuery, window, document );
+ };
+})(jQuery, window, document);
diff --git a/definitions/collections/breadcrumb.less b/definitions/collections/breadcrumb.less
index df6f979..face26f 100644
--- a/definitions/collections/breadcrumb.less
+++ b/definitions/collections/breadcrumb.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Breadcrumb
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,27 +12,26 @@
Theme
*******************************/
-@type : 'collection';
-@element : 'breadcrumb';
-
-@import (multiple) '../../theme.config';
+@type: "collection";
+@element: "breadcrumb";
+@import (multiple) "../../theme.config";
/*******************************
Breadcrumb
*******************************/
.ui.breadcrumb {
- line-height: @lineHeight;
- display: @display;
- margin: @verticalMargin 0;
- vertical-align: @verticalAlign;
+ line-height: @lineHeight;
+ display: @display;
+ margin: @verticalMargin 0;
+ vertical-align: @verticalAlign;
}
.ui.breadcrumb:first-child {
- margin-top: 0;
+ margin-top: 0;
}
.ui.breadcrumb:last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
/*******************************
@@ -41,57 +40,55 @@
/* Divider */
.ui.breadcrumb .divider {
- display: inline-block;
- opacity: @dividerOpacity;
- margin: 0 @dividerSpacing 0;
-
- font-size: @dividerSize;
- color: @dividerColor;
- vertical-align: @dividerVerticalAlign;
+ display: inline-block;
+ opacity: @dividerOpacity;
+ margin: 0 @dividerSpacing;
+ font-size: @dividerSize;
+ color: @dividerColor;
+ vertical-align: @dividerVerticalAlign;
}
/* Link */
.ui.breadcrumb a {
- color: @linkColor;
+ color: @linkColor;
}
.ui.breadcrumb a:hover {
- color: @linkHoverColor;
+ color: @linkHoverColor;
}
-
/* Icon Divider */
.ui.breadcrumb .icon.divider {
- font-size: @iconDividerSize;
- vertical-align: @iconDividerVerticalAlign;
+ font-size: @iconDividerSize;
+ vertical-align: @iconDividerVerticalAlign;
}
/* Section */
.ui.breadcrumb a.section {
- cursor: pointer;
+ cursor: pointer;
}
.ui.breadcrumb .section {
- display: inline-block;
- margin: @sectionMargin;
- padding: @sectionPadding;
+ display: inline-block;
+ margin: @sectionMargin;
+ padding: @sectionPadding;
}
/* Loose Coupling */
.ui.breadcrumb.segment {
- display: inline-block;
- padding: @segmentPadding;
+ display: inline-block;
+ padding: @segmentPadding;
}
& when (@variationBreadcrumbInverted) {
- /* Inverted */
- .ui.inverted.breadcrumb {
- color: @invertedColor;
- }
- .ui.inverted.breadcrumb > .active.section {
- color: @invertedActiveColor;
- }
- .ui.inverted.breadcrumb > .divider {
- color: @invertedDividerColor;
- }
+ /* Inverted */
+ .ui.inverted.breadcrumb {
+ color: @invertedColor;
+ }
+ .ui.inverted.breadcrumb > .active.section {
+ color: @invertedActiveColor;
+ }
+ .ui.inverted.breadcrumb > .divider {
+ color: @invertedDividerColor;
+ }
}
/*******************************
@@ -99,24 +96,23 @@
*******************************/
.ui.breadcrumb .active.section {
- font-weight: @activeFontWeight;
+ font-weight: @activeFontWeight;
}
-
/*******************************
Variations
*******************************/
.ui.breadcrumb {
- font-size: @medium;
+ font-size: @medium;
}
& when not (@variationBreadcrumbSizes = false) {
- each(@variationBreadcrumbSizes, {
- @s: @@value;
- .ui.@{value}.breadcrumb {
- font-size: @s;
- }
- })
+ each(@variationBreadcrumbSizes, {
+ @s: @@value;
+ .ui.@{value}.breadcrumb {
+ font-size: @s;
+ }
+ });
}
.loadUIOverrides();
diff --git a/definitions/collections/form.less b/definitions/collections/form.less
index 06c5f34..264054f 100644
--- a/definitions/collections/form.less
+++ b/definitions/collections/form.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Form
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,71 +12,70 @@
Theme
*******************************/
-@type : 'collection';
-@element : 'form';
+@type: "collection";
+@element: "form";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Elements
*******************************/
-/*--------------------
+/* --------------------
Form
----------------------*/
+--------------------- */
.ui.form {
- position: relative;
- max-width: 100%;
+ position: relative;
+ max-width: 100%;
}
-/*--------------------
+/* --------------------
Content
----------------------*/
+--------------------- */
.ui.form > p {
- margin: @paragraphMargin;
+ margin: @paragraphMargin;
}
-/*--------------------
+/* --------------------
Field
----------------------*/
+--------------------- */
.ui.form .field {
- clear: both;
- margin: @fieldMargin;
+ clear: both;
+ margin: @fieldMargin;
}
.ui.form .fields .fields,
.ui.form .field:last-child,
.ui.form .fields:last-child .field {
- margin-bottom: 0;
+ margin-bottom: 0;
}
.ui.form .fields .field {
- clear: both;
- margin: 0;
+ clear: both;
+ margin: 0;
}
-
-/*--------------------
+/* --------------------
Labels
----------------------*/
+--------------------- */
.ui.form .field > label {
- display: block;
- margin: @labelMargin;
- font-size: @labelFontSize;
- font-weight: @labelFontWeight;
- text-transform: @labelTextTransform;
+ display: block;
+ margin: @labelMargin;
+ font-size: @labelFontSize;
+ font-weight: @labelFontWeight;
+ text-transform: @labelTextTransform;
}
.ui.form:not(.inverted) .field > label:not(.button) {
- color: @labelColor;
+ color: @labelColor;
}
-/*--------------------
- Standard Inputs
----------------------*/
+/* --------------------
+ Standard Inputs
+--------------------- */
.ui.form textarea,
.ui.form input:not([type]),
@@ -94,14 +93,14 @@
.ui.form input[type="file"],
.ui.form input[type="url"],
.ui.form input[type="week"] {
- width: @inputWidth;
- vertical-align: top;
+ width: @inputWidth;
+ vertical-align: top;
}
/* Set max height on unusual input */
.ui.form ::-webkit-datetime-edit,
.ui.form ::-webkit-inner-spin-button {
- height: @inputLineHeight;
+ height: @inputLineHeight;
}
.ui.form input:not([type]),
@@ -119,304 +118,295 @@
.ui.form input[type="file"],
.ui.form input[type="url"],
.ui.form input[type="week"] {
- font-family: @inputFont;
- margin: 0;
- outline: none;
- -webkit-appearance: none;
- -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
-
- line-height: @inputLineHeight;
- padding: @inputPadding;
- font-size: @inputFontSize;
-
- background: @inputBackground;
- border: @inputBorder;
- color: @inputColor;
- border-radius: @inputBorderRadius;
- box-shadow: @inputBoxShadow;
- transition: @inputTransition;
+ font-family: @inputFont;
+ margin: 0;
+ outline: none;
+ -webkit-appearance: none;
+ -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
+ line-height: @inputLineHeight;
+ padding: @inputPadding;
+ font-size: @inputFontSize;
+ background: @inputBackground;
+ border: @inputBorder;
+ color: @inputColor;
+ border-radius: @inputBorderRadius;
+ box-shadow: @inputBoxShadow;
+ transition: @inputTransition;
}
.ui.form input[type="color"] {
- padding: initial;
+ padding: initial;
}
.ui.form input::-webkit-calendar-picker-indicator {
- padding: 0;
- opacity: @iconOpacity;
- transition: @iconTransition;
- cursor: pointer;
+ padding: 0;
+ opacity: @iconOpacity;
+ transition: @iconTransition;
+ cursor: pointer;
}
/* Text Area */
.ui.input textarea,
.ui.form textarea {
- margin: 0;
- -webkit-appearance: none;
- -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
-
- padding: @textAreaPadding;
- background: @textAreaBackground;
- border: @textAreaBorder;
- outline: none;
- color: @inputColor;
- border-radius: @inputBorderRadius;
- box-shadow: @inputBoxShadow;
- transition: @textAreaTransition;
- font-size: @textAreaFontSize;
- font-family: @inputFont;
- line-height: @textAreaLineHeight;
- resize: @textAreaResize;
+ margin: 0;
+ -webkit-appearance: none;
+ -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
+ padding: @textAreaPadding;
+ background: @textAreaBackground;
+ border: @textAreaBorder;
+ outline: none;
+ color: @inputColor;
+ border-radius: @inputBorderRadius;
+ box-shadow: @inputBoxShadow;
+ transition: @textAreaTransition;
+ font-size: @textAreaFontSize;
+ font-family: @inputFont;
+ line-height: @textAreaLineHeight;
+ resize: @textAreaResize;
}
.ui.form textarea:not([rows]) {
- height: @textAreaHeight;
- min-height: @textAreaMinHeight;
- max-height: @textAreaMaxHeight;
+ height: @textAreaHeight;
+ min-height: @textAreaMinHeight;
+ max-height: @textAreaMaxHeight;
}
.ui.form textarea,
.ui.form input[type="checkbox"] {
- vertical-align: @checkboxVerticalAlign;
+ vertical-align: @checkboxVerticalAlign;
}
-/*--------------------
+/* --------------------
Checkbox margin
----------------------*/
+--------------------- */
.ui.form .fields:not(.grouped):not(.inline) .field:not(:only-child) label + .ui.ui.checkbox {
- margin-top: @checkboxLabelFieldTopMargin;
+ margin-top: @checkboxLabelFieldTopMargin;
}
.ui.form .fields:not(.grouped):not(.inline) .field:not(:only-child) .ui.checkbox {
- margin-top: @inputLineHeight + @checkboxFieldTopMargin;
+ margin-top: @inputLineHeight + @checkboxFieldTopMargin;
}
.ui.form .fields:not(.grouped):not(.inline) .field:not(:only-child) .ui.toggle.checkbox {
- margin-top: @inputLineHeight + @checkboxToggleFieldTopMargin;
+ margin-top: @inputLineHeight + @checkboxToggleFieldTopMargin;
}
.ui.form .fields:not(.grouped):not(.inline) .field:not(:only-child) .ui.slider.checkbox {
- margin-top: @inputLineHeight + @checkboxSliderFieldTopMargin;
+ margin-top: @inputLineHeight + @checkboxSliderFieldTopMargin;
}
.ui.ui.form .field .fields .field:not(:only-child) .ui.checkbox {
- margin-top: (@checkboxFieldTopMargin / 2);
+ margin-top: (@checkboxFieldTopMargin / 2);
}
.ui.ui.form .field .fields .field:not(:only-child) .ui.toggle.checkbox {
- margin-top: (@checkboxToggleFieldTopMargin / 2);
+ margin-top: (@checkboxToggleFieldTopMargin / 2);
}
.ui.ui.form .field .fields .field:not(:only-child) .ui.slider.checkbox {
- margin-top: (@checkboxSliderFieldTopMargin / 2);
+ margin-top: (@checkboxSliderFieldTopMargin / 2);
}
& when (@variationFormTransparent) {
- /*--------------------
- Transparent
- ---------------------*/
-
- .ui.form .field .transparent.input:not(.icon) input,
- .ui.form .field input.transparent,
- .ui.form .field textarea.transparent {
- padding: @transparentPadding;
- }
-
- .ui.form .field input.transparent,
- .ui.form .field textarea.transparent {
- border-color: transparent !important;
- background-color: transparent !important;
- box-shadow: none !important;
- }
-}
-/*--------------------------
+ /* --------------------
+ Transparent
+ --------------------- */
+
+ .ui.form .field .transparent.input:not(.icon) input,
+ .ui.form .field input.transparent,
+ .ui.form .field textarea.transparent {
+ padding: @transparentPadding;
+ }
+
+ .ui.form .field input.transparent,
+ .ui.form .field textarea.transparent {
+ border-color: transparent !important;
+ background-color: transparent !important;
+ box-shadow: none !important;
+ }
+}
+
+/* --------------------------
Input w/ attached Button
----------------------------*/
+--------------------------- */
.ui.form input.attached {
- width: auto;
+ width: auto;
}
-
-/*--------------------
+/* --------------------
Basic Select
----------------------*/
+--------------------- */
.ui.form select {
- display: block;
- height: auto;
- width: 100%;
- background: @selectBackground;
- border: @selectBorder;
- border-radius: @selectBorderRadius;
- box-shadow: @selectBoxShadow;
- padding: @selectPadding;
- color: @selectColor;
- transition: @selectTransition;
-}
-
-/*--------------------
+ display: block;
+ height: auto;
+ width: 100%;
+ background: @selectBackground;
+ border: @selectBorder;
+ border-radius: @selectBorderRadius;
+ box-shadow: @selectBoxShadow;
+ padding: @selectPadding;
+ color: @selectColor;
+ transition: @selectTransition;
+}
+
+/* --------------------
Dropdown
----------------------*/
+--------------------- */
/* Block */
.ui.form .field > .selection.dropdown:not(.compact) {
- min-width: auto;
- width: 100%;
+ min-width: auto;
+ width: 100%;
}
.ui.form .field > .selection.dropdown > .dropdown.icon {
- float: right;
+ float: right;
}
& when (@variationFormInline) {
- /* Inline */
- .ui.form .inline.fields .field > .selection.dropdown,
- .ui.form .inline.field > .selection.dropdown {
- width: auto;
- }
- .ui.form .inline.fields .field > .selection.dropdown > .dropdown.icon,
- .ui.form .inline.field > .selection.dropdown > .dropdown.icon {
- float: none;
- }
+ /* Inline */
+ .ui.form .inline.fields .field > .selection.dropdown,
+ .ui.form .inline.field > .selection.dropdown {
+ width: auto;
+ }
+ .ui.form .inline.fields .field > .selection.dropdown > .dropdown.icon,
+ .ui.form .inline.field > .selection.dropdown > .dropdown.icon {
+ float: none;
+ }
}
-/*--------------------
+/* --------------------
UI Input
----------------------*/
+--------------------- */
/* Block */
.ui.form .field .ui.input,
.ui.form .fields .field .ui.input,
.ui.form .wide.field .ui.input {
- width: 100%;
+ width: 100%;
}
& when (@variationFormInline) {
- /* Inline */
- .ui.form .inline.fields .field:not(.wide) .ui.input,
- .ui.form .inline.field:not(.wide) .ui.input {
- width: auto;
- vertical-align: middle;
- }
+ /* Inline */
+ .ui.form .inline.fields .field:not(.wide) .ui.input,
+ .ui.form .inline.field:not(.wide) .ui.input {
+ width: auto;
+ vertical-align: middle;
+ }
}
/* Auto Input */
.ui.form .fields .field .ui.input input,
.ui.form .field .ui.input input {
- width: auto;
+ width: auto;
}
& when (@variationFormEqualWidth) or (@variationFormWide) {
- /* Full Width Input */
- .ui.form .ten.fields .ui.input input,
- .ui.form .nine.fields .ui.input input,
- .ui.form .eight.fields .ui.input input,
- .ui.form .seven.fields .ui.input input,
- .ui.form .six.fields .ui.input input,
- .ui.form .five.fields .ui.input input,
- .ui.form .four.fields .ui.input input,
- .ui.form .three.fields .ui.input input,
- .ui.form .two.fields .ui.input input,
- .ui.form .wide.field .ui.input input {
- flex: 1 0 auto;
- width: 0;
- }
-}
-
-
-/*--------------------
+ /* Full Width Input */
+ .ui.form .ten.fields .ui.input input,
+ .ui.form .nine.fields .ui.input input,
+ .ui.form .eight.fields .ui.input input,
+ .ui.form .seven.fields .ui.input input,
+ .ui.form .six.fields .ui.input input,
+ .ui.form .five.fields .ui.input input,
+ .ui.form .four.fields .ui.input input,
+ .ui.form .three.fields .ui.input input,
+ .ui.form .two.fields .ui.input input,
+ .ui.form .wide.field .ui.input input {
+ flex: 1 0 auto;
+ width: 0;
+ }
+}
+
+/* --------------------
Types of Messages
----------------------*/
+--------------------- */
& when not (@variationFormStates = false) {
- each(@variationFormStates, {
- @state: @value;
- .ui.form .@{state}.message,
- .ui.form .@{state}.message:empty {
- display: none;
- }
- })
+ each(@variationFormStates, {
+ @state: @value;
+ .ui.form .@{state}.message,
+ .ui.form .@{state}.message:empty {
+ display: none;
+ }
+ });
}
/* Assumptions */
.ui.form .message:first-child {
- margin-top: 0;
+ margin-top: 0;
}
-/*--------------------
+/* --------------------
Validation Prompt
----------------------*/
+--------------------- */
.ui.form .field .prompt.label {
- white-space: normal;
- background: @promptBackground !important;
- border: @promptBorder !important;
- color: @promptTextColor !important;
- & li::before {
- color: @promptTextColor;
- }
+ white-space: normal;
+ background: @promptBackground !important;
+ border: @promptBorder !important;
+ color: @promptTextColor !important;
+ & li::before {
+ color: @promptTextColor;
+ }
}
& when (@variationFormInline) {
- .ui.form .inline.fields .field .prompt,
- .ui.form .inline.field .prompt {
- vertical-align: top;
- margin: @inlinePromptMargin;
- }
- .ui.form .inline.fields .field .prompt::before,
- .ui.form .inline.field .prompt::before {
- border-width: 0 0 @inlinePromptBorderWidth @inlinePromptBorderWidth;
- bottom: auto;
- right: auto;
- top: 50%;
- left: 0;
- }
+ .ui.form .inline.fields .field .prompt,
+ .ui.form .inline.field .prompt {
+ vertical-align: top;
+ margin: @inlinePromptMargin;
+ }
+ .ui.form .inline.fields .field .prompt::before,
+ .ui.form .inline.field .prompt::before {
+ border-width: 0 0 @inlinePromptBorderWidth @inlinePromptBorderWidth;
+ bottom: auto;
+ right: auto;
+ top: 50%;
+ left: 0;
+ }
}
-
/*******************************
States
*******************************/
-/*--------------------
+/* --------------------
Autofilled
----------------------*/
+--------------------- */
.ui.form .field.field input:-webkit-autofill {
- box-shadow: 0 0 0 100px @inputAutoFillBackground inset !important;
- border-color: @inputAutoFillBorder !important;
+ box-shadow: 0 0 0 100px @inputAutoFillBackground inset !important;
+ border-color: @inputAutoFillBorder !important;
}
/* Focus */
.ui.form .field.field input:-webkit-autofill:focus {
- box-shadow: 0 0 0 100px @inputAutoFillFocusBackground inset !important;
- border-color: @inputAutoFillFocusBorder !important;
+ box-shadow: 0 0 0 100px @inputAutoFillFocusBackground inset !important;
+ border-color: @inputAutoFillFocusBorder !important;
}
-
-
-/*--------------------
+/* --------------------
Placeholder
----------------------*/
+--------------------- */
/* browsers require these rules separate */
.ui.form ::-webkit-input-placeholder {
- color: @inputPlaceholderColor;
+ color: @inputPlaceholderColor;
}
.ui.form :-ms-input-placeholder when (@supportIE) {
- color: @inputPlaceholderColor !important;
+ color: @inputPlaceholderColor !important;
}
.ui.form ::-moz-placeholder {
- color: @inputPlaceholderColor;
- opacity: 1;
+ color: @inputPlaceholderColor;
+ opacity: 1;
}
.ui.form :focus::-webkit-input-placeholder {
- color: @inputPlaceholderFocusColor;
+ color: @inputPlaceholderFocusColor;
}
.ui.form :focus:-ms-input-placeholder when (@supportIE) {
- color: @inputPlaceholderFocusColor !important;
+ color: @inputPlaceholderFocusColor !important;
}
.ui.form :focus::-moz-placeholder {
- color: @inputPlaceholderFocusColor;
+ color: @inputPlaceholderFocusColor;
}
-
-
-/*--------------------
+/* --------------------
Focus
----------------------*/
+--------------------- */
.ui.form input:not([type]):focus,
.ui.form input[type="color"]:focus,
@@ -433,388 +423,386 @@
.ui.form input[type="file"]:focus,
.ui.form input[type="url"]:focus,
.ui.form input[type="week"]:focus {
- color: @inputFocusColor;
- border-color: @inputFocusBorderColor;
- border-radius: @inputFocusBorderRadius;
- background: @inputFocusBackground;
- box-shadow: @inputFocusBoxShadow;
+ color: @inputFocusColor;
+ border-color: @inputFocusBorderColor;
+ border-radius: @inputFocusBorderRadius;
+ background: @inputFocusBackground;
+ box-shadow: @inputFocusBoxShadow;
}
& when (@variationInputAction) {
- .ui.form .ui.action.input:not([class*="left action"]) {
- & input:not([type]):focus,
- input[type="color"]:focus,
- input[type="date"]:focus,
- input[type="datetime-local"]:focus,
- input[type="email"]:focus,
- input[type="month"]:focus,
- input[type="number"]:focus,
- input[type="password"]:focus,
- input[type="search"]:focus,
- input[type="tel"]:focus,
- input[type="time"]:focus,
- input[type="text"]:focus,
- input[type="file"]:focus,
- input[type="url"]:focus,
- input[type="week"]:focus {
- border-top-right-radius: 0;
- border-bottom-right-radius: 0;
- }
- }
-
- .ui.form .ui[class*="left action"].input {
- & input:not([type]),
- input[type="color"],
- input[type="date"],
- input[type="datetime-local"],
- input[type="email"],
- input[type="month"],
- input[type="number"],
- input[type="password"],
- input[type="search"],
- input[type="tel"],
- input[type="time"],
- input[type="text"],
- input[type="file"],
- input[type="url"],
- input[type="week"] {
- border-bottom-left-radius: 0;
- border-top-left-radius: 0;
- }
- }
+ .ui.form .ui.action.input:not([class*="left action"]) {
+ & input:not([type]):focus,
+ input[type="color"]:focus,
+ input[type="date"]:focus,
+ input[type="datetime-local"]:focus,
+ input[type="email"]:focus,
+ input[type="month"]:focus,
+ input[type="number"]:focus,
+ input[type="password"]:focus,
+ input[type="search"]:focus,
+ input[type="tel"]:focus,
+ input[type="time"]:focus,
+ input[type="text"]:focus,
+ input[type="file"]:focus,
+ input[type="url"]:focus,
+ input[type="week"]:focus {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+ }
+ }
+
+ .ui.form .ui[class*="left action"].input {
+ & input:not([type]),
+ input[type="color"],
+ input[type="date"],
+ input[type="datetime-local"],
+ input[type="email"],
+ input[type="month"],
+ input[type="number"],
+ input[type="password"],
+ input[type="search"],
+ input[type="tel"],
+ input[type="time"],
+ input[type="text"],
+ input[type="file"],
+ input[type="url"],
+ input[type="week"] {
+ border-bottom-left-radius: 0;
+ border-top-left-radius: 0;
+ }
+ }
}
.ui.form textarea:focus {
- color: @textAreaFocusColor;
- border-color: @textAreaFocusBorderColor;
- border-radius: @textAreaFocusBorderRadius;
- background: @textAreaFocusBackground;
- box-shadow: @textAreaFocusBoxShadow;
- -webkit-appearance: none;
+ color: @textAreaFocusColor;
+ border-color: @textAreaFocusBorderColor;
+ border-radius: @textAreaFocusBorderRadius;
+ background: @textAreaFocusBackground;
+ box-shadow: @textAreaFocusBoxShadow;
+ -webkit-appearance: none;
}
+
/* Focus */
.ui.form input:focus::-webkit-calendar-picker-indicator {
- opacity: @iconFocusOpacity;
+ opacity: @iconFocusOpacity;
}
& when not (@variationFormStates = false) {
- /*--------------------
- States
- ---------------------*/
- each(@variationFormStates, {
- @state: @value;
- @c: @formStates[@@state][color];
- @bg: @formStates[@@state][background];
- @bdc: @formStates[@@state][borderColor];
- @lbg: @formStates[@@state][labelBackground];
-
- /* On Form */
- .ui.form.@{state} .@{state}.message:not(:empty) {
- display: block;
- }
- .ui.form.@{state} .compact.@{state}.message:not(:empty) {
- display: inline-block;
- }
- .ui.form.@{state} .icon.@{state}.message:not(:empty) {
- display: flex;
- }
-
- /* On Field(s) */
- .ui.form .fields.@{state} .@{state}.message:not(:empty),
- .ui.form .field.@{state} .@{state}.message:not(:empty) {
- display: block;
- }
- .ui.form .fields.@{state} .compact.@{state}.message:not(:empty),
- .ui.form .field.@{state} .compact.@{state}.message:not(:empty) {
- display: inline-block;
- }
- .ui.form .fields.@{state} .icon.@{state}.message:not(:empty),
- .ui.form .field.@{state} .icon.@{state}.message:not(:empty) {
- display: flex;
- }
-
- .ui.ui.form .fields.@{state} .field label,
- .ui.ui.form .fields.@{state} .field .ui.label:not(.corner),
- .ui.ui.form .field.@{state} label,
- .ui.ui.form .field.@{state} .ui.label:not(.corner),
- .ui.ui.form .fields.@{state} .field .input,
- .ui.ui.form .field.@{state} .input {
- color: @c;
- }
-
- .ui.form .fields.@{state} .field .ui.label,
- .ui.form .field.@{state} .ui.label {
- background-color: @lbg;
- }
-
- .ui.form .fields.@{state} .field .corner.label,
- .ui.form .field.@{state} .corner.label {
- border-color: @c;
- color: @formStates[@@state][cornerLabelColor];
- }
-
- .ui.form .fields.@{state} .field textarea,
- .ui.form .fields.@{state} .field select,
- .ui.form .fields.@{state} .field input:not([type]),
- .ui.form .fields.@{state} .field input[type="color"],
- .ui.form .fields.@{state} .field input[type="date"],
- .ui.form .fields.@{state} .field input[type="datetime-local"],
- .ui.form .fields.@{state} .field input[type="email"],
- .ui.form .fields.@{state} .field input[type="month"],
- .ui.form .fields.@{state} .field input[type="number"],
- .ui.form .fields.@{state} .field input[type="password"],
- .ui.form .fields.@{state} .field input[type="search"],
- .ui.form .fields.@{state} .field input[type="tel"],
- .ui.form .fields.@{state} .field input[type="time"],
- .ui.form .fields.@{state} .field input[type="text"],
- .ui.form .fields.@{state} .field input[type="file"],
- .ui.form .fields.@{state} .field input[type="url"],
- .ui.form .fields.@{state} .field input[type="week"],
- .ui.form .field.@{state} textarea,
- .ui.form .field.@{state} select,
- .ui.form .field.@{state} input:not([type]),
- .ui.form .field.@{state} input[type="color"],
- .ui.form .field.@{state} input[type="date"],
- .ui.form .field.@{state} input[type="datetime-local"],
- .ui.form .field.@{state} input[type="email"],
- .ui.form .field.@{state} input[type="month"],
- .ui.form .field.@{state} input[type="number"],
- .ui.form .field.@{state} input[type="password"],
- .ui.form .field.@{state} input[type="search"],
- .ui.form .field.@{state} input[type="tel"],
- .ui.form .field.@{state} input[type="time"],
- .ui.form .field.@{state} input[type="text"],
- .ui.form .field.@{state} input[type="file"],
- .ui.form .field.@{state} input[type="url"],
- .ui.form .field.@{state} input[type="week"] {
- color: @c;
- background: @bg;
- border-color: @formStates[@@state][borderColor];
- border-radius: @formStates[@@state][borderRadius];
- box-shadow: @formStates[@@state][boxShadow];
- }
- & when (@state=error) {
- .ui.form .field input:not(:placeholder-shown):invalid {
- color: @c;
- background: @bg;
- border-color: @formStates[@@state][borderColor];
- border-radius: @formStates[@@state][borderRadius];
- box-shadow: @formStates[@@state][boxShadow];
- }
- .ui.form .field input:not(:-ms-input-placeholder):invalid when (@supportIE) {
- color: @c;
- background: @bg;
- border-color: @formStates[@@state][borderColor];
- border-radius: @formStates[@@state][borderRadius];
- box-shadow: @formStates[@@state][boxShadow];
- }
- }
-
- .ui.form .field.@{state} textarea:focus,
- .ui.form .field.@{state} select:focus,
- .ui.form .field.@{state} input:not([type]):focus,
- .ui.form .field.@{state} input[type="color"]:focus,
- .ui.form .field.@{state} input[type="date"]:focus,
- .ui.form .field.@{state} input[type="datetime-local"]:focus,
- .ui.form .field.@{state} input[type="email"]:focus,
- .ui.form .field.@{state} input[type="month"]:focus,
- .ui.form .field.@{state} input[type="number"]:focus,
- .ui.form .field.@{state} input[type="password"]:focus,
- .ui.form .field.@{state} input[type="search"]:focus,
- .ui.form .field.@{state} input[type="tel"]:focus,
- .ui.form .field.@{state} input[type="time"]:focus,
- .ui.form .field.@{state} input[type="text"]:focus,
- .ui.form .field.@{state} input[type="file"]:focus,
- .ui.form .field.@{state} input[type="url"]:focus,
- .ui.form .field.@{state} input[type="week"]:focus {
- background: @formStates[@@state][inputFocusBackground];
- border-color: @formStates[@@state][inputFocusBorderColor];
- color: @formStates[@@state][inputFocusColor];
-
- box-shadow: @formStates[@@state][inputFocusBoxShadow];
- }
-
- /* Preserve Native Select Stylings */
- .ui.form .field.@{state} select {
- -webkit-appearance: menulist-button;
- }
-
- /*------------------
- Input State
- --------------------*/
- & when (@variationFormTransparent) {
- /* Transparent */
- .ui.form .field.@{state} .transparent.input input,
- .ui.form .field.@{state} .transparent.input textarea,
- .ui.form .field.@{state} input.transparent,
- .ui.form .field.@{state} textarea.transparent {
- background-color: @formStates[@@state][transparentBackground] !important;
- color: @formStates[@@state][transparentColor] !important;
- }
- }
-
- /* Autofilled */
- .ui.form .@{state}.@{state} input:-webkit-autofill {
- box-shadow: 0 0 0 100px @formStates[@@state][inputAutoFillBackground] inset !important;
- border-color: @formStates[@@state][inputAutoFillBorderColor] !important;
- }
-
- /* Placeholder */
- .ui.form .@{state} ::-webkit-input-placeholder {
- color: @formStates[@@state][inputPlaceholderColor];
- }
- .ui.form .@{state} :-ms-input-placeholder when (@supportIE) {
- color: @formStates[@@state][inputPlaceholderColor] !important;
- }
- .ui.form .@{state} ::-moz-placeholder {
- color: @formStates[@@state][inputPlaceholderColor];
- }
-
- .ui.form .@{state} :focus::-webkit-input-placeholder {
- color: @formStates[@@state][inputPlaceholderFocusColor];
- }
- .ui.form .@{state} :focus:-ms-input-placeholder when (@supportIE) {
- color: @formStates[@@state][inputPlaceholderFocusColor] !important;
- }
- .ui.form .@{state} :focus::-moz-placeholder {
- color: @formStates[@@state][inputPlaceholderFocusColor];
- }
-
- /*------------------
- Dropdown State
- --------------------*/
-
- .ui.form .fields.@{state} .field .ui.dropdown,
- .ui.form .fields.@{state} .field .ui.dropdown .item,
- .ui.form .field.@{state} .ui.dropdown,
- .ui.form .field.@{state} .ui.dropdown > .text,
- .ui.form .field.@{state} .ui.dropdown .item {
- background: @bg;
- color: @c;
- }
- .ui.form .fields.@{state} .field .ui.dropdown,
- .ui.form .field.@{state} .ui.dropdown {
- border-color: @bdc !important;
- }
- .ui.form .fields.@{state} .field .ui.dropdown:hover,
- .ui.form .field.@{state} .ui.dropdown:hover {
- border-color: @bdc !important;
- }
- .ui.form .fields.@{state} .field .ui.dropdown:hover .menu,
- .ui.form .field.@{state} .ui.dropdown:hover .menu {
- border-color: @bdc;
- }
- .ui.form .fields.@{state} .field .ui.multiple.selection.dropdown > .label,
- .ui.form .field.@{state} .ui.multiple.selection.dropdown > .label {
- background-color: @formStates[@@state][dropdownLabelBackground];
- color: @formStates[@@state][dropdownLabelColor];
- }
+ /* --------------------
+ States
+ --------------------- */
+ each(@variationFormStates, {
+ @state: @value;
+ @c: @formStates[@@state][color];
+ @bg: @formStates[@@state][background];
+ @bdc: @formStates[@@state][borderColor];
+ @lbg: @formStates[@@state][labelBackground];
+
+ /* On Form */
+ .ui.form.@{state} .@{state}.message:not(:empty) {
+ display: block;
+ }
+ .ui.form.@{state} .compact.@{state}.message:not(:empty) {
+ display: inline-block;
+ }
+ .ui.form.@{state} .icon.@{state}.message:not(:empty) {
+ display: flex;
+ }
+
+ /* On Field(s) */
+ .ui.form .fields.@{state} .@{state}.message:not(:empty),
+ .ui.form .field.@{state} .@{state}.message:not(:empty) {
+ display: block;
+ }
+ .ui.form .fields.@{state} .compact.@{state}.message:not(:empty),
+ .ui.form .field.@{state} .compact.@{state}.message:not(:empty) {
+ display: inline-block;
+ }
+ .ui.form .fields.@{state} .icon.@{state}.message:not(:empty),
+ .ui.form .field.@{state} .icon.@{state}.message:not(:empty) {
+ display: flex;
+ }
+
+ .ui.ui.form .fields.@{state} .field label,
+ .ui.ui.form .fields.@{state} .field .ui.label:not(.corner),
+ .ui.ui.form .field.@{state} label,
+ .ui.ui.form .field.@{state} .ui.label:not(.corner),
+ .ui.ui.form .fields.@{state} .field .input,
+ .ui.ui.form .field.@{state} .input {
+ color: @c;
+ }
+
+ .ui.form .fields.@{state} .field .ui.label,
+ .ui.form .field.@{state} .ui.label {
+ background-color: @lbg;
+ }
+
+ .ui.form .fields.@{state} .field .corner.label,
+ .ui.form .field.@{state} .corner.label {
+ border-color: @c;
+ color: @formStates[@@state][cornerLabelColor];
+ }
+
+ .ui.form .fields.@{state} .field textarea,
+ .ui.form .fields.@{state} .field select,
+ .ui.form .fields.@{state} .field input:not([type]),
+ .ui.form .fields.@{state} .field input[type="color"],
+ .ui.form .fields.@{state} .field input[type="date"],
+ .ui.form .fields.@{state} .field input[type="datetime-local"],
+ .ui.form .fields.@{state} .field input[type="email"],
+ .ui.form .fields.@{state} .field input[type="month"],
+ .ui.form .fields.@{state} .field input[type="number"],
+ .ui.form .fields.@{state} .field input[type="password"],
+ .ui.form .fields.@{state} .field input[type="search"],
+ .ui.form .fields.@{state} .field input[type="tel"],
+ .ui.form .fields.@{state} .field input[type="time"],
+ .ui.form .fields.@{state} .field input[type="text"],
+ .ui.form .fields.@{state} .field input[type="file"],
+ .ui.form .fields.@{state} .field input[type="url"],
+ .ui.form .fields.@{state} .field input[type="week"],
+ .ui.form .field.@{state} textarea,
+ .ui.form .field.@{state} select,
+ .ui.form .field.@{state} input:not([type]),
+ .ui.form .field.@{state} input[type="color"],
+ .ui.form .field.@{state} input[type="date"],
+ .ui.form .field.@{state} input[type="datetime-local"],
+ .ui.form .field.@{state} input[type="email"],
+ .ui.form .field.@{state} input[type="month"],
+ .ui.form .field.@{state} input[type="number"],
+ .ui.form .field.@{state} input[type="password"],
+ .ui.form .field.@{state} input[type="search"],
+ .ui.form .field.@{state} input[type="tel"],
+ .ui.form .field.@{state} input[type="time"],
+ .ui.form .field.@{state} input[type="text"],
+ .ui.form .field.@{state} input[type="file"],
+ .ui.form .field.@{state} input[type="url"],
+ .ui.form .field.@{state} input[type="week"] {
+ color: @c;
+ background: @bg;
+ border-color: @formStates[@@state][borderColor];
+ border-radius: @formStates[@@state][borderRadius];
+ box-shadow: @formStates[@@state][boxShadow];
+ }
+ & when (@state=error) and (@variationFormInvalid) {
+ .ui.form .field input:not(:placeholder-shown):invalid {
+ color: @c;
+ background: @bg;
+ border-color: @formStates[@@state][borderColor];
+ border-radius: @formStates[@@state][borderRadius];
+ box-shadow: @formStates[@@state][boxShadow];
+ }
+ .ui.form .field input:not(:-ms-input-placeholder):invalid when (@supportIE) {
+ color: @c;
+ background: @bg;
+ border-color: @formStates[@@state][borderColor];
+ border-radius: @formStates[@@state][borderRadius];
+ box-shadow: @formStates[@@state][boxShadow];
+ }
+ }
+
+ .ui.form .field.@{state} textarea:focus,
+ .ui.form .field.@{state} select:focus,
+ .ui.form .field.@{state} input:not([type]):focus,
+ .ui.form .field.@{state} input[type="color"]:focus,
+ .ui.form .field.@{state} input[type="date"]:focus,
+ .ui.form .field.@{state} input[type="datetime-local"]:focus,
+ .ui.form .field.@{state} input[type="email"]:focus,
+ .ui.form .field.@{state} input[type="month"]:focus,
+ .ui.form .field.@{state} input[type="number"]:focus,
+ .ui.form .field.@{state} input[type="password"]:focus,
+ .ui.form .field.@{state} input[type="search"]:focus,
+ .ui.form .field.@{state} input[type="tel"]:focus,
+ .ui.form .field.@{state} input[type="time"]:focus,
+ .ui.form .field.@{state} input[type="text"]:focus,
+ .ui.form .field.@{state} input[type="file"]:focus,
+ .ui.form .field.@{state} input[type="url"]:focus,
+ .ui.form .field.@{state} input[type="week"]:focus {
+ background: @formStates[@@state][inputFocusBackground];
+ border-color: @formStates[@@state][inputFocusBorderColor];
+ color: @formStates[@@state][inputFocusColor];
+
+ box-shadow: @formStates[@@state][inputFocusBoxShadow];
+ }
+
+ /* Preserve Native Select Stylings */
+ .ui.form .field.@{state} select {
+ -webkit-appearance: menulist-button;
+ }
+
+ /*------------------
+ Input State
+ --------------------*/
+ & when (@variationFormTransparent) {
+ /* Transparent */
+ .ui.form .field.@{state} .transparent.input input,
+ .ui.form .field.@{state} .transparent.input textarea,
+ .ui.form .field.@{state} input.transparent,
+ .ui.form .field.@{state} textarea.transparent {
+ background-color: @formStates[@@state][transparentBackground] !important;
+ color: @formStates[@@state][transparentColor] !important;
+ }
+ }
+
+ /* Autofilled */
+ .ui.form .@{state}.@{state} input:-webkit-autofill {
+ box-shadow: 0 0 0 100px @formStates[@@state][inputAutoFillBackground] inset !important;
+ border-color: @formStates[@@state][inputAutoFillBorderColor] !important;
+ }
+
+ /* Placeholder */
+ .ui.form .@{state} ::-webkit-input-placeholder {
+ color: @formStates[@@state][inputPlaceholderColor];
+ }
+ .ui.form .@{state} :-ms-input-placeholder when (@supportIE) {
+ color: @formStates[@@state][inputPlaceholderColor] !important;
+ }
+ .ui.form .@{state} ::-moz-placeholder {
+ color: @formStates[@@state][inputPlaceholderColor];
+ }
+
+ .ui.form .@{state} :focus::-webkit-input-placeholder {
+ color: @formStates[@@state][inputPlaceholderFocusColor];
+ }
+ .ui.form .@{state} :focus:-ms-input-placeholder when (@supportIE) {
+ color: @formStates[@@state][inputPlaceholderFocusColor] !important;
+ }
+ .ui.form .@{state} :focus::-moz-placeholder {
+ color: @formStates[@@state][inputPlaceholderFocusColor];
+ }
+
+ /*------------------
+ Dropdown State
+ --------------------*/
+
+ .ui.form .fields.@{state} .field .ui.dropdown,
+ .ui.form .fields.@{state} .field .ui.dropdown .item,
+ .ui.form .field.@{state} .ui.dropdown,
+ .ui.form .field.@{state} .ui.dropdown > .text,
+ .ui.form .field.@{state} .ui.dropdown .item {
+ background: @bg;
+ color: @c;
+ }
+ .ui.form .fields.@{state} .field .ui.dropdown,
+ .ui.form .field.@{state} .ui.dropdown {
+ border-color: @bdc !important;
+ }
+ .ui.form .fields.@{state} .field .ui.dropdown:hover,
+ .ui.form .field.@{state} .ui.dropdown:hover {
+ border-color: @bdc !important;
+ }
+ .ui.form .fields.@{state} .field .ui.dropdown:hover .menu,
+ .ui.form .field.@{state} .ui.dropdown:hover .menu {
+ border-color: @bdc;
+ }
+ .ui.form .fields.@{state} .field .ui.multiple.selection.dropdown > .label,
+ .ui.form .field.@{state} .ui.multiple.selection.dropdown > .label {
+ background-color: @formStates[@@state][dropdownLabelBackground];
+ color: @formStates[@@state][dropdownLabelColor];
+ }
+
+ /* Hover */
+ .ui.form .fields.@{state} .field .ui.dropdown .menu .item:hover,
+ .ui.form .field.@{state} .ui.dropdown .menu .item:hover {
+ background-color: @formStates[@@state][dropdownHoverBackground];
+ }
+
+ /* Selected */
+ .ui.form .fields.@{state} .field .ui.dropdown .menu .selected.item,
+ .ui.form .field.@{state} .ui.dropdown .menu .selected.item {
+ background-color: @formStates[@@state][dropdownSelectedBackground];
+ }
+
+ /* Active */
+ .ui.form .fields.@{state} .field .ui.dropdown .menu .active.item,
+ .ui.form .field.@{state} .ui.dropdown .menu .active.item {
+ background-color: @formStates[@@state][dropdownActiveBackground] !important;
+ }
+
+ /*--------------------
+ Checkbox State
+ ---------------------*/
+ .ui.form .fields.@{state} .field .checkbox:not(.toggle):not(.slider) label,
+ .ui.form .field.@{state} .checkbox:not(.toggle):not(.slider) label {
+ color: @c;
+ }
+ .ui.form .fields.@{state} .field .checkbox:not(.toggle):not(.slider) label::before,
+ .ui.form .field.@{state} .checkbox:not(.toggle):not(.slider) label::before {
+ background: @bg;
+ border-color: @bdc;
+ }
+ .ui.form .fields.@{state} .field .checkbox label::after,
+ .ui.form .field.@{state} .checkbox label::after {
+ color: @c;
+ }
+
+ & when (@variationFormInverted) {
+ .ui.inverted.form .fields.@{state} .field label,
+ .ui.inverted.form .@{state}.field label {
+ color: @lbg;
+ }
+ }
+ });
+}
- /* Hover */
- .ui.form .fields.@{state} .field .ui.dropdown .menu .item:hover,
- .ui.form .field.@{state} .ui.dropdown .menu .item:hover {
- background-color: @formStates[@@state][dropdownHoverBackground];
+& when (@variationFormDisabled) {
+ /* --------------------
+ Disabled
+ --------------------- */
+
+ .ui.form .disabled.fields .field,
+ .ui.form .disabled.field,
+ .ui.form .field :disabled {
+ pointer-events: @disabledPointerEvents;
+ opacity: @disabledOpacity;
}
-
- /* Selected */
- .ui.form .fields.@{state} .field .ui.dropdown .menu .selected.item,
- .ui.form .field.@{state} .ui.dropdown .menu .selected.item {
- background-color: @formStates[@@state][dropdownSelectedBackground];
+ .ui.form .field.disabled > label,
+ .ui.form .fields.disabled > label {
+ opacity: @disabledLabelOpacity;
}
-
- /* Active */
- .ui.form .fields.@{state} .field .ui.dropdown .menu .active.item,
- .ui.form .field.@{state} .ui.dropdown .menu .active.item {
- background-color: @formStates[@@state][dropdownActiveBackground] !important;
+ .ui.form .field.disabled :disabled {
+ opacity: 1;
}
+}
- /*--------------------
- Checkbox State
- ---------------------*/
- .ui.form .fields.@{state} .field .checkbox:not(.toggle):not(.slider) label,
- .ui.form .field.@{state} .checkbox:not(.toggle):not(.slider) label {
- color: @c;
- }
- .ui.form .fields.@{state} .field .checkbox:not(.toggle):not(.slider) label::before,
- .ui.form .field.@{state} .checkbox:not(.toggle):not(.slider) label::before {
- background: @bg;
- border-color: @bdc;
+& when (@variationFormLoading) {
+ /* --------------
+ Loading
+ --------------- */
+
+ .ui.loading.form {
+ position: relative;
+ cursor: default;
+ pointer-events: none;
}
- .ui.form .fields.@{state} .field .checkbox label::after,
- .ui.form .field.@{state} .checkbox label::after {
- color: @c;
+ .ui.loading.form::before {
+ position: absolute;
+ content: "";
+ top: 0;
+ left: 0;
+ background: @loaderDimmerColor;
+ width: 100%;
+ height: 100%;
+ z-index: @loaderDimmerZIndex;
}
- & when (@variationFormInverted) {
- .ui.inverted.form .fields.@{state} .field label,
- .ui.inverted.form .@{state}.field label {
- color: @lbg;
- }
+ .ui.loading.form.segments::before {
+ border-radius: @defaultBorderRadius;
}
- })
-}
-
-& when (@variationFormDisabled) {
- /*--------------------
- Disabled
- ---------------------*/
-
- .ui.form .disabled.fields .field,
- .ui.form .disabled.field,
- .ui.form .field :disabled {
- pointer-events: none;
- opacity: @disabledOpacity;
- }
- .ui.form .field.disabled > label,
- .ui.form .fields.disabled > label {
- opacity: @disabledLabelOpacity;
- }
- .ui.form .field.disabled :disabled {
- opacity: 1;
- }
-}
-
-& when (@variationFormLoading) {
- /*--------------
- Loading
- ---------------*/
-
- .ui.loading.form {
- position: relative;
- cursor: default;
- pointer-events: none;
- }
- .ui.loading.form::before {
- position: absolute;
- content: '';
- top: 0;
- left: 0;
- background: @loaderDimmerColor;
- width: 100%;
- height: 100%;
- z-index: @loaderDimmerZIndex;
- }
-
- .ui.loading.form.segments::before {
- border-radius: @defaultBorderRadius;
- }
- .ui.loading.form::after {
- position: absolute;
- content: '';
- top: 50%;
- left: 50%;
-
- margin: @loaderMargin;
- width: @loaderSize;
- height: @loaderSize;
-
- animation: loader @loaderSpeed infinite linear;
- border: @loaderLineWidth solid @loaderLineColor;
- border-radius: @circularRadius;
-
- box-shadow: 0 0 0 1px transparent;
- visibility: visible;
- z-index: @loaderLineZIndex;
- }
+ .ui.loading.form::after {
+ position: absolute;
+ content: "";
+ top: 50%;
+ left: 50%;
+ margin: @loaderMargin;
+ width: @loaderSize;
+ height: @loaderSize;
+ animation: loader @loaderSpeed infinite linear;
+ border: @loaderLineWidth solid @loaderLineColor;
+ border-radius: @circularRadius;
+ box-shadow: 0 0 0 1px transparent;
+ visibility: visible;
+ z-index: @loaderLineZIndex;
+ }
}
/*******************************
@@ -822,370 +810,364 @@
*******************************/
& when (@variationFormRequired) {
- /*--------------------
- Required Field
- ---------------------*/
-
- .ui.form .required.fields:not(.grouped) > .field > label::after,
- .ui.form .required.fields.grouped > label::after,
- .ui.form .required.field > label::after,
- .ui.form .required.fields:not(.grouped) > .field > .checkbox::after,
- .ui.form .required.field > .checkbox::after,
- .ui.form label.required::after {
- margin: @requiredMargin;
- content: @requiredContent;
- color: @requiredColor;
- }
-
- .ui.form .required.fields:not(.grouped) > .field > label::after,
- .ui.form .required.fields.grouped > label::after,
- .ui.form .required.field > label::after,
- .ui.form label.required::after {
- display: inline-block;
- vertical-align: top;
- }
+ /* --------------------
+ Required Field
+ --------------------- */
+
+ .ui.form .required.fields:not(.grouped) > .field > label::after,
+ .ui.form .required.fields.grouped > label::after,
+ .ui.form .required.field > label::after,
+ .ui.form .required.fields:not(.grouped) > .field > .checkbox::after,
+ .ui.form .required.field > .checkbox::after,
+ .ui.form label.required::after {
+ margin: @requiredMargin;
+ content: @requiredContent;
+ color: @requiredColor;
+ }
- .ui.form .required.fields:not(.grouped) > .field > .checkbox::after,
- .ui.form .required.field > .checkbox::after {
- position: absolute;
- top: 0;
- left: 100%;
- }
-}
+ .ui.form .required.fields:not(.grouped) > .field > label::after,
+ .ui.form .required.fields.grouped > label::after,
+ .ui.form .required.field > label::after,
+ .ui.form label.required::after {
+ display: inline-block;
+ vertical-align: top;
+ }
+ .ui.form .required.fields:not(.grouped) > .field > .checkbox::after,
+ .ui.form .required.field > .checkbox::after {
+ position: absolute;
+ top: 0;
+ left: 100%;
+ }
+}
/*******************************
Variations
*******************************/
& when (@variationFormInverted) {
- /*--------------------
- Inverted Colors
- ---------------------*/
-
- .ui.inverted.form label,
- .ui.form .inverted.segment label,
- .ui.form .inverted.segment .ui.checkbox label,
- .ui.inverted.form .ui.checkbox label,
- .ui.inverted.form .inline.fields > label,
- .ui.inverted.form .inline.fields .field > label,
- .ui.inverted.form .inline.fields .field > p,
- .ui.inverted.form .inline.field > label,
- .ui.inverted.form .inline.field > p {
- color: @invertedLabelColor;
- }
- .ui.inverted.loading.form {
- color: @invertedLoaderLineColor;
- }
- .ui.inverted.loading.form::before {
- background: @loaderInvertedDimmerColor;
- }
- /* Inverted Field */
- .ui.inverted.form input:not([type]),
- .ui.inverted.form input[type="color"],
- .ui.inverted.form input[type="date"],
- .ui.inverted.form input[type="datetime-local"],
- .ui.inverted.form input[type="email"],
- .ui.inverted.form input[type="month"],
- .ui.inverted.form input[type="number"],
- .ui.inverted.form input[type="password"],
- .ui.inverted.form input[type="search"],
- .ui.inverted.form input[type="tel"],
- .ui.inverted.form input[type="time"],
- .ui.inverted.form input[type="text"],
- .ui.inverted.form input[type="file"],
- .ui.inverted.form input[type="url"],
- .ui.inverted.form input[type="week"] {
- background: @invertedInputBackground;
- border-color: @invertedInputBorderColor;
- color: @invertedInputColor;
- box-shadow: @invertedInputBoxShadow;
- }
+ /* --------------------
+ Inverted Colors
+ --------------------- */
+
+ .ui.inverted.form label,
+ .ui.form .inverted.segment label,
+ .ui.form .inverted.segment .ui.checkbox label,
+ .ui.inverted.form .ui.checkbox label,
+ .ui.inverted.form .inline.fields > label,
+ .ui.inverted.form .inline.fields .field > label,
+ .ui.inverted.form .inline.fields .field > p,
+ .ui.inverted.form .inline.field > label,
+ .ui.inverted.form .inline.field > p {
+ color: @invertedLabelColor;
+ }
+ .ui.inverted.loading.form {
+ color: @invertedLoaderLineColor;
+ }
+ .ui.inverted.loading.form::before {
+ background: @loaderInvertedDimmerColor;
+ }
+
+ /* Inverted Field */
+ .ui.inverted.form input:not([type]),
+ .ui.inverted.form input[type="color"],
+ .ui.inverted.form input[type="date"],
+ .ui.inverted.form input[type="datetime-local"],
+ .ui.inverted.form input[type="email"],
+ .ui.inverted.form input[type="month"],
+ .ui.inverted.form input[type="number"],
+ .ui.inverted.form input[type="password"],
+ .ui.inverted.form input[type="search"],
+ .ui.inverted.form input[type="tel"],
+ .ui.inverted.form input[type="time"],
+ .ui.inverted.form input[type="text"],
+ .ui.inverted.form input[type="file"],
+ .ui.inverted.form input[type="url"],
+ .ui.inverted.form input[type="week"] {
+ background: @invertedInputBackground;
+ border-color: @invertedInputBorderColor;
+ color: @invertedInputColor;
+ box-shadow: @invertedInputBoxShadow;
+ }
}
& when (@variationFormGrouped) {
- /*--------------------
- Field Groups
- ---------------------*/
+ /* --------------------
+ Field Groups
+ --------------------- */
- /* Grouped Vertically */
+ /* Grouped Vertically */
- .ui.form .grouped.fields {
- display: block;
- margin: @groupedMargin;
- }
+ .ui.form .grouped.fields {
+ display: block;
+ margin: @groupedMargin;
+ }
- .ui.form .grouped.fields:last-child {
- margin-bottom: 0;
- }
-
- .ui.form .grouped.fields > label {
- margin: @groupedLabelMargin;
- color: @groupedLabelColor;
- font-size: @groupedLabelFontSize;
- font-weight: @groupedLabelFontWeight;
- text-transform: @groupedLabelTextTransform;
- }
-
- .ui.form .grouped.fields .field,
- .ui.form .grouped.inline.fields .field {
- display: block;
- margin: @groupedFieldMargin;
- padding: 0;
- }
- .ui.form .grouped.inline.fields .ui.checkbox {
- margin-bottom: @groupedInlineCheckboxBottomMargin;
- }
+ .ui.form .grouped.fields:last-child {
+ margin-bottom: 0;
+ }
+
+ .ui.form .grouped.fields > label {
+ margin: @groupedLabelMargin;
+ color: @groupedLabelColor;
+ font-size: @groupedLabelFontSize;
+ font-weight: @groupedLabelFontWeight;
+ text-transform: @groupedLabelTextTransform;
+ }
+
+ .ui.form .grouped.fields .field,
+ .ui.form .grouped.inline.fields .field {
+ display: block;
+ margin: @groupedFieldMargin;
+ padding: 0;
+ }
+ .ui.form .grouped.inline.fields .ui.checkbox {
+ margin-bottom: @groupedInlineCheckboxBottomMargin;
+ }
}
-/*--------------------
+/* --------------------
Fields
----------------------*/
+--------------------- */
/* Split fields */
.ui.form .fields {
- display: flex;
- flex-direction: row;
- margin: @fieldsMargin;
+ display: flex;
+ flex-direction: row;
+ margin: @fieldsMargin;
}
.ui.form .fields > .field {
- flex: 0 1 auto;
- padding-left: (@gutterWidth / 2);
- padding-right: (@gutterWidth / 2);
+ flex: 0 1 auto;
+ padding-left: (@gutterWidth / 2);
+ padding-right: (@gutterWidth / 2);
}
.ui.form .fields > .field:first-child {
- border-left: none;
- box-shadow: none;
+ border-left: none;
+ box-shadow: none;
}
& when (@variationFormEqualWidth) {
- /* Other Combinations */
- .ui.form .two.fields > .fields,
- .ui.form .two.fields > .field {
- width: @twoColumn;
- }
- .ui.form .three.fields > .fields,
- .ui.form .three.fields > .field {
- width: @threeColumn;
- }
- .ui.form .four.fields > .fields,
- .ui.form .four.fields > .field {
- width: @fourColumn;
- }
- .ui.form .five.fields > .fields,
- .ui.form .five.fields > .field {
- width: @fiveColumn;
- }
- .ui.form .six.fields > .fields,
- .ui.form .six.fields > .field {
- width: @sixColumn;
- }
- .ui.form .seven.fields > .fields,
- .ui.form .seven.fields > .field {
- width: @sevenColumn;
- }
- .ui.form .eight.fields > .fields,
- .ui.form .eight.fields > .field {
- width: @eightColumn;
- }
- .ui.form .nine.fields > .fields,
- .ui.form .nine.fields > .field {
- width: @nineColumn;
- }
- .ui.form .ten.fields > .fields,
- .ui.form .ten.fields > .field {
- width: @tenColumn;
- }
+ /* Other Combinations */
+ .ui.form .two.fields > .fields,
+ .ui.form .two.fields > .field {
+ width: @twoColumn;
+ }
+ .ui.form .three.fields > .fields,
+ .ui.form .three.fields > .field {
+ width: @threeColumn;
+ }
+ .ui.form .four.fields > .fields,
+ .ui.form .four.fields > .field {
+ width: @fourColumn;
+ }
+ .ui.form .five.fields > .fields,
+ .ui.form .five.fields > .field {
+ width: @fiveColumn;
+ }
+ .ui.form .six.fields > .fields,
+ .ui.form .six.fields > .field {
+ width: @sixColumn;
+ }
+ .ui.form .seven.fields > .fields,
+ .ui.form .seven.fields > .field {
+ width: @sevenColumn;
+ }
+ .ui.form .eight.fields > .fields,
+ .ui.form .eight.fields > .field {
+ width: @eightColumn;
+ }
+ .ui.form .nine.fields > .fields,
+ .ui.form .nine.fields > .field {
+ width: @nineColumn;
+ }
+ .ui.form .ten.fields > .fields,
+ .ui.form .ten.fields > .field {
+ width: @tenColumn;
+ }
}
/* Swap to full width on mobile */
-@media only screen and (max-width : @largestMobileScreen) {
- .ui.form .fields {
- flex-wrap: wrap;
- margin-bottom: 0;
- }
+@media only screen and (max-width: @largestMobileScreen) {
+ .ui.form .fields {
+ flex-wrap: wrap;
+ margin-bottom: 0;
+ }
- .ui.form:not(.unstackable) .fields:not(.unstackable) > .fields,
- .ui.form:not(.unstackable) .fields:not(.unstackable) > .field {
- width: @oneColumn;
- margin: 0 0 @rowDistance;
- }
+ .ui.form:not(.unstackable) .fields:not(.unstackable) > .fields,
+ .ui.form:not(.unstackable) .fields:not(.unstackable) > .field {
+ width: @oneColumn;
+ margin: 0 0 @rowDistance;
+ }
}
& when (@variationFormWide) {
+ /* Sizing Combinations */
+ .ui.form .fields .wide.field {
+ width: @oneWide;
+ padding-left: (@gutterWidth / 2);
+ padding-right: (@gutterWidth / 2);
+ }
- /* Sizing Combinations */
- .ui.form .fields .wide.field {
- width: @oneWide;
- padding-left: (@gutterWidth / 2);
- padding-right: (@gutterWidth / 2);
- }
-
- .ui.form .one.wide.field {
- width: @oneWide;
- }
- .ui.form .two.wide.field {
- width: @twoWide;
- }
- .ui.form .three.wide.field {
- width: @threeWide;
- }
- .ui.form .four.wide.field {
- width: @fourWide;
- }
- .ui.form .five.wide.field {
- width: @fiveWide;
- }
- .ui.form .six.wide.field {
- width: @sixWide;
- }
- .ui.form .seven.wide.field {
- width: @sevenWide;
- }
- .ui.form .eight.wide.field {
- width: @eightWide;
- }
- .ui.form .nine.wide.field {
- width: @nineWide;
- }
- .ui.form .ten.wide.field {
- width: @tenWide;
- }
- .ui.form .eleven.wide.field {
- width: @elevenWide;
- }
- .ui.form .twelve.wide.field {
- width: @twelveWide;
- }
- .ui.form .thirteen.wide.field {
- width: @thirteenWide;
- }
- .ui.form .fourteen.wide.field {
- width: @fourteenWide;
- }
- .ui.form .fifteen.wide.field {
- width: @fifteenWide;
- }
- .ui.form .sixteen.wide.field {
- width: @sixteenWide;
- }
-}
-
-
-/*--------------------
+ .ui.form .one.wide.field {
+ width: @oneWide;
+ }
+ .ui.form .two.wide.field {
+ width: @twoWide;
+ }
+ .ui.form .three.wide.field {
+ width: @threeWide;
+ }
+ .ui.form .four.wide.field {
+ width: @fourWide;
+ }
+ .ui.form .five.wide.field {
+ width: @fiveWide;
+ }
+ .ui.form .six.wide.field {
+ width: @sixWide;
+ }
+ .ui.form .seven.wide.field {
+ width: @sevenWide;
+ }
+ .ui.form .eight.wide.field {
+ width: @eightWide;
+ }
+ .ui.form .nine.wide.field {
+ width: @nineWide;
+ }
+ .ui.form .ten.wide.field {
+ width: @tenWide;
+ }
+ .ui.form .eleven.wide.field {
+ width: @elevenWide;
+ }
+ .ui.form .twelve.wide.field {
+ width: @twelveWide;
+ }
+ .ui.form .thirteen.wide.field {
+ width: @thirteenWide;
+ }
+ .ui.form .fourteen.wide.field {
+ width: @fourteenWide;
+ }
+ .ui.form .fifteen.wide.field {
+ width: @fifteenWide;
+ }
+ .ui.form .sixteen.wide.field {
+ width: @sixteenWide;
+ }
+}
+
+/* --------------------
Equal Width
----------------------*/
+--------------------- */
& when (@variationFormEqualWidth) {
- .ui[class*="equal width"].form .fields > .field,
- .ui.form [class*="equal width"].fields > .field {
- width: 100%;
- flex: 1 1 auto;
- }
+ .ui[class*="equal width"].form .fields > .field,
+ .ui.form [class*="equal width"].fields > .field {
+ width: 100%;
+ flex: 1 1 auto;
+ }
}
& when (@variationFormInline) {
- /*--------------------
- Inline Fields
- ---------------------*/
+ /* --------------------
+ Inline Fields
+ --------------------- */
- .ui.form .inline.fields {
- margin: @fieldMargin;
- align-items: center;
- }
- .ui.form .inline.fields .field {
- margin: 0;
- padding: @inlineFieldsMargin;
- }
-
- /* Inline Label */
- .ui.form .inline.fields > label,
- .ui.form .inline.fields .field > label,
- .ui.form .inline.fields .field > p,
- .ui.form .inline.field > label,
- .ui.form .inline.field > p {
- display: inline-block;
- width: auto;
- margin-top: 0;
- margin-bottom: 0;
- vertical-align: baseline;
- font-size: @inlineLabelFontSize;
- font-weight: @inlineLabelFontWeight;
- color: @inlineLabelColor;
- text-transform: @inlineLabelTextTransform;
- }
-
- /* Grouped Inline Label */
- .ui.form .inline.fields > label {
- margin: @groupedInlineLabelMargin;
- }
-
- /* Inline Input */
- .ui.form .inline.fields .field > input,
- .ui.form .inline.fields .field > select,
- .ui.form .inline.field > input,
- .ui.form .inline.field > select {
- display: inline-block;
- width: auto;
+ .ui.form .inline.fields {
+ margin: @fieldMargin;
+ align-items: center;
+ }
+ .ui.form .inline.fields .field {
+ margin: 0;
+ padding: @inlineFieldsMargin;
+ }
- margin-top: 0;
- margin-bottom: 0;
+ /* Inline Label */
+ .ui.form .inline.fields > label,
+ .ui.form .inline.fields .field > label,
+ .ui.form .inline.fields .field > p,
+ .ui.form .inline.field > label,
+ .ui.form .inline.field > p {
+ display: inline-block;
+ width: auto;
+ margin-top: 0;
+ margin-bottom: 0;
+ vertical-align: baseline;
+ font-size: @inlineLabelFontSize;
+ font-weight: @inlineLabelFontWeight;
+ color: @inlineLabelColor;
+ text-transform: @inlineLabelTextTransform;
+ }
- vertical-align: middle;
- font-size: @inlineInputSize;
- }
-
- .ui.form .inline.fields .field .calendar:not(.popup),
- .ui.form .inline.field .calendar:not(.popup) {
- display:inline-block;
- }
-
- .ui.form .inline.fields .field .calendar:not(.popup) > .input > input,
- .ui.form .inline.field .calendar:not(.popup) > .input > input {
- width: @inlineCalendarWidth;
- }
-
- /* Label */
- .ui.form .inline.fields .field > :first-child,
- .ui.form .inline.field > :first-child {
- margin: 0 @inlineLabelDistance 0 0;
- }
- .ui.form .inline.fields .field > :only-child,
- .ui.form .inline.field > :only-child {
- margin: 0;
- }
+ /* Grouped Inline Label */
+ .ui.form .inline.fields > label {
+ margin: @groupedInlineLabelMargin;
+ }
- /* Wide */
- .ui.form .inline.fields .wide.field {
- display: flex;
- align-items: center;
- }
- .ui.form .inline.fields .wide.field > input,
- .ui.form .inline.fields .wide.field > select {
- width: 100%;
- }
-}
+ /* Inline Input */
+ .ui.form .inline.fields .field > input,
+ .ui.form .inline.fields .field > select,
+ .ui.form .inline.field > input,
+ .ui.form .inline.field > select {
+ display: inline-block;
+ width: auto;
+ margin-top: 0;
+ margin-bottom: 0;
+ vertical-align: middle;
+ font-size: @inlineInputSize;
+ }
+
+ .ui.form .inline.fields .field .calendar:not(.popup),
+ .ui.form .inline.field .calendar:not(.popup) {
+ display: inline-block;
+ }
+ .ui.form .inline.fields .field .calendar:not(.popup) > .input > input,
+ .ui.form .inline.field .calendar:not(.popup) > .input > input {
+ width: @inlineCalendarWidth;
+ }
+
+ /* Label */
+ .ui.form .inline.fields .field > :first-child,
+ .ui.form .inline.field > :first-child {
+ margin: 0 @inlineLabelDistance 0 0;
+ }
+ .ui.form .inline.fields .field > :only-child,
+ .ui.form .inline.field > :only-child {
+ margin: 0;
+ }
+
+ /* Wide */
+ .ui.form .inline.fields .wide.field {
+ display: flex;
+ align-items: center;
+ }
+ .ui.form .inline.fields .wide.field > input,
+ .ui.form .inline.fields .wide.field > select {
+ width: 100%;
+ }
+}
-/*--------------------
+/* --------------------
Sizes
----------------------*/
+--------------------- */
.ui.form,
.ui.form .field .dropdown,
.ui.form .field .dropdown .menu > .item {
- font-size: @medium;
+ font-size: @medium;
}
& when not (@variationFormSizes = false) {
- each(@variationFormSizes, {
- @s: @@value;
- .ui.@{value}.form,
- .ui.@{value}.form .field .dropdown,
- .ui.@{value}.form .field .dropdown .menu > .item {
- font-size: @s;
- }
- })
+ each(@variationFormSizes, {
+ @s: @@value;
+ .ui.@{value}.form,
+ .ui.@{value}.form .field .dropdown,
+ .ui.@{value}.form .field .dropdown .menu > .item {
+ font-size: @s;
+ }
+ });
}
-
.loadUIOverrides();
diff --git a/definitions/collections/grid.less b/definitions/collections/grid.less
index 3a0cf93..de108e1 100644
--- a/definitions/collections/grid.less
+++ b/definitions/collections/grid.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Grid
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,144 +12,137 @@
Theme
*******************************/
-@type : 'collection';
-@element : 'grid';
+@type: "collection";
+@element: "grid";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Standard
*******************************/
.ui.grid {
- display: flex;
- flex-direction: row;
- flex-wrap: wrap;
- align-items: stretch;
- padding: 0;
+ display: flex;
+ flex-flow: row wrap;
+ align-items: stretch;
+ padding: 0;
}
-/*----------------------
+/* ----------------------
Remove Gutters
------------------------*/
+----------------------- */
.ui.grid {
- margin-top: -(@rowSpacing / 2);
- margin-bottom: -(@rowSpacing / 2);
- margin-left: -(@gutterWidth / 2);
- margin-right: -(@gutterWidth / 2);
+ margin: -(@rowSpacing / 2) -(@gutterWidth / 2);
}
& when (@variationGridRelaxed) {
- .ui.relaxed.grid {
- margin-left: -(@relaxedGutterWidth / 2);
- margin-right: -(@relaxedGutterWidth / 2);
- }
- & when (@variationGridVeryRelaxed) {
- .ui[class*="very relaxed"].grid {
- margin-left: -(@veryRelaxedGutterWidth / 2);
- margin-right: -(@veryRelaxedGutterWidth / 2);
+ .ui.relaxed.grid {
+ margin-left: -(@relaxedGutterWidth / 2);
+ margin-right: -(@relaxedGutterWidth / 2);
+ }
+ & when (@variationGridVeryRelaxed) {
+ .ui[class*="very relaxed"].grid {
+ margin-left: -(@veryRelaxedGutterWidth / 2);
+ margin-right: -(@veryRelaxedGutterWidth / 2);
+ }
}
- }
}
-
/* Preserve Rows Spacing on Consecutive Grids */
.ui.grid + .grid {
- margin-top: @consecutiveGridDistance;
+ margin-top: @consecutiveGridDistance;
}
-/*-------------------
+/* -------------------
Columns
---------------------*/
+-------------------- */
/* Standard 16 column */
.ui.grid > .column:not(.row),
.ui.grid > .row > .column {
- position: relative;
- display: inline-block;
-
- width: @oneWide;
- padding-left: (@gutterWidth / 2);
- padding-right: (@gutterWidth / 2);
- vertical-align: top;
+ position: relative;
+ display: inline-block;
+ width: @oneWide;
+ padding-left: (@gutterWidth / 2);
+ padding-right: (@gutterWidth / 2);
+ vertical-align: top;
}
.ui.grid > * {
- padding-left: (@gutterWidth / 2);
- padding-right: (@gutterWidth / 2);
+ padding-left: (@gutterWidth / 2);
+ padding-right: (@gutterWidth / 2);
}
-/*-------------------
+/* -------------------
Rows
---------------------*/
+-------------------- */
.ui.grid > .row {
- position: relative;
- display: flex;
- flex-direction: row;
- flex-wrap: wrap;
- justify-content: inherit;
- align-items: stretch;
- width: 100% !important;
- padding: 0;
- padding-top: (@rowSpacing / 2);
- padding-bottom: (@rowSpacing / 2);
-}
-
-/*-------------------
+ position: relative;
+ display: flex;
+ flex-flow: row wrap;
+ justify-content: inherit;
+ align-items: stretch;
+ width: 100% !important;
+ padding: 0;
+ padding-top: (@rowSpacing / 2);
+ padding-bottom: (@rowSpacing / 2);
+}
+
+/* -------------------
Columns
---------------------*/
+-------------------- */
/* Vertical padding when no rows */
.ui.grid > .column:not(.row) {
- padding-top: (@rowSpacing / 2);
- padding-bottom: (@rowSpacing / 2);
+ padding-top: (@rowSpacing / 2);
+ padding-bottom: (@rowSpacing / 2);
}
.ui.grid > .row > .column {
- margin-top: 0;
- margin-bottom: 0;
+ margin-top: 0;
+ margin-bottom: 0;
}
-/*-------------------
+/* -------------------
Content
---------------------*/
+-------------------- */
.ui.grid > .row > img,
.ui.grid > .row > .column > img {
- max-width: @columnMaxImageWidth;
+ max-width: @columnMaxImageWidth;
}
-/*-------------------
+/* -------------------
Loose Coupling
---------------------*/
+-------------------- */
/* Collapse Margin on Consecutive Grid */
.ui.grid > .ui.grid:first-child {
- margin-top: 0;
+ margin-top: 0;
}
.ui.grid > .ui.grid:last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
/* Segment inside Aligned Grid */
.ui.grid .aligned.row > .column > .segment:not(.compact):not(.attached),
.ui.aligned.grid .column > .segment:not(.compact):not(.attached) {
- width: 100%;
+ width: 100%;
}
/* Align Dividers with Gutter */
.ui.grid .row + .ui.divider {
- flex-grow: 1;
- margin: (@rowSpacing / 2) (@gutterWidth / 2);
+ flex-grow: 1;
+ margin: (@rowSpacing / 2) (@gutterWidth / 2);
}
.ui.grid .column + .ui.vertical.divider {
- height: e(%("calc(50%% - %d)", (@rowSpacing / 2)));
+ height: e(%("calc(50%% - %d)", (@rowSpacing / 2)));
}
/* Remove Border on Last Horizontal Segment */
.ui.grid > .row > .column:last-child > .horizontal.segment,
.ui.grid > .column:last-child > .horizontal.segment {
- box-shadow: none;
+ box-shadow: none;
}
/*******************************
@@ -157,1837 +150,1826 @@
*******************************/
& when (@variationGridPage) {
- /*-----------------------
- Page Grid
- -------------------------*/
-
- @media only screen and (max-width: @largestMobileScreen) {
- .ui.page.grid {
- width: @mobileWidth;
- padding-left: @mobileGutter;
- padding-right: @mobileGutter;
- margin-left: 0;
- margin-right: 0;
- }
- }
- @media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) {
- .ui.page.grid {
- width: @tabletWidth;
- margin-left: @tabletMargin;
- margin-right: @tabletMargin;
- padding-left: @tabletGutter;
- padding-right: @tabletGutter;
- }
- }
- @media only screen and (min-width: @computerBreakpoint) and (max-width: @largestSmallMonitor) {
- .ui.page.grid {
- width: @computerWidth;
- margin-left: @computerMargin;
- margin-right: @computerMargin;
- padding-left: @computerGutter;
- padding-right: @computerGutter;
- }
- }
- @media only screen and (min-width: @largeMonitorBreakpoint) and (max-width: @largestLargeMonitor) {
- .ui.page.grid {
- width: @largeMonitorWidth;
- margin-left: @largeMonitorMargin;
- margin-right: @largeMonitorMargin;
- padding-left: @largeMonitorGutter;
- padding-right: @largeMonitorGutter;
- }
- }
- @media only screen and (min-width: @widescreenMonitorBreakpoint) {
- .ui.page.grid {
- width: @widescreenMonitorWidth;
- margin-left: @widescreenMargin;
- margin-right: @widescreenMargin;
- padding-left: @widescreenMonitorGutter;
- padding-right: @widescreenMonitorGutter;
- }
- }
-}
-
-
-/*-------------------
+ /* -----------------------
+ Page Grid
+ ------------------------- */
+
+ @media only screen and (max-width: @largestMobileScreen) {
+ .ui.page.grid {
+ width: @mobileWidth;
+ padding-left: @mobileGutter;
+ padding-right: @mobileGutter;
+ margin-left: 0;
+ margin-right: 0;
+ }
+ }
+ @media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) {
+ .ui.page.grid {
+ width: @tabletWidth;
+ margin-left: @tabletMargin;
+ margin-right: @tabletMargin;
+ padding-left: @tabletGutter;
+ padding-right: @tabletGutter;
+ }
+ }
+ @media only screen and (min-width: @computerBreakpoint) and (max-width: @largestSmallMonitor) {
+ .ui.page.grid {
+ width: @computerWidth;
+ margin-left: @computerMargin;
+ margin-right: @computerMargin;
+ padding-left: @computerGutter;
+ padding-right: @computerGutter;
+ }
+ }
+ @media only screen and (min-width: @largeMonitorBreakpoint) and (max-width: @largestLargeMonitor) {
+ .ui.page.grid {
+ width: @largeMonitorWidth;
+ margin-left: @largeMonitorMargin;
+ margin-right: @largeMonitorMargin;
+ padding-left: @largeMonitorGutter;
+ padding-right: @largeMonitorGutter;
+ }
+ }
+ @media only screen and (min-width: @widescreenMonitorBreakpoint) {
+ .ui.page.grid {
+ width: @widescreenMonitorWidth;
+ margin-left: @widescreenMargin;
+ margin-right: @widescreenMargin;
+ padding-left: @widescreenMonitorGutter;
+ padding-right: @widescreenMonitorGutter;
+ }
+ }
+}
+
+/* -------------------
Column Count
---------------------*/
+-------------------- */
/* Assume full width with one column */
.ui.grid > .column:only-child,
.ui.grid > .row > .column:only-child {
- width: @oneColumn;
+ width: @oneColumn;
}
/* Grid Based */
.ui[class*="one column"].grid > .row > .column,
.ui[class*="one column"].grid > .column:not(.row) {
- width: @oneColumn;
+ width: @oneColumn;
}
.ui[class*="two column"].grid > .row > .column,
.ui[class*="two column"].grid > .column:not(.row) {
- width: @twoColumn;
+ width: @twoColumn;
}
.ui[class*="three column"].grid > .row > .column,
.ui[class*="three column"].grid > .column:not(.row) {
- width: @threeColumn;
+ width: @threeColumn;
}
.ui[class*="four column"].grid > .row > .column,
.ui[class*="four column"].grid > .column:not(.row) {
- width: @fourColumn;
+ width: @fourColumn;
}
.ui[class*="five column"].grid > .row > .column,
.ui[class*="five column"].grid > .column:not(.row) {
- width: @fiveColumn;
+ width: @fiveColumn;
}
.ui[class*="six column"].grid > .row > .column,
.ui[class*="six column"].grid > .column:not(.row) {
- width: @sixColumn;
+ width: @sixColumn;
}
.ui[class*="seven column"].grid > .row > .column,
.ui[class*="seven column"].grid > .column:not(.row) {
- width: @sevenColumn;
+ width: @sevenColumn;
}
.ui[class*="eight column"].grid > .row > .column,
.ui[class*="eight column"].grid > .column:not(.row) {
- width: @eightColumn;
+ width: @eightColumn;
}
.ui[class*="nine column"].grid > .row > .column,
.ui[class*="nine column"].grid > .column:not(.row) {
- width: @nineColumn;
+ width: @nineColumn;
}
.ui[class*="ten column"].grid > .row > .column,
.ui[class*="ten column"].grid > .column:not(.row) {
- width: @tenColumn;
+ width: @tenColumn;
}
.ui[class*="eleven column"].grid > .row > .column,
.ui[class*="eleven column"].grid > .column:not(.row) {
- width: @elevenColumn;
+ width: @elevenColumn;
}
.ui[class*="twelve column"].grid > .row > .column,
.ui[class*="twelve column"].grid > .column:not(.row) {
- width: @twelveColumn;
+ width: @twelveColumn;
}
.ui[class*="thirteen column"].grid > .row > .column,
.ui[class*="thirteen column"].grid > .column:not(.row) {
- width: @thirteenColumn;
+ width: @thirteenColumn;
}
.ui[class*="fourteen column"].grid > .row > .column,
.ui[class*="fourteen column"].grid > .column:not(.row) {
- width: @fourteenColumn;
+ width: @fourteenColumn;
}
.ui[class*="fifteen column"].grid > .row > .column,
.ui[class*="fifteen column"].grid > .column:not(.row) {
- width: @fifteenColumn;
+ width: @fifteenColumn;
}
.ui[class*="sixteen column"].grid > .row > .column,
.ui[class*="sixteen column"].grid > .column:not(.row) {
- width: @sixteenColumn;
+ width: @sixteenColumn;
}
/* Row Based Overrides */
.ui.grid > [class*="one column"].row > .column {
- width: @oneColumn !important;
+ width: @oneColumn !important;
}
.ui.grid > [class*="two column"].row > .column {
- width: @twoColumn !important;
+ width: @twoColumn !important;
}
.ui.grid > [class*="three column"].row > .column {
- width: @threeColumn !important;
+ width: @threeColumn !important;
}
.ui.grid > [class*="four column"].row > .column {
- width: @fourColumn !important;
+ width: @fourColumn !important;
}
.ui.grid > [class*="five column"].row > .column {
- width: @fiveColumn !important;
+ width: @fiveColumn !important;
}
.ui.grid > [class*="six column"].row > .column {
- width: @sixColumn !important;
+ width: @sixColumn !important;
}
.ui.grid > [class*="seven column"].row > .column {
- width: @sevenColumn !important;
+ width: @sevenColumn !important;
}
.ui.grid > [class*="eight column"].row > .column {
- width: @eightColumn !important;
+ width: @eightColumn !important;
}
.ui.grid > [class*="nine column"].row > .column {
- width: @nineColumn !important;
+ width: @nineColumn !important;
}
.ui.grid > [class*="ten column"].row > .column {
- width: @tenColumn !important;
+ width: @tenColumn !important;
}
.ui.grid > [class*="eleven column"].row > .column {
- width: @elevenColumn !important;
+ width: @elevenColumn !important;
}
.ui.grid > [class*="twelve column"].row > .column {
- width: @twelveColumn !important;
+ width: @twelveColumn !important;
}
.ui.grid > [class*="thirteen column"].row > .column {
- width: @thirteenColumn !important;
+ width: @thirteenColumn !important;
}
.ui.grid > [class*="fourteen column"].row > .column {
- width: @fourteenColumn !important;
+ width: @fourteenColumn !important;
}
.ui.grid > [class*="fifteen column"].row > .column {
- width: @fifteenColumn !important;
+ width: @fifteenColumn !important;
}
.ui.grid > [class*="sixteen column"].row > .column {
- width: @sixteenColumn !important;
+ width: @sixteenColumn !important;
}
-& when (@variationGridCelled) and (@variationGridPage){
- /* Celled Page */
- .ui.celled.page.grid {
- box-shadow: none;
- }
+& when (@variationGridCelled) and (@variationGridPage) {
+ /* Celled Page */
+ .ui.celled.page.grid {
+ box-shadow: none;
+ }
}
& when (@variationGridWide) {
- /*-------------------
- Column Width
- --------------------*/
-
- /* Sizing Combinations */
- .ui.grid > .row > [class*="one wide"].column,
- .ui.grid > .column.row > [class*="one wide"].column,
- .ui.grid > [class*="one wide"].column,
- .ui.column.grid > [class*="one wide"].column {
- width: @oneWide !important;
- }
- .ui.grid > .row > [class*="two wide"].column,
- .ui.grid > .column.row > [class*="two wide"].column,
- .ui.grid > [class*="two wide"].column,
- .ui.column.grid > [class*="two wide"].column {
- width: @twoWide !important;
- }
- .ui.grid > .row > [class*="three wide"].column,
- .ui.grid > .column.row > [class*="three wide"].column,
- .ui.grid > [class*="three wide"].column,
- .ui.column.grid > [class*="three wide"].column {
- width: @threeWide !important;
- }
- .ui.grid > .row > [class*="four wide"].column,
- .ui.grid > .column.row > [class*="four wide"].column,
- .ui.grid > [class*="four wide"].column,
- .ui.column.grid > [class*="four wide"].column {
- width: @fourWide !important;
- }
- .ui.grid > .row > [class*="five wide"].column,
- .ui.grid > .column.row > [class*="five wide"].column,
- .ui.grid > [class*="five wide"].column,
- .ui.column.grid > [class*="five wide"].column {
- width: @fiveWide !important;
- }
- .ui.grid > .row > [class*="six wide"].column,
- .ui.grid > .column.row > [class*="six wide"].column,
- .ui.grid > [class*="six wide"].column,
- .ui.column.grid > [class*="six wide"].column {
- width: @sixWide !important;
- }
- .ui.grid > .row > [class*="seven wide"].column,
- .ui.grid > .column.row > [class*="seven wide"].column,
- .ui.grid > [class*="seven wide"].column,
- .ui.column.grid > [class*="seven wide"].column {
- width: @sevenWide !important;
- }
- .ui.grid > .row > [class*="eight wide"].column,
- .ui.grid > .column.row > [class*="eight wide"].column,
- .ui.grid > [class*="eight wide"].column,
- .ui.column.grid > [class*="eight wide"].column {
- width: @eightWide !important;
- }
- .ui.grid > .row > [class*="nine wide"].column,
- .ui.grid > .column.row > [class*="nine wide"].column,
- .ui.grid > [class*="nine wide"].column,
- .ui.column.grid > [class*="nine wide"].column {
- width: @nineWide !important;
- }
- .ui.grid > .row > [class*="ten wide"].column,
- .ui.grid > .column.row > [class*="ten wide"].column,
- .ui.grid > [class*="ten wide"].column,
- .ui.column.grid > [class*="ten wide"].column {
- width: @tenWide !important;
- }
- .ui.grid > .row > [class*="eleven wide"].column,
- .ui.grid > .column.row > [class*="eleven wide"].column,
- .ui.grid > [class*="eleven wide"].column,
- .ui.column.grid > [class*="eleven wide"].column {
- width: @elevenWide !important;
- }
- .ui.grid > .row > [class*="twelve wide"].column,
- .ui.grid > .column.row > [class*="twelve wide"].column,
- .ui.grid > [class*="twelve wide"].column,
- .ui.column.grid > [class*="twelve wide"].column {
- width: @twelveWide !important;
- }
- .ui.grid > .row > [class*="thirteen wide"].column,
- .ui.grid > .column.row > [class*="thirteen wide"].column,
- .ui.grid > [class*="thirteen wide"].column,
- .ui.column.grid > [class*="thirteen wide"].column {
- width: @thirteenWide !important;
- }
- .ui.grid > .row > [class*="fourteen wide"].column,
- .ui.grid > .column.row > [class*="fourteen wide"].column,
- .ui.grid > [class*="fourteen wide"].column,
- .ui.column.grid > [class*="fourteen wide"].column {
- width: @fourteenWide !important;
- }
- .ui.grid > .row > [class*="fifteen wide"].column,
- .ui.grid > .column.row > [class*="fifteen wide"].column,
- .ui.grid > [class*="fifteen wide"].column,
- .ui.column.grid > [class*="fifteen wide"].column {
- width: @fifteenWide !important;
- }
- .ui.grid > .row > [class*="sixteen wide"].column,
- .ui.grid > .column.row > [class*="sixteen wide"].column,
- .ui.grid > [class*="sixteen wide"].column,
- .ui.column.grid > [class*="sixteen wide"].column {
- width: @sixteenWide !important;
- }
-
- /*----------------------
- Width per Device
- -----------------------*/
-
- /* Mobile Sizing Combinations */
- @media only screen and (min-width: @mobileBreakpoint) and (max-width: @largestMobileScreen) {
- .ui.grid > .row > [class*="one wide mobile"].column,
- .ui.grid > .column.row > [class*="one wide mobile"].column,
- .ui.grid > [class*="one wide mobile"].column,
- .ui.column.grid > [class*="one wide mobile"].column {
- width: @oneWide !important;
- }
- .ui.grid > .row > [class*="two wide mobile"].column,
- .ui.grid > .column.row > [class*="two wide mobile"].column,
- .ui.grid > [class*="two wide mobile"].column,
- .ui.column.grid > [class*="two wide mobile"].column {
- width: @twoWide !important;
- }
- .ui.grid > .row > [class*="three wide mobile"].column,
- .ui.grid > .column.row > [class*="three wide mobile"].column,
- .ui.grid > [class*="three wide mobile"].column,
- .ui.column.grid > [class*="three wide mobile"].column {
- width: @threeWide !important;
- }
- .ui.grid > .row > [class*="four wide mobile"].column,
- .ui.grid > .column.row > [class*="four wide mobile"].column,
- .ui.grid > [class*="four wide mobile"].column,
- .ui.column.grid > [class*="four wide mobile"].column {
- width: @fourWide !important;
- }
- .ui.grid > .row > [class*="five wide mobile"].column,
- .ui.grid > .column.row > [class*="five wide mobile"].column,
- .ui.grid > [class*="five wide mobile"].column,
- .ui.column.grid > [class*="five wide mobile"].column {
- width: @fiveWide !important;
- }
- .ui.grid > .row > [class*="six wide mobile"].column,
- .ui.grid > .column.row > [class*="six wide mobile"].column,
- .ui.grid > [class*="six wide mobile"].column,
- .ui.column.grid > [class*="six wide mobile"].column {
- width: @sixWide !important;
- }
- .ui.grid > .row > [class*="seven wide mobile"].column,
- .ui.grid > .column.row > [class*="seven wide mobile"].column,
- .ui.grid > [class*="seven wide mobile"].column,
- .ui.column.grid > [class*="seven wide mobile"].column {
- width: @sevenWide !important;
- }
- .ui.grid > .row > [class*="eight wide mobile"].column,
- .ui.grid > .column.row > [class*="eight wide mobile"].column,
- .ui.grid > [class*="eight wide mobile"].column,
- .ui.column.grid > [class*="eight wide mobile"].column {
- width: @eightWide !important;
- }
- .ui.grid > .row > [class*="nine wide mobile"].column,
- .ui.grid > .column.row > [class*="nine wide mobile"].column,
- .ui.grid > [class*="nine wide mobile"].column,
- .ui.column.grid > [class*="nine wide mobile"].column {
- width: @nineWide !important;
- }
- .ui.grid > .row > [class*="ten wide mobile"].column,
- .ui.grid > .column.row > [class*="ten wide mobile"].column,
- .ui.grid > [class*="ten wide mobile"].column,
- .ui.column.grid > [class*="ten wide mobile"].column {
- width: @tenWide !important;
- }
- .ui.grid > .row > [class*="eleven wide mobile"].column,
- .ui.grid > .column.row > [class*="eleven wide mobile"].column,
- .ui.grid > [class*="eleven wide mobile"].column,
- .ui.column.grid > [class*="eleven wide mobile"].column {
- width: @elevenWide !important;
- }
- .ui.grid > .row > [class*="twelve wide mobile"].column,
- .ui.grid > .column.row > [class*="twelve wide mobile"].column,
- .ui.grid > [class*="twelve wide mobile"].column,
- .ui.column.grid > [class*="twelve wide mobile"].column {
- width: @twelveWide !important;
- }
- .ui.grid > .row > [class*="thirteen wide mobile"].column,
- .ui.grid > .column.row > [class*="thirteen wide mobile"].column,
- .ui.grid > [class*="thirteen wide mobile"].column,
- .ui.column.grid > [class*="thirteen wide mobile"].column {
- width: @thirteenWide !important;
- }
- .ui.grid > .row > [class*="fourteen wide mobile"].column,
- .ui.grid > .column.row > [class*="fourteen wide mobile"].column,
- .ui.grid > [class*="fourteen wide mobile"].column,
- .ui.column.grid > [class*="fourteen wide mobile"].column {
- width: @fourteenWide !important;
- }
- .ui.grid > .row > [class*="fifteen wide mobile"].column,
- .ui.grid > .column.row > [class*="fifteen wide mobile"].column,
- .ui.grid > [class*="fifteen wide mobile"].column,
- .ui.column.grid > [class*="fifteen wide mobile"].column {
- width: @fifteenWide !important;
- }
- .ui.grid > .row > [class*="sixteen wide mobile"].column,
- .ui.grid > .column.row > [class*="sixteen wide mobile"].column,
- .ui.grid > [class*="sixteen wide mobile"].column,
- .ui.column.grid > [class*="sixteen wide mobile"].column {
- width: @sixteenWide !important;
- }
- }
-
- /* Tablet Sizing Combinations */
- @media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) {
- .ui.grid > .row > [class*="one wide tablet"].column,
- .ui.grid > .column.row > [class*="one wide tablet"].column,
- .ui.grid > [class*="one wide tablet"].column,
- .ui.column.grid > [class*="one wide tablet"].column {
- width: @oneWide !important;
- }
- .ui.grid > .row > [class*="two wide tablet"].column,
- .ui.grid > .column.row > [class*="two wide tablet"].column,
- .ui.grid > [class*="two wide tablet"].column,
- .ui.column.grid > [class*="two wide tablet"].column {
- width: @twoWide !important;
- }
- .ui.grid > .row > [class*="three wide tablet"].column,
- .ui.grid > .column.row > [class*="three wide tablet"].column,
- .ui.grid > [class*="three wide tablet"].column,
- .ui.column.grid > [class*="three wide tablet"].column {
- width: @threeWide !important;
- }
- .ui.grid > .row > [class*="four wide tablet"].column,
- .ui.grid > .column.row > [class*="four wide tablet"].column,
- .ui.grid > [class*="four wide tablet"].column,
- .ui.column.grid > [class*="four wide tablet"].column {
- width: @fourWide !important;
- }
- .ui.grid > .row > [class*="five wide tablet"].column,
- .ui.grid > .column.row > [class*="five wide tablet"].column,
- .ui.grid > [class*="five wide tablet"].column,
- .ui.column.grid > [class*="five wide tablet"].column {
- width: @fiveWide !important;
- }
- .ui.grid > .row > [class*="six wide tablet"].column,
- .ui.grid > .column.row > [class*="six wide tablet"].column,
- .ui.grid > [class*="six wide tablet"].column,
- .ui.column.grid > [class*="six wide tablet"].column {
- width: @sixWide !important;
- }
- .ui.grid > .row > [class*="seven wide tablet"].column,
- .ui.grid > .column.row > [class*="seven wide tablet"].column,
- .ui.grid > [class*="seven wide tablet"].column,
- .ui.column.grid > [class*="seven wide tablet"].column {
- width: @sevenWide !important;
- }
- .ui.grid > .row > [class*="eight wide tablet"].column,
- .ui.grid > .column.row > [class*="eight wide tablet"].column,
- .ui.grid > [class*="eight wide tablet"].column,
- .ui.column.grid > [class*="eight wide tablet"].column {
- width: @eightWide !important;
- }
- .ui.grid > .row > [class*="nine wide tablet"].column,
- .ui.grid > .column.row > [class*="nine wide tablet"].column,
- .ui.grid > [class*="nine wide tablet"].column,
- .ui.column.grid > [class*="nine wide tablet"].column {
- width: @nineWide !important;
- }
- .ui.grid > .row > [class*="ten wide tablet"].column,
- .ui.grid > .column.row > [class*="ten wide tablet"].column,
- .ui.grid > [class*="ten wide tablet"].column,
- .ui.column.grid > [class*="ten wide tablet"].column {
- width: @tenWide !important;
- }
- .ui.grid > .row > [class*="eleven wide tablet"].column,
- .ui.grid > .column.row > [class*="eleven wide tablet"].column,
- .ui.grid > [class*="eleven wide tablet"].column,
- .ui.column.grid > [class*="eleven wide tablet"].column {
- width: @elevenWide !important;
- }
- .ui.grid > .row > [class*="twelve wide tablet"].column,
- .ui.grid > .column.row > [class*="twelve wide tablet"].column,
- .ui.grid > [class*="twelve wide tablet"].column,
- .ui.column.grid > [class*="twelve wide tablet"].column {
- width: @twelveWide !important;
- }
- .ui.grid > .row > [class*="thirteen wide tablet"].column,
- .ui.grid > .column.row > [class*="thirteen wide tablet"].column,
- .ui.grid > [class*="thirteen wide tablet"].column,
- .ui.column.grid > [class*="thirteen wide tablet"].column {
- width: @thirteenWide !important;
- }
- .ui.grid > .row > [class*="fourteen wide tablet"].column,
- .ui.grid > .column.row > [class*="fourteen wide tablet"].column,
- .ui.grid > [class*="fourteen wide tablet"].column,
- .ui.column.grid > [class*="fourteen wide tablet"].column {
- width: @fourteenWide !important;
- }
- .ui.grid > .row > [class*="fifteen wide tablet"].column,
- .ui.grid > .column.row > [class*="fifteen wide tablet"].column,
- .ui.grid > [class*="fifteen wide tablet"].column,
- .ui.column.grid > [class*="fifteen wide tablet"].column {
- width: @fifteenWide !important;
- }
- .ui.grid > .row > [class*="sixteen wide tablet"].column,
- .ui.grid > .column.row > [class*="sixteen wide tablet"].column,
- .ui.grid > [class*="sixteen wide tablet"].column,
- .ui.column.grid > [class*="sixteen wide tablet"].column {
- width: @sixteenWide !important;
- }
- }
-
- /* Computer/Desktop Sizing Combinations */
- @media only screen and (min-width: @computerBreakpoint) {
- .ui.grid > .row > [class*="one wide computer"].column,
- .ui.grid > .column.row > [class*="one wide computer"].column,
- .ui.grid > [class*="one wide computer"].column,
- .ui.column.grid > [class*="one wide computer"].column {
- width: @oneWide !important;
- }
- .ui.grid > .row > [class*="two wide computer"].column,
- .ui.grid > .column.row > [class*="two wide computer"].column,
- .ui.grid > [class*="two wide computer"].column,
- .ui.column.grid > [class*="two wide computer"].column {
- width: @twoWide !important;
- }
- .ui.grid > .row > [class*="three wide computer"].column,
- .ui.grid > .column.row > [class*="three wide computer"].column,
- .ui.grid > [class*="three wide computer"].column,
- .ui.column.grid > [class*="three wide computer"].column {
- width: @threeWide !important;
- }
- .ui.grid > .row > [class*="four wide computer"].column,
- .ui.grid > .column.row > [class*="four wide computer"].column,
- .ui.grid > [class*="four wide computer"].column,
- .ui.column.grid > [class*="four wide computer"].column {
- width: @fourWide !important;
- }
- .ui.grid > .row > [class*="five wide computer"].column,
- .ui.grid > .column.row > [class*="five wide computer"].column,
- .ui.grid > [class*="five wide computer"].column,
- .ui.column.grid > [class*="five wide computer"].column {
- width: @fiveWide !important;
- }
- .ui.grid > .row > [class*="six wide computer"].column,
- .ui.grid > .column.row > [class*="six wide computer"].column,
- .ui.grid > [class*="six wide computer"].column,
- .ui.column.grid > [class*="six wide computer"].column {
- width: @sixWide !important;
- }
- .ui.grid > .row > [class*="seven wide computer"].column,
- .ui.grid > .column.row > [class*="seven wide computer"].column,
- .ui.grid > [class*="seven wide computer"].column,
- .ui.column.grid > [class*="seven wide computer"].column {
- width: @sevenWide !important;
- }
- .ui.grid > .row > [class*="eight wide computer"].column,
- .ui.grid > .column.row > [class*="eight wide computer"].column,
- .ui.grid > [class*="eight wide computer"].column,
- .ui.column.grid > [class*="eight wide computer"].column {
- width: @eightWide !important;
- }
- .ui.grid > .row > [class*="nine wide computer"].column,
- .ui.grid > .column.row > [class*="nine wide computer"].column,
- .ui.grid > [class*="nine wide computer"].column,
- .ui.column.grid > [class*="nine wide computer"].column {
- width: @nineWide !important;
- }
- .ui.grid > .row > [class*="ten wide computer"].column,
- .ui.grid > .column.row > [class*="ten wide computer"].column,
- .ui.grid > [class*="ten wide computer"].column,
- .ui.column.grid > [class*="ten wide computer"].column {
- width: @tenWide !important;
- }
- .ui.grid > .row > [class*="eleven wide computer"].column,
- .ui.grid > .column.row > [class*="eleven wide computer"].column,
- .ui.grid > [class*="eleven wide computer"].column,
- .ui.column.grid > [class*="eleven wide computer"].column {
- width: @elevenWide !important;
- }
- .ui.grid > .row > [class*="twelve wide computer"].column,
- .ui.grid > .column.row > [class*="twelve wide computer"].column,
- .ui.grid > [class*="twelve wide computer"].column,
- .ui.column.grid > [class*="twelve wide computer"].column {
- width: @twelveWide !important;
- }
- .ui.grid > .row > [class*="thirteen wide computer"].column,
- .ui.grid > .column.row > [class*="thirteen wide computer"].column,
- .ui.grid > [class*="thirteen wide computer"].column,
- .ui.column.grid > [class*="thirteen wide computer"].column {
- width: @thirteenWide !important;
- }
- .ui.grid > .row > [class*="fourteen wide computer"].column,
- .ui.grid > .column.row > [class*="fourteen wide computer"].column,
- .ui.grid > [class*="fourteen wide computer"].column,
- .ui.column.grid > [class*="fourteen wide computer"].column {
- width: @fourteenWide !important;
- }
- .ui.grid > .row > [class*="fifteen wide computer"].column,
- .ui.grid > .column.row > [class*="fifteen wide computer"].column,
- .ui.grid > [class*="fifteen wide computer"].column,
- .ui.column.grid > [class*="fifteen wide computer"].column {
- width: @fifteenWide !important;
- }
- .ui.grid > .row > [class*="sixteen wide computer"].column,
- .ui.grid > .column.row > [class*="sixteen wide computer"].column,
- .ui.grid > [class*="sixteen wide computer"].column,
- .ui.column.grid > [class*="sixteen wide computer"].column {
- width: @sixteenWide !important;
- }
- }
-
- /* Large Monitor Sizing Combinations */
- @media only screen and (min-width: @largeMonitorBreakpoint) and (max-width: @largestLargeMonitor) {
- .ui.grid > .row > [class*="one wide large screen"].column,
- .ui.grid > .column.row > [class*="one wide large screen"].column,
- .ui.grid > [class*="one wide large screen"].column,
- .ui.column.grid > [class*="one wide large screen"].column {
- width: @oneWide !important;
- }
- .ui.grid > .row > [class*="two wide large screen"].column,
- .ui.grid > .column.row > [class*="two wide large screen"].column,
- .ui.grid > [class*="two wide large screen"].column,
- .ui.column.grid > [class*="two wide large screen"].column {
- width: @twoWide !important;
- }
- .ui.grid > .row > [class*="three wide large screen"].column,
- .ui.grid > .column.row > [class*="three wide large screen"].column,
- .ui.grid > [class*="three wide large screen"].column,
- .ui.column.grid > [class*="three wide large screen"].column {
- width: @threeWide !important;
- }
- .ui.grid > .row > [class*="four wide large screen"].column,
- .ui.grid > .column.row > [class*="four wide large screen"].column,
- .ui.grid > [class*="four wide large screen"].column,
- .ui.column.grid > [class*="four wide large screen"].column {
- width: @fourWide !important;
- }
- .ui.grid > .row > [class*="five wide large screen"].column,
- .ui.grid > .column.row > [class*="five wide large screen"].column,
- .ui.grid > [class*="five wide large screen"].column,
- .ui.column.grid > [class*="five wide large screen"].column {
- width: @fiveWide !important;
- }
- .ui.grid > .row > [class*="six wide large screen"].column,
- .ui.grid > .column.row > [class*="six wide large screen"].column,
- .ui.grid > [class*="six wide large screen"].column,
- .ui.column.grid > [class*="six wide large screen"].column {
- width: @sixWide !important;
- }
- .ui.grid > .row > [class*="seven wide large screen"].column,
- .ui.grid > .column.row > [class*="seven wide large screen"].column,
- .ui.grid > [class*="seven wide large screen"].column,
- .ui.column.grid > [class*="seven wide large screen"].column {
- width: @sevenWide !important;
- }
- .ui.grid > .row > [class*="eight wide large screen"].column,
- .ui.grid > .column.row > [class*="eight wide large screen"].column,
- .ui.grid > [class*="eight wide large screen"].column,
- .ui.column.grid > [class*="eight wide large screen"].column {
- width: @eightWide !important;
- }
- .ui.grid > .row > [class*="nine wide large screen"].column,
- .ui.grid > .column.row > [class*="nine wide large screen"].column,
- .ui.grid > [class*="nine wide large screen"].column,
- .ui.column.grid > [class*="nine wide large screen"].column {
- width: @nineWide !important;
- }
- .ui.grid > .row > [class*="ten wide large screen"].column,
- .ui.grid > .column.row > [class*="ten wide large screen"].column,
- .ui.grid > [class*="ten wide large screen"].column,
- .ui.column.grid > [class*="ten wide large screen"].column {
- width: @tenWide !important;
- }
- .ui.grid > .row > [class*="eleven wide large screen"].column,
- .ui.grid > .column.row > [class*="eleven wide large screen"].column,
- .ui.grid > [class*="eleven wide large screen"].column,
- .ui.column.grid > [class*="eleven wide large screen"].column {
- width: @elevenWide !important;
- }
- .ui.grid > .row > [class*="twelve wide large screen"].column,
- .ui.grid > .column.row > [class*="twelve wide large screen"].column,
- .ui.grid > [class*="twelve wide large screen"].column,
- .ui.column.grid > [class*="twelve wide large screen"].column {
- width: @twelveWide !important;
- }
- .ui.grid > .row > [class*="thirteen wide large screen"].column,
- .ui.grid > .column.row > [class*="thirteen wide large screen"].column,
- .ui.grid > [class*="thirteen wide large screen"].column,
- .ui.column.grid > [class*="thirteen wide large screen"].column {
- width: @thirteenWide !important;
- }
- .ui.grid > .row > [class*="fourteen wide large screen"].column,
- .ui.grid > .column.row > [class*="fourteen wide large screen"].column,
- .ui.grid > [class*="fourteen wide large screen"].column,
- .ui.column.grid > [class*="fourteen wide large screen"].column {
- width: @fourteenWide !important;
- }
- .ui.grid > .row > [class*="fifteen wide large screen"].column,
- .ui.grid > .column.row > [class*="fifteen wide large screen"].column,
- .ui.grid > [class*="fifteen wide large screen"].column,
- .ui.column.grid > [class*="fifteen wide large screen"].column {
- width: @fifteenWide !important;
- }
- .ui.grid > .row > [class*="sixteen wide large screen"].column,
- .ui.grid > .column.row > [class*="sixteen wide large screen"].column,
- .ui.grid > [class*="sixteen wide large screen"].column,
- .ui.column.grid > [class*="sixteen wide large screen"].column {
- width: @sixteenWide !important;
- }
- }
-
- /* Widescreen Sizing Combinations */
- @media only screen and (min-width: @widescreenMonitorBreakpoint) {
- .ui.grid > .row > [class*="one wide widescreen"].column,
- .ui.grid > .column.row > [class*="one wide widescreen"].column,
- .ui.grid > [class*="one wide widescreen"].column,
- .ui.column.grid > [class*="one wide widescreen"].column {
- width: @oneWide !important;
- }
- .ui.grid > .row > [class*="two wide widescreen"].column,
- .ui.grid > .column.row > [class*="two wide widescreen"].column,
- .ui.grid > [class*="two wide widescreen"].column,
- .ui.column.grid > [class*="two wide widescreen"].column {
- width: @twoWide !important;
- }
- .ui.grid > .row > [class*="three wide widescreen"].column,
- .ui.grid > .column.row > [class*="three wide widescreen"].column,
- .ui.grid > [class*="three wide widescreen"].column,
- .ui.column.grid > [class*="three wide widescreen"].column {
- width: @threeWide !important;
- }
- .ui.grid > .row > [class*="four wide widescreen"].column,
- .ui.grid > .column.row > [class*="four wide widescreen"].column,
- .ui.grid > [class*="four wide widescreen"].column,
- .ui.column.grid > [class*="four wide widescreen"].column {
- width: @fourWide !important;
- }
- .ui.grid > .row > [class*="five wide widescreen"].column,
- .ui.grid > .column.row > [class*="five wide widescreen"].column,
- .ui.grid > [class*="five wide widescreen"].column,
- .ui.column.grid > [class*="five wide widescreen"].column {
- width: @fiveWide !important;
- }
- .ui.grid > .row > [class*="six wide widescreen"].column,
- .ui.grid > .column.row > [class*="six wide widescreen"].column,
- .ui.grid > [class*="six wide widescreen"].column,
- .ui.column.grid > [class*="six wide widescreen"].column {
- width: @sixWide !important;
- }
- .ui.grid > .row > [class*="seven wide widescreen"].column,
- .ui.grid > .column.row > [class*="seven wide widescreen"].column,
- .ui.grid > [class*="seven wide widescreen"].column,
- .ui.column.grid > [class*="seven wide widescreen"].column {
- width: @sevenWide !important;
- }
- .ui.grid > .row > [class*="eight wide widescreen"].column,
- .ui.grid > .column.row > [class*="eight wide widescreen"].column,
- .ui.grid > [class*="eight wide widescreen"].column,
- .ui.column.grid > [class*="eight wide widescreen"].column {
- width: @eightWide !important;
- }
- .ui.grid > .row > [class*="nine wide widescreen"].column,
- .ui.grid > .column.row > [class*="nine wide widescreen"].column,
- .ui.grid > [class*="nine wide widescreen"].column,
- .ui.column.grid > [class*="nine wide widescreen"].column {
- width: @nineWide !important;
- }
- .ui.grid > .row > [class*="ten wide widescreen"].column,
- .ui.grid > .column.row > [class*="ten wide widescreen"].column,
- .ui.grid > [class*="ten wide widescreen"].column,
- .ui.column.grid > [class*="ten wide widescreen"].column {
- width: @tenWide !important;
- }
- .ui.grid > .row > [class*="eleven wide widescreen"].column,
- .ui.grid > .column.row > [class*="eleven wide widescreen"].column,
- .ui.grid > [class*="eleven wide widescreen"].column,
- .ui.column.grid > [class*="eleven wide widescreen"].column {
- width: @elevenWide !important;
- }
- .ui.grid > .row > [class*="twelve wide widescreen"].column,
- .ui.grid > .column.row > [class*="twelve wide widescreen"].column,
- .ui.grid > [class*="twelve wide widescreen"].column,
- .ui.column.grid > [class*="twelve wide widescreen"].column {
- width: @twelveWide !important;
- }
- .ui.grid > .row > [class*="thirteen wide widescreen"].column,
- .ui.grid > .column.row > [class*="thirteen wide widescreen"].column,
- .ui.grid > [class*="thirteen wide widescreen"].column,
- .ui.column.grid > [class*="thirteen wide widescreen"].column {
- width: @thirteenWide !important;
- }
- .ui.grid > .row > [class*="fourteen wide widescreen"].column,
- .ui.grid > .column.row > [class*="fourteen wide widescreen"].column,
- .ui.grid > [class*="fourteen wide widescreen"].column,
- .ui.column.grid > [class*="fourteen wide widescreen"].column {
- width: @fourteenWide !important;
- }
- .ui.grid > .row > [class*="fifteen wide widescreen"].column,
- .ui.grid > .column.row > [class*="fifteen wide widescreen"].column,
- .ui.grid > [class*="fifteen wide widescreen"].column,
- .ui.column.grid > [class*="fifteen wide widescreen"].column {
- width: @fifteenWide !important;
- }
- .ui.grid > .row > [class*="sixteen wide widescreen"].column,
- .ui.grid > .column.row > [class*="sixteen wide widescreen"].column,
- .ui.grid > [class*="sixteen wide widescreen"].column,
- .ui.column.grid > [class*="sixteen wide widescreen"].column {
- width: @sixteenWide !important;
- }
- }
+ /* -------------------
+ Column Width
+ -------------------- */
+
+ /* Sizing Combinations */
+ .ui.grid > .row > [class*="one wide"].column,
+ .ui.grid > .column.row > [class*="one wide"].column,
+ .ui.grid > [class*="one wide"].column,
+ .ui.column.grid > [class*="one wide"].column {
+ width: @oneWide !important;
+ }
+ .ui.grid > .row > [class*="two wide"].column,
+ .ui.grid > .column.row > [class*="two wide"].column,
+ .ui.grid > [class*="two wide"].column,
+ .ui.column.grid > [class*="two wide"].column {
+ width: @twoWide !important;
+ }
+ .ui.grid > .row > [class*="three wide"].column,
+ .ui.grid > .column.row > [class*="three wide"].column,
+ .ui.grid > [class*="three wide"].column,
+ .ui.column.grid > [class*="three wide"].column {
+ width: @threeWide !important;
+ }
+ .ui.grid > .row > [class*="four wide"].column,
+ .ui.grid > .column.row > [class*="four wide"].column,
+ .ui.grid > [class*="four wide"].column,
+ .ui.column.grid > [class*="four wide"].column {
+ width: @fourWide !important;
+ }
+ .ui.grid > .row > [class*="five wide"].column,
+ .ui.grid > .column.row > [class*="five wide"].column,
+ .ui.grid > [class*="five wide"].column,
+ .ui.column.grid > [class*="five wide"].column {
+ width: @fiveWide !important;
+ }
+ .ui.grid > .row > [class*="six wide"].column,
+ .ui.grid > .column.row > [class*="six wide"].column,
+ .ui.grid > [class*="six wide"].column,
+ .ui.column.grid > [class*="six wide"].column {
+ width: @sixWide !important;
+ }
+ .ui.grid > .row > [class*="seven wide"].column,
+ .ui.grid > .column.row > [class*="seven wide"].column,
+ .ui.grid > [class*="seven wide"].column,
+ .ui.column.grid > [class*="seven wide"].column {
+ width: @sevenWide !important;
+ }
+ .ui.grid > .row > [class*="eight wide"].column,
+ .ui.grid > .column.row > [class*="eight wide"].column,
+ .ui.grid > [class*="eight wide"].column,
+ .ui.column.grid > [class*="eight wide"].column {
+ width: @eightWide !important;
+ }
+ .ui.grid > .row > [class*="nine wide"].column,
+ .ui.grid > .column.row > [class*="nine wide"].column,
+ .ui.grid > [class*="nine wide"].column,
+ .ui.column.grid > [class*="nine wide"].column {
+ width: @nineWide !important;
+ }
+ .ui.grid > .row > [class*="ten wide"].column,
+ .ui.grid > .column.row > [class*="ten wide"].column,
+ .ui.grid > [class*="ten wide"].column,
+ .ui.column.grid > [class*="ten wide"].column {
+ width: @tenWide !important;
+ }
+ .ui.grid > .row > [class*="eleven wide"].column,
+ .ui.grid > .column.row > [class*="eleven wide"].column,
+ .ui.grid > [class*="eleven wide"].column,
+ .ui.column.grid > [class*="eleven wide"].column {
+ width: @elevenWide !important;
+ }
+ .ui.grid > .row > [class*="twelve wide"].column,
+ .ui.grid > .column.row > [class*="twelve wide"].column,
+ .ui.grid > [class*="twelve wide"].column,
+ .ui.column.grid > [class*="twelve wide"].column {
+ width: @twelveWide !important;
+ }
+ .ui.grid > .row > [class*="thirteen wide"].column,
+ .ui.grid > .column.row > [class*="thirteen wide"].column,
+ .ui.grid > [class*="thirteen wide"].column,
+ .ui.column.grid > [class*="thirteen wide"].column {
+ width: @thirteenWide !important;
+ }
+ .ui.grid > .row > [class*="fourteen wide"].column,
+ .ui.grid > .column.row > [class*="fourteen wide"].column,
+ .ui.grid > [class*="fourteen wide"].column,
+ .ui.column.grid > [class*="fourteen wide"].column {
+ width: @fourteenWide !important;
+ }
+ .ui.grid > .row > [class*="fifteen wide"].column,
+ .ui.grid > .column.row > [class*="fifteen wide"].column,
+ .ui.grid > [class*="fifteen wide"].column,
+ .ui.column.grid > [class*="fifteen wide"].column {
+ width: @fifteenWide !important;
+ }
+ .ui.grid > .row > [class*="sixteen wide"].column,
+ .ui.grid > .column.row > [class*="sixteen wide"].column,
+ .ui.grid > [class*="sixteen wide"].column,
+ .ui.column.grid > [class*="sixteen wide"].column {
+ width: @sixteenWide !important;
+ }
+
+ /* ----------------------
+ Width per Device
+ ----------------------- */
+
+ /* Mobile Sizing Combinations */
+ @media only screen and (min-width: @mobileBreakpoint) and (max-width: @largestMobileScreen) {
+ .ui.grid > .row > [class*="one wide mobile"].column,
+ .ui.grid > .column.row > [class*="one wide mobile"].column,
+ .ui.grid > [class*="one wide mobile"].column,
+ .ui.column.grid > [class*="one wide mobile"].column {
+ width: @oneWide !important;
+ }
+ .ui.grid > .row > [class*="two wide mobile"].column,
+ .ui.grid > .column.row > [class*="two wide mobile"].column,
+ .ui.grid > [class*="two wide mobile"].column,
+ .ui.column.grid > [class*="two wide mobile"].column {
+ width: @twoWide !important;
+ }
+ .ui.grid > .row > [class*="three wide mobile"].column,
+ .ui.grid > .column.row > [class*="three wide mobile"].column,
+ .ui.grid > [class*="three wide mobile"].column,
+ .ui.column.grid > [class*="three wide mobile"].column {
+ width: @threeWide !important;
+ }
+ .ui.grid > .row > [class*="four wide mobile"].column,
+ .ui.grid > .column.row > [class*="four wide mobile"].column,
+ .ui.grid > [class*="four wide mobile"].column,
+ .ui.column.grid > [class*="four wide mobile"].column {
+ width: @fourWide !important;
+ }
+ .ui.grid > .row > [class*="five wide mobile"].column,
+ .ui.grid > .column.row > [class*="five wide mobile"].column,
+ .ui.grid > [class*="five wide mobile"].column,
+ .ui.column.grid > [class*="five wide mobile"].column {
+ width: @fiveWide !important;
+ }
+ .ui.grid > .row > [class*="six wide mobile"].column,
+ .ui.grid > .column.row > [class*="six wide mobile"].column,
+ .ui.grid > [class*="six wide mobile"].column,
+ .ui.column.grid > [class*="six wide mobile"].column {
+ width: @sixWide !important;
+ }
+ .ui.grid > .row > [class*="seven wide mobile"].column,
+ .ui.grid > .column.row > [class*="seven wide mobile"].column,
+ .ui.grid > [class*="seven wide mobile"].column,
+ .ui.column.grid > [class*="seven wide mobile"].column {
+ width: @sevenWide !important;
+ }
+ .ui.grid > .row > [class*="eight wide mobile"].column,
+ .ui.grid > .column.row > [class*="eight wide mobile"].column,
+ .ui.grid > [class*="eight wide mobile"].column,
+ .ui.column.grid > [class*="eight wide mobile"].column {
+ width: @eightWide !important;
+ }
+ .ui.grid > .row > [class*="nine wide mobile"].column,
+ .ui.grid > .column.row > [class*="nine wide mobile"].column,
+ .ui.grid > [class*="nine wide mobile"].column,
+ .ui.column.grid > [class*="nine wide mobile"].column {
+ width: @nineWide !important;
+ }
+ .ui.grid > .row > [class*="ten wide mobile"].column,
+ .ui.grid > .column.row > [class*="ten wide mobile"].column,
+ .ui.grid > [class*="ten wide mobile"].column,
+ .ui.column.grid > [class*="ten wide mobile"].column {
+ width: @tenWide !important;
+ }
+ .ui.grid > .row > [class*="eleven wide mobile"].column,
+ .ui.grid > .column.row > [class*="eleven wide mobile"].column,
+ .ui.grid > [class*="eleven wide mobile"].column,
+ .ui.column.grid > [class*="eleven wide mobile"].column {
+ width: @elevenWide !important;
+ }
+ .ui.grid > .row > [class*="twelve wide mobile"].column,
+ .ui.grid > .column.row > [class*="twelve wide mobile"].column,
+ .ui.grid > [class*="twelve wide mobile"].column,
+ .ui.column.grid > [class*="twelve wide mobile"].column {
+ width: @twelveWide !important;
+ }
+ .ui.grid > .row > [class*="thirteen wide mobile"].column,
+ .ui.grid > .column.row > [class*="thirteen wide mobile"].column,
+ .ui.grid > [class*="thirteen wide mobile"].column,
+ .ui.column.grid > [class*="thirteen wide mobile"].column {
+ width: @thirteenWide !important;
+ }
+ .ui.grid > .row > [class*="fourteen wide mobile"].column,
+ .ui.grid > .column.row > [class*="fourteen wide mobile"].column,
+ .ui.grid > [class*="fourteen wide mobile"].column,
+ .ui.column.grid > [class*="fourteen wide mobile"].column {
+ width: @fourteenWide !important;
+ }
+ .ui.grid > .row > [class*="fifteen wide mobile"].column,
+ .ui.grid > .column.row > [class*="fifteen wide mobile"].column,
+ .ui.grid > [class*="fifteen wide mobile"].column,
+ .ui.column.grid > [class*="fifteen wide mobile"].column {
+ width: @fifteenWide !important;
+ }
+ .ui.grid > .row > [class*="sixteen wide mobile"].column,
+ .ui.grid > .column.row > [class*="sixteen wide mobile"].column,
+ .ui.grid > [class*="sixteen wide mobile"].column,
+ .ui.column.grid > [class*="sixteen wide mobile"].column {
+ width: @sixteenWide !important;
+ }
+ }
+
+ /* Tablet Sizing Combinations */
+ @media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) {
+ .ui.grid > .row > [class*="one wide tablet"].column,
+ .ui.grid > .column.row > [class*="one wide tablet"].column,
+ .ui.grid > [class*="one wide tablet"].column,
+ .ui.column.grid > [class*="one wide tablet"].column {
+ width: @oneWide !important;
+ }
+ .ui.grid > .row > [class*="two wide tablet"].column,
+ .ui.grid > .column.row > [class*="two wide tablet"].column,
+ .ui.grid > [class*="two wide tablet"].column,
+ .ui.column.grid > [class*="two wide tablet"].column {
+ width: @twoWide !important;
+ }
+ .ui.grid > .row > [class*="three wide tablet"].column,
+ .ui.grid > .column.row > [class*="three wide tablet"].column,
+ .ui.grid > [class*="three wide tablet"].column,
+ .ui.column.grid > [class*="three wide tablet"].column {
+ width: @threeWide !important;
+ }
+ .ui.grid > .row > [class*="four wide tablet"].column,
+ .ui.grid > .column.row > [class*="four wide tablet"].column,
+ .ui.grid > [class*="four wide tablet"].column,
+ .ui.column.grid > [class*="four wide tablet"].column {
+ width: @fourWide !important;
+ }
+ .ui.grid > .row > [class*="five wide tablet"].column,
+ .ui.grid > .column.row > [class*="five wide tablet"].column,
+ .ui.grid > [class*="five wide tablet"].column,
+ .ui.column.grid > [class*="five wide tablet"].column {
+ width: @fiveWide !important;
+ }
+ .ui.grid > .row > [class*="six wide tablet"].column,
+ .ui.grid > .column.row > [class*="six wide tablet"].column,
+ .ui.grid > [class*="six wide tablet"].column,
+ .ui.column.grid > [class*="six wide tablet"].column {
+ width: @sixWide !important;
+ }
+ .ui.grid > .row > [class*="seven wide tablet"].column,
+ .ui.grid > .column.row > [class*="seven wide tablet"].column,
+ .ui.grid > [class*="seven wide tablet"].column,
+ .ui.column.grid > [class*="seven wide tablet"].column {
+ width: @sevenWide !important;
+ }
+ .ui.grid > .row > [class*="eight wide tablet"].column,
+ .ui.grid > .column.row > [class*="eight wide tablet"].column,
+ .ui.grid > [class*="eight wide tablet"].column,
+ .ui.column.grid > [class*="eight wide tablet"].column {
+ width: @eightWide !important;
+ }
+ .ui.grid > .row > [class*="nine wide tablet"].column,
+ .ui.grid > .column.row > [class*="nine wide tablet"].column,
+ .ui.grid > [class*="nine wide tablet"].column,
+ .ui.column.grid > [class*="nine wide tablet"].column {
+ width: @nineWide !important;
+ }
+ .ui.grid > .row > [class*="ten wide tablet"].column,
+ .ui.grid > .column.row > [class*="ten wide tablet"].column,
+ .ui.grid > [class*="ten wide tablet"].column,
+ .ui.column.grid > [class*="ten wide tablet"].column {
+ width: @tenWide !important;
+ }
+ .ui.grid > .row > [class*="eleven wide tablet"].column,
+ .ui.grid > .column.row > [class*="eleven wide tablet"].column,
+ .ui.grid > [class*="eleven wide tablet"].column,
+ .ui.column.grid > [class*="eleven wide tablet"].column {
+ width: @elevenWide !important;
+ }
+ .ui.grid > .row > [class*="twelve wide tablet"].column,
+ .ui.grid > .column.row > [class*="twelve wide tablet"].column,
+ .ui.grid > [class*="twelve wide tablet"].column,
+ .ui.column.grid > [class*="twelve wide tablet"].column {
+ width: @twelveWide !important;
+ }
+ .ui.grid > .row > [class*="thirteen wide tablet"].column,
+ .ui.grid > .column.row > [class*="thirteen wide tablet"].column,
+ .ui.grid > [class*="thirteen wide tablet"].column,
+ .ui.column.grid > [class*="thirteen wide tablet"].column {
+ width: @thirteenWide !important;
+ }
+ .ui.grid > .row > [class*="fourteen wide tablet"].column,
+ .ui.grid > .column.row > [class*="fourteen wide tablet"].column,
+ .ui.grid > [class*="fourteen wide tablet"].column,
+ .ui.column.grid > [class*="fourteen wide tablet"].column {
+ width: @fourteenWide !important;
+ }
+ .ui.grid > .row > [class*="fifteen wide tablet"].column,
+ .ui.grid > .column.row > [class*="fifteen wide tablet"].column,
+ .ui.grid > [class*="fifteen wide tablet"].column,
+ .ui.column.grid > [class*="fifteen wide tablet"].column {
+ width: @fifteenWide !important;
+ }
+ .ui.grid > .row > [class*="sixteen wide tablet"].column,
+ .ui.grid > .column.row > [class*="sixteen wide tablet"].column,
+ .ui.grid > [class*="sixteen wide tablet"].column,
+ .ui.column.grid > [class*="sixteen wide tablet"].column {
+ width: @sixteenWide !important;
+ }
+ }
+
+ /* Computer/Desktop Sizing Combinations */
+ @media only screen and (min-width: @computerBreakpoint) {
+ .ui.grid > .row > [class*="one wide computer"].column,
+ .ui.grid > .column.row > [class*="one wide computer"].column,
+ .ui.grid > [class*="one wide computer"].column,
+ .ui.column.grid > [class*="one wide computer"].column {
+ width: @oneWide !important;
+ }
+ .ui.grid > .row > [class*="two wide computer"].column,
+ .ui.grid > .column.row > [class*="two wide computer"].column,
+ .ui.grid > [class*="two wide computer"].column,
+ .ui.column.grid > [class*="two wide computer"].column {
+ width: @twoWide !important;
+ }
+ .ui.grid > .row > [class*="three wide computer"].column,
+ .ui.grid > .column.row > [class*="three wide computer"].column,
+ .ui.grid > [class*="three wide computer"].column,
+ .ui.column.grid > [class*="three wide computer"].column {
+ width: @threeWide !important;
+ }
+ .ui.grid > .row > [class*="four wide computer"].column,
+ .ui.grid > .column.row > [class*="four wide computer"].column,
+ .ui.grid > [class*="four wide computer"].column,
+ .ui.column.grid > [class*="four wide computer"].column {
+ width: @fourWide !important;
+ }
+ .ui.grid > .row > [class*="five wide computer"].column,
+ .ui.grid > .column.row > [class*="five wide computer"].column,
+ .ui.grid > [class*="five wide computer"].column,
+ .ui.column.grid > [class*="five wide computer"].column {
+ width: @fiveWide !important;
+ }
+ .ui.grid > .row > [class*="six wide computer"].column,
+ .ui.grid > .column.row > [class*="six wide computer"].column,
+ .ui.grid > [class*="six wide computer"].column,
+ .ui.column.grid > [class*="six wide computer"].column {
+ width: @sixWide !important;
+ }
+ .ui.grid > .row > [class*="seven wide computer"].column,
+ .ui.grid > .column.row > [class*="seven wide computer"].column,
+ .ui.grid > [class*="seven wide computer"].column,
+ .ui.column.grid > [class*="seven wide computer"].column {
+ width: @sevenWide !important;
+ }
+ .ui.grid > .row > [class*="eight wide computer"].column,
+ .ui.grid > .column.row > [class*="eight wide computer"].column,
+ .ui.grid > [class*="eight wide computer"].column,
+ .ui.column.grid > [class*="eight wide computer"].column {
+ width: @eightWide !important;
+ }
+ .ui.grid > .row > [class*="nine wide computer"].column,
+ .ui.grid > .column.row > [class*="nine wide computer"].column,
+ .ui.grid > [class*="nine wide computer"].column,
+ .ui.column.grid > [class*="nine wide computer"].column {
+ width: @nineWide !important;
+ }
+ .ui.grid > .row > [class*="ten wide computer"].column,
+ .ui.grid > .column.row > [class*="ten wide computer"].column,
+ .ui.grid > [class*="ten wide computer"].column,
+ .ui.column.grid > [class*="ten wide computer"].column {
+ width: @tenWide !important;
+ }
+ .ui.grid > .row > [class*="eleven wide computer"].column,
+ .ui.grid > .column.row > [class*="eleven wide computer"].column,
+ .ui.grid > [class*="eleven wide computer"].column,
+ .ui.column.grid > [class*="eleven wide computer"].column {
+ width: @elevenWide !important;
+ }
+ .ui.grid > .row > [class*="twelve wide computer"].column,
+ .ui.grid > .column.row > [class*="twelve wide computer"].column,
+ .ui.grid > [class*="twelve wide computer"].column,
+ .ui.column.grid > [class*="twelve wide computer"].column {
+ width: @twelveWide !important;
+ }
+ .ui.grid > .row > [class*="thirteen wide computer"].column,
+ .ui.grid > .column.row > [class*="thirteen wide computer"].column,
+ .ui.grid > [class*="thirteen wide computer"].column,
+ .ui.column.grid > [class*="thirteen wide computer"].column {
+ width: @thirteenWide !important;
+ }
+ .ui.grid > .row > [class*="fourteen wide computer"].column,
+ .ui.grid > .column.row > [class*="fourteen wide computer"].column,
+ .ui.grid > [class*="fourteen wide computer"].column,
+ .ui.column.grid > [class*="fourteen wide computer"].column {
+ width: @fourteenWide !important;
+ }
+ .ui.grid > .row > [class*="fifteen wide computer"].column,
+ .ui.grid > .column.row > [class*="fifteen wide computer"].column,
+ .ui.grid > [class*="fifteen wide computer"].column,
+ .ui.column.grid > [class*="fifteen wide computer"].column {
+ width: @fifteenWide !important;
+ }
+ .ui.grid > .row > [class*="sixteen wide computer"].column,
+ .ui.grid > .column.row > [class*="sixteen wide computer"].column,
+ .ui.grid > [class*="sixteen wide computer"].column,
+ .ui.column.grid > [class*="sixteen wide computer"].column {
+ width: @sixteenWide !important;
+ }
+ }
+
+ /* Large Monitor Sizing Combinations */
+ @media only screen and (min-width: @largeMonitorBreakpoint) and (max-width: @largestLargeMonitor) {
+ .ui.grid > .row > [class*="one wide large screen"].column,
+ .ui.grid > .column.row > [class*="one wide large screen"].column,
+ .ui.grid > [class*="one wide large screen"].column,
+ .ui.column.grid > [class*="one wide large screen"].column {
+ width: @oneWide !important;
+ }
+ .ui.grid > .row > [class*="two wide large screen"].column,
+ .ui.grid > .column.row > [class*="two wide large screen"].column,
+ .ui.grid > [class*="two wide large screen"].column,
+ .ui.column.grid > [class*="two wide large screen"].column {
+ width: @twoWide !important;
+ }
+ .ui.grid > .row > [class*="three wide large screen"].column,
+ .ui.grid > .column.row > [class*="three wide large screen"].column,
+ .ui.grid > [class*="three wide large screen"].column,
+ .ui.column.grid > [class*="three wide large screen"].column {
+ width: @threeWide !important;
+ }
+ .ui.grid > .row > [class*="four wide large screen"].column,
+ .ui.grid > .column.row > [class*="four wide large screen"].column,
+ .ui.grid > [class*="four wide large screen"].column,
+ .ui.column.grid > [class*="four wide large screen"].column {
+ width: @fourWide !important;
+ }
+ .ui.grid > .row > [class*="five wide large screen"].column,
+ .ui.grid > .column.row > [class*="five wide large screen"].column,
+ .ui.grid > [class*="five wide large screen"].column,
+ .ui.column.grid > [class*="five wide large screen"].column {
+ width: @fiveWide !important;
+ }
+ .ui.grid > .row > [class*="six wide large screen"].column,
+ .ui.grid > .column.row > [class*="six wide large screen"].column,
+ .ui.grid > [class*="six wide large screen"].column,
+ .ui.column.grid > [class*="six wide large screen"].column {
+ width: @sixWide !important;
+ }
+ .ui.grid > .row > [class*="seven wide large screen"].column,
+ .ui.grid > .column.row > [class*="seven wide large screen"].column,
+ .ui.grid > [class*="seven wide large screen"].column,
+ .ui.column.grid > [class*="seven wide large screen"].column {
+ width: @sevenWide !important;
+ }
+ .ui.grid > .row > [class*="eight wide large screen"].column,
+ .ui.grid > .column.row > [class*="eight wide large screen"].column,
+ .ui.grid > [class*="eight wide large screen"].column,
+ .ui.column.grid > [class*="eight wide large screen"].column {
+ width: @eightWide !important;
+ }
+ .ui.grid > .row > [class*="nine wide large screen"].column,
+ .ui.grid > .column.row > [class*="nine wide large screen"].column,
+ .ui.grid > [class*="nine wide large screen"].column,
+ .ui.column.grid > [class*="nine wide large screen"].column {
+ width: @nineWide !important;
+ }
+ .ui.grid > .row > [class*="ten wide large screen"].column,
+ .ui.grid > .column.row > [class*="ten wide large screen"].column,
+ .ui.grid > [class*="ten wide large screen"].column,
+ .ui.column.grid > [class*="ten wide large screen"].column {
+ width: @tenWide !important;
+ }
+ .ui.grid > .row > [class*="eleven wide large screen"].column,
+ .ui.grid > .column.row > [class*="eleven wide large screen"].column,
+ .ui.grid > [class*="eleven wide large screen"].column,
+ .ui.column.grid > [class*="eleven wide large screen"].column {
+ width: @elevenWide !important;
+ }
+ .ui.grid > .row > [class*="twelve wide large screen"].column,
+ .ui.grid > .column.row > [class*="twelve wide large screen"].column,
+ .ui.grid > [class*="twelve wide large screen"].column,
+ .ui.column.grid > [class*="twelve wide large screen"].column {
+ width: @twelveWide !important;
+ }
+ .ui.grid > .row > [class*="thirteen wide large screen"].column,
+ .ui.grid > .column.row > [class*="thirteen wide large screen"].column,
+ .ui.grid > [class*="thirteen wide large screen"].column,
+ .ui.column.grid > [class*="thirteen wide large screen"].column {
+ width: @thirteenWide !important;
+ }
+ .ui.grid > .row > [class*="fourteen wide large screen"].column,
+ .ui.grid > .column.row > [class*="fourteen wide large screen"].column,
+ .ui.grid > [class*="fourteen wide large screen"].column,
+ .ui.column.grid > [class*="fourteen wide large screen"].column {
+ width: @fourteenWide !important;
+ }
+ .ui.grid > .row > [class*="fifteen wide large screen"].column,
+ .ui.grid > .column.row > [class*="fifteen wide large screen"].column,
+ .ui.grid > [class*="fifteen wide large screen"].column,
+ .ui.column.grid > [class*="fifteen wide large screen"].column {
+ width: @fifteenWide !important;
+ }
+ .ui.grid > .row > [class*="sixteen wide large screen"].column,
+ .ui.grid > .column.row > [class*="sixteen wide large screen"].column,
+ .ui.grid > [class*="sixteen wide large screen"].column,
+ .ui.column.grid > [class*="sixteen wide large screen"].column {
+ width: @sixteenWide !important;
+ }
+ }
+
+ /* Widescreen Sizing Combinations */
+ @media only screen and (min-width: @widescreenMonitorBreakpoint) {
+ .ui.grid > .row > [class*="one wide widescreen"].column,
+ .ui.grid > .column.row > [class*="one wide widescreen"].column,
+ .ui.grid > [class*="one wide widescreen"].column,
+ .ui.column.grid > [class*="one wide widescreen"].column {
+ width: @oneWide !important;
+ }
+ .ui.grid > .row > [class*="two wide widescreen"].column,
+ .ui.grid > .column.row > [class*="two wide widescreen"].column,
+ .ui.grid > [class*="two wide widescreen"].column,
+ .ui.column.grid > [class*="two wide widescreen"].column {
+ width: @twoWide !important;
+ }
+ .ui.grid > .row > [class*="three wide widescreen"].column,
+ .ui.grid > .column.row > [class*="three wide widescreen"].column,
+ .ui.grid > [class*="three wide widescreen"].column,
+ .ui.column.grid > [class*="three wide widescreen"].column {
+ width: @threeWide !important;
+ }
+ .ui.grid > .row > [class*="four wide widescreen"].column,
+ .ui.grid > .column.row > [class*="four wide widescreen"].column,
+ .ui.grid > [class*="four wide widescreen"].column,
+ .ui.column.grid > [class*="four wide widescreen"].column {
+ width: @fourWide !important;
+ }
+ .ui.grid > .row > [class*="five wide widescreen"].column,
+ .ui.grid > .column.row > [class*="five wide widescreen"].column,
+ .ui.grid > [class*="five wide widescreen"].column,
+ .ui.column.grid > [class*="five wide widescreen"].column {
+ width: @fiveWide !important;
+ }
+ .ui.grid > .row > [class*="six wide widescreen"].column,
+ .ui.grid > .column.row > [class*="six wide widescreen"].column,
+ .ui.grid > [class*="six wide widescreen"].column,
+ .ui.column.grid > [class*="six wide widescreen"].column {
+ width: @sixWide !important;
+ }
+ .ui.grid > .row > [class*="seven wide widescreen"].column,
+ .ui.grid > .column.row > [class*="seven wide widescreen"].column,
+ .ui.grid > [class*="seven wide widescreen"].column,
+ .ui.column.grid > [class*="seven wide widescreen"].column {
+ width: @sevenWide !important;
+ }
+ .ui.grid > .row > [class*="eight wide widescreen"].column,
+ .ui.grid > .column.row > [class*="eight wide widescreen"].column,
+ .ui.grid > [class*="eight wide widescreen"].column,
+ .ui.column.grid > [class*="eight wide widescreen"].column {
+ width: @eightWide !important;
+ }
+ .ui.grid > .row > [class*="nine wide widescreen"].column,
+ .ui.grid > .column.row > [class*="nine wide widescreen"].column,
+ .ui.grid > [class*="nine wide widescreen"].column,
+ .ui.column.grid > [class*="nine wide widescreen"].column {
+ width: @nineWide !important;
+ }
+ .ui.grid > .row > [class*="ten wide widescreen"].column,
+ .ui.grid > .column.row > [class*="ten wide widescreen"].column,
+ .ui.grid > [class*="ten wide widescreen"].column,
+ .ui.column.grid > [class*="ten wide widescreen"].column {
+ width: @tenWide !important;
+ }
+ .ui.grid > .row > [class*="eleven wide widescreen"].column,
+ .ui.grid > .column.row > [class*="eleven wide widescreen"].column,
+ .ui.grid > [class*="eleven wide widescreen"].column,
+ .ui.column.grid > [class*="eleven wide widescreen"].column {
+ width: @elevenWide !important;
+ }
+ .ui.grid > .row > [class*="twelve wide widescreen"].column,
+ .ui.grid > .column.row > [class*="twelve wide widescreen"].column,
+ .ui.grid > [class*="twelve wide widescreen"].column,
+ .ui.column.grid > [class*="twelve wide widescreen"].column {
+ width: @twelveWide !important;
+ }
+ .ui.grid > .row > [class*="thirteen wide widescreen"].column,
+ .ui.grid > .column.row > [class*="thirteen wide widescreen"].column,
+ .ui.grid > [class*="thirteen wide widescreen"].column,
+ .ui.column.grid > [class*="thirteen wide widescreen"].column {
+ width: @thirteenWide !important;
+ }
+ .ui.grid > .row > [class*="fourteen wide widescreen"].column,
+ .ui.grid > .column.row > [class*="fourteen wide widescreen"].column,
+ .ui.grid > [class*="fourteen wide widescreen"].column,
+ .ui.column.grid > [class*="fourteen wide widescreen"].column {
+ width: @fourteenWide !important;
+ }
+ .ui.grid > .row > [class*="fifteen wide widescreen"].column,
+ .ui.grid > .column.row > [class*="fifteen wide widescreen"].column,
+ .ui.grid > [class*="fifteen wide widescreen"].column,
+ .ui.column.grid > [class*="fifteen wide widescreen"].column {
+ width: @fifteenWide !important;
+ }
+ .ui.grid > .row > [class*="sixteen wide widescreen"].column,
+ .ui.grid > .column.row > [class*="sixteen wide widescreen"].column,
+ .ui.grid > [class*="sixteen wide widescreen"].column,
+ .ui.column.grid > [class*="sixteen wide widescreen"].column {
+ width: @sixteenWide !important;
+ }
+ }
}
& when (@variationGridCentered) {
- /*----------------------
- Centered
- -----------------------*/
-
- .ui.centered.grid,
- .ui.centered.grid > .row,
- .ui.grid > .centered.row {
- text-align: center;
- justify-content: center;
- }
- .ui.centered.grid > .column:not(.aligned):not(.justified):not(.row),
- .ui.centered.grid > .row > .column:not(.aligned):not(.justified),
- .ui.grid .centered.row > .column:not(.aligned):not(.justified) {
- text-align: left;
- }
-
- .ui.grid > .centered.column,
- .ui.grid > .row > .centered.column {
- display: block;
- margin-left: auto;
- margin-right: auto;
- }
+ /* ----------------------
+ Centered
+ ----------------------- */
+
+ .ui.centered.grid,
+ .ui.centered.grid > .row,
+ .ui.grid > .centered.row {
+ text-align: center;
+ justify-content: center;
+ }
+ .ui.centered.grid > .column:not(.aligned):not(.justified):not(.row),
+ .ui.centered.grid > .row > .column:not(.aligned):not(.justified),
+ .ui.grid .centered.row > .column:not(.aligned):not(.justified) {
+ text-align: left;
+ }
+
+ .ui.grid > .centered.column,
+ .ui.grid > .row > .centered.column {
+ display: block;
+ margin-left: auto;
+ margin-right: auto;
+ }
}
& when (@variationGridRelaxed) {
- /*----------------------
- Relaxed
- -----------------------*/
-
- .ui.relaxed.grid > .column:not(.row),
- .ui.relaxed.grid > .row > .column,
- .ui.grid > .relaxed.row > .column {
- padding-left: (@relaxedGutterWidth / 2);
- padding-right: (@relaxedGutterWidth / 2);
- }
-
- & when (@variationGridVeryRelaxed) {
- .ui[class*="very relaxed"].grid > .column:not(.row),
- .ui[class*="very relaxed"].grid > .row > .column,
- .ui.grid > [class*="very relaxed"].row > .column {
- padding-left: (@veryRelaxedGutterWidth / 2);
- padding-right: (@veryRelaxedGutterWidth / 2);
- }
- }
-
- /* Coupling with UI Divider */
- .ui.relaxed.grid .row + .ui.divider,
- .ui.grid .relaxed.row + .ui.divider {
- margin-left: (@relaxedGutterWidth / 2);
- margin-right: (@relaxedGutterWidth / 2);
- }
- & when (@variationGridVeryRelaxed) {
- .ui[class*="very relaxed"].grid .row + .ui.divider,
- .ui.grid [class*="very relaxed"].row + .ui.divider {
- margin-left: (@veryRelaxedGutterWidth / 2);
- margin-right: (@veryRelaxedGutterWidth / 2);
- }
- }
+ /* ----------------------
+ Relaxed
+ ----------------------- */
+
+ .ui.relaxed.grid > .column:not(.row),
+ .ui.relaxed.grid > .row > .column,
+ .ui.grid > .relaxed.row > .column {
+ padding-left: (@relaxedGutterWidth / 2);
+ padding-right: (@relaxedGutterWidth / 2);
+ }
+
+ & when (@variationGridVeryRelaxed) {
+ .ui[class*="very relaxed"].grid > .column:not(.row),
+ .ui[class*="very relaxed"].grid > .row > .column,
+ .ui.grid > [class*="very relaxed"].row > .column {
+ padding-left: (@veryRelaxedGutterWidth / 2);
+ padding-right: (@veryRelaxedGutterWidth / 2);
+ }
+ }
+
+ /* Coupling with UI Divider */
+ .ui.relaxed.grid .row + .ui.divider,
+ .ui.grid .relaxed.row + .ui.divider {
+ margin-left: (@relaxedGutterWidth / 2);
+ margin-right: (@relaxedGutterWidth / 2);
+ }
+ & when (@variationGridVeryRelaxed) {
+ .ui[class*="very relaxed"].grid .row + .ui.divider,
+ .ui.grid [class*="very relaxed"].row + .ui.divider {
+ margin-left: (@veryRelaxedGutterWidth / 2);
+ margin-right: (@veryRelaxedGutterWidth / 2);
+ }
+ }
}
& when (@variationGridPadded) {
- /*----------------------
- Padded
- -----------------------*/
-
- .ui.padded.grid:not(.vertically):not(.horizontally) {
- margin: 0 !important;
- }
- [class*="horizontally padded"].ui.grid {
- margin-left: 0 !important;
- margin-right: 0 !important;
- }
- [class*="vertically padded"].ui.grid {
- margin-top: 0 !important;
- margin-bottom: 0 !important;
- }
+ /* ----------------------
+ Padded
+ ----------------------- */
+
+ .ui.padded.grid:not(.vertically):not(.horizontally) {
+ margin: 0;
+ }
+ [class*="horizontally padded"].ui.grid {
+ margin-left: 0;
+ margin-right: 0;
+ }
+ [class*="vertically padded"].ui.grid {
+ margin-top: 0;
+ margin-bottom: 0;
+ }
}
& when (@variationGridFloated) {
- /*----------------------
- "Floated"
- -----------------------*/
+ /* ----------------------
+ "Floated"
+ ----------------------- */
- .ui.grid [class*="left floated"].column {
- margin-right: auto;
- }
- .ui.grid [class*="right floated"].column {
- margin-left: auto;
- }
+ .ui.grid [class*="left floated"].column {
+ margin-right: auto;
+ }
+ .ui.grid [class*="right floated"].column {
+ margin-left: auto;
+ }
}
& when (@variationGridDivided) {
- /*----------------------
- Divided
- -----------------------*/
-
- .ui.divided.grid:not([class*="vertically divided"]) > .column:not(.row),
- .ui.divided.grid:not([class*="vertically divided"]) > .row > .column {
- box-shadow: @dividedBorder;
- }
+ /* ----------------------
+ Divided
+ ----------------------- */
- & when (@variationGridVertical) {
- /* Swap from padding to margin on columns to have dividers align */
- .ui[class*="vertically divided"].grid > .column:not(.row),
- .ui[class*="vertically divided"].grid > .row > .column {
- margin-top: (@rowSpacing / 2);
- margin-bottom: (@rowSpacing / 2);
- padding-top: 0;
- padding-bottom: 0;
- }
- .ui[class*="vertically divided"].grid > .row {
- margin-top: 0;
- margin-bottom: 0;
+ .ui.divided.grid:not([class*="vertically divided"]) > .column:not(.row),
+ .ui.divided.grid:not([class*="vertically divided"]) > .row > .column {
+ box-shadow: @dividedBorder;
}
- }
+ & when (@variationGridVertical) {
+ /* Swap from padding to margin on columns to have dividers align */
+ .ui[class*="vertically divided"].grid > .column:not(.row),
+ .ui[class*="vertically divided"].grid > .row > .column {
+ margin-top: (@rowSpacing / 2);
+ margin-bottom: (@rowSpacing / 2);
+ padding-top: 0;
+ padding-bottom: 0;
+ }
+ .ui[class*="vertically divided"].grid > .row {
+ margin-top: 0;
+ margin-bottom: 0;
+ }
+ }
+ /* No divider on first column on row */
+ .ui.divided.grid:not([class*="vertically divided"]) > .column:first-child,
+ .ui.divided.grid:not([class*="vertically divided"]) > .row > .column:first-child {
+ box-shadow: none;
+ }
- /* No divider on first column on row */
- .ui.divided.grid:not([class*="vertically divided"]) > .column:first-child,
- .ui.divided.grid:not([class*="vertically divided"]) > .row > .column:first-child {
- box-shadow: none;
- }
+ & when (@variationGridVertical) {
+ /* No space on top of first row */
+ .ui[class*="vertically divided"].grid > .row:first-child > .column {
+ margin-top: 0;
+ }
+ }
- & when (@variationGridVertical) {
- /* No space on top of first row */
- .ui[class*="vertically divided"].grid > .row:first-child > .column {
- margin-top: 0;
+ /* Divided Row */
+ .ui.grid > .divided.row > .column {
+ box-shadow: @dividedBorder;
+ }
+ .ui.grid > .divided.row > .column:first-child {
+ box-shadow: none;
}
- }
+ & when (@variationGridVertical) {
+ /* Vertically Divided */
+ .ui[class*="vertically divided"].grid > .row {
+ position: relative;
+ }
+ .ui[class*="vertically divided"].grid > .row::before {
+ position: absolute;
+ content: "";
+ top: 0;
+ left: 0;
+ width: e(%("calc(100%% - %d)", @gutterWidth));
+ height: 1px;
+ margin: 0 (@gutterWidth / 2);
+ box-shadow: @verticallyDividedBorder;
+ }
+ }
- /* Divided Row */
- .ui.grid > .divided.row > .column {
- box-shadow: @dividedBorder;
- }
- .ui.grid > .divided.row > .column:first-child {
- box-shadow: none;
- }
-
- & when (@variationGridVertical) {
- /* Vertically Divided */
- .ui[class*="vertically divided"].grid > .row {
- position: relative;
- }
- .ui[class*="vertically divided"].grid > .row::before {
- position: absolute;
- content: "";
- top: 0;
- left: 0;
-
- width: e(%("calc(100%% - %d)", @gutterWidth));
- height: 1px;
-
- margin: 0 (@gutterWidth / 2);
- box-shadow: @verticallyDividedBorder;
- }
- }
-
- & when (@variationGridPadded) {
- /* Padded Horizontally Divided */
- [class*="horizontally padded"].ui.divided.grid,
- .ui.padded.divided.grid:not(.vertically):not(.horizontally) {
- width: 100%;
- }
- }
- & when (@variationGridVertical) {
- /* First Row Vertically Divided */
- .ui[class*="vertically divided"].grid > .row:first-child::before {
- box-shadow: none;
- }
- }
- & when (@variationGridInverted) {
- /* Inverted Divided */
- .ui.inverted.divided.grid:not([class*="vertically divided"]) > .column:not(.row),
- .ui.inverted.divided.grid:not([class*="vertically divided"]) > .row > .column {
- box-shadow: @dividedInvertedBorder;
- }
- .ui.inverted.divided.grid:not([class*="vertically divided"]) > .column:not(.row):first-child,
- .ui.inverted.divided.grid:not([class*="vertically divided"]) > .row > .column:first-child {
- box-shadow: none;
+ & when (@variationGridPadded) {
+ /* Padded Horizontally Divided */
+ [class*="horizontally padded"].ui.divided.grid,
+ .ui.padded.divided.grid:not(.vertically):not(.horizontally) {
+ width: 100%;
+ }
}
& when (@variationGridVertical) {
- .ui.inverted[class*="vertically divided"].grid > .row::before {
- box-shadow: @verticallyDividedInvertedBorder;
- }
- }
- }
- & when (@variationGridRelaxed) and (@variationGridVertical) {
- /* Relaxed */
- .ui.relaxed[class*="vertically divided"].grid > .row::before {
- margin-left: (@relaxedGutterWidth / 2);
- margin-right: (@relaxedGutterWidth / 2);
- width: e(%("calc(100%% - %d)", @relaxedGutterWidth));
+ /* First Row Vertically Divided */
+ .ui[class*="vertically divided"].grid > .row:first-child::before {
+ box-shadow: none;
+ }
}
- & when (@variationGridVeryRelaxed) {
- .ui[class*="very relaxed"][class*="vertically divided"].grid > .row::before {
- margin-left: (@veryRelaxedGutterWidth / 2);
- margin-right: (@veryRelaxedGutterWidth / 2);
- width: e(%("calc(100%% - %d)", @veryRelaxedGutterWidth));
- }
+ & when (@variationGridInverted) {
+ /* Inverted Divided */
+ .ui.inverted.divided.grid:not([class*="vertically divided"]) > .column:not(.row),
+ .ui.inverted.divided.grid:not([class*="vertically divided"]) > .row > .column {
+ box-shadow: @dividedInvertedBorder;
+ }
+ .ui.inverted.divided.grid:not([class*="vertically divided"]) > .column:not(.row):first-child,
+ .ui.inverted.divided.grid:not([class*="vertically divided"]) > .row > .column:first-child {
+ box-shadow: none;
+ }
+ & when (@variationGridVertical) {
+ .ui.inverted[class*="vertically divided"].grid > .row::before {
+ box-shadow: @verticallyDividedInvertedBorder;
+ }
+ }
+ }
+ & when (@variationGridRelaxed) and (@variationGridVertical) {
+ /* Relaxed */
+ .ui.relaxed[class*="vertically divided"].grid > .row::before {
+ margin-left: (@relaxedGutterWidth / 2);
+ margin-right: (@relaxedGutterWidth / 2);
+ width: e(%("calc(100%% - %d)", @relaxedGutterWidth));
+ }
+ & when (@variationGridVeryRelaxed) {
+ .ui[class*="very relaxed"][class*="vertically divided"].grid > .row::before {
+ margin-left: (@veryRelaxedGutterWidth / 2);
+ margin-right: (@veryRelaxedGutterWidth / 2);
+ width: e(%("calc(100%% - %d)", @veryRelaxedGutterWidth));
+ }
+ }
}
- }
}
& when (@variationGridCelled) {
- /*----------------------
- Celled
- -----------------------*/
+ /* ----------------------
+ Celled
+ ----------------------- */
- .ui.celled.grid {
- width: 100%;
- margin: @celledMargin;
- box-shadow: @celledGridDivider;
- }
+ .ui.celled.grid {
+ width: 100%;
+ margin: @celledMargin;
+ box-shadow: @celledGridDivider;
+ }
- .ui.celled.grid > .row {
- width: 100% !important;
- margin: 0;
- padding: 0;
- box-shadow: @celledRowDivider;
- }
- .ui.celled.grid > .column:not(.row),
- .ui.celled.grid > .row > .column {
- box-shadow: @celledColumnDivider;
- }
-
- .ui.celled.grid > .column:first-child,
- .ui.celled.grid > .row > .column:first-child {
- box-shadow: none;
- }
-
- .ui.celled.grid > .column:not(.row),
- .ui.celled.grid > .row > .column {
- padding: @celledPadding;
- }
- & when (@variationGridRelaxed) {
- .ui.relaxed.celled.grid > .column:not(.row),
- .ui.relaxed.celled.grid > .row > .column {
- padding: @celledRelaxedPadding;
- }
- }
- & when (@variationGridVeryRelaxed) {
- .ui[class*="very relaxed"].celled.grid > .column:not(.row),
- .ui[class*="very relaxed"].celled.grid > .row > .column {
- padding: @celledVeryRelaxedPadding;
- }
- }
- /* Internally Celled */
- .ui[class*="internally celled"].grid {
- box-shadow: none;
- margin: 0;
- }
- .ui[class*="internally celled"].grid > .row:first-child {
- box-shadow: none;
- }
- .ui[class*="internally celled"].grid > .row > .column:first-child {
- box-shadow: none;
- }
+ .ui.celled.grid > .row {
+ width: 100% !important;
+ margin: 0;
+ padding: 0;
+ box-shadow: @celledRowDivider;
+ }
+ .ui.celled.grid > .column:not(.row),
+ .ui.celled.grid > .row > .column {
+ box-shadow: @celledColumnDivider;
+ }
+
+ .ui.celled.grid > .column:first-child,
+ .ui.celled.grid > .row > .column:first-child {
+ box-shadow: none;
+ }
+
+ .ui.celled.grid > .column:not(.row),
+ .ui.celled.grid > .row > .column {
+ padding: @celledPadding;
+ }
+ & when (@variationGridRelaxed) {
+ .ui.relaxed.celled.grid > .column:not(.row),
+ .ui.relaxed.celled.grid > .row > .column {
+ padding: @celledRelaxedPadding;
+ }
+ }
+ & when (@variationGridVeryRelaxed) {
+ .ui[class*="very relaxed"].celled.grid > .column:not(.row),
+ .ui[class*="very relaxed"].celled.grid > .row > .column {
+ padding: @celledVeryRelaxedPadding;
+ }
+ }
+
+ /* Internally Celled */
+ .ui[class*="internally celled"].grid {
+ box-shadow: none;
+ margin: 0;
+ }
+ .ui[class*="internally celled"].grid > .row:first-child {
+ box-shadow: none;
+ }
+ .ui[class*="internally celled"].grid > .row > .column:first-child {
+ box-shadow: none;
+ }
}
& when (@variationGridAligned) {
- /*----------------------
- Vertically Aligned
- -----------------------*/
-
- /* Top Aligned */
- .ui[class*="top aligned"].grid > .column:not(.row),
- .ui[class*="top aligned"].grid > .row > .column,
- .ui.grid > [class*="top aligned"].row > .column,
- .ui.grid > [class*="top aligned"].column:not(.row),
- .ui.grid > .row > [class*="top aligned"].column {
- flex-direction: column;
- vertical-align: top;
- align-self: flex-start !important;
- }
-
- /* Middle Aligned */
- .ui[class*="middle aligned"].grid > .column:not(.row),
- .ui[class*="middle aligned"].grid > .row > .column,
- .ui.grid > [class*="middle aligned"].row > .column,
- .ui.grid > [class*="middle aligned"].column:not(.row),
- .ui.grid > .row > [class*="middle aligned"].column {
- flex-direction: column;
- vertical-align: middle;
- align-self: center !important;
- }
-
- /* Bottom Aligned */
- .ui[class*="bottom aligned"].grid > .column:not(.row),
- .ui[class*="bottom aligned"].grid > .row > .column,
- .ui.grid > [class*="bottom aligned"].row > .column,
- .ui.grid > [class*="bottom aligned"].column:not(.row),
- .ui.grid > .row > [class*="bottom aligned"].column {
- flex-direction: column;
- vertical-align: bottom;
- align-self: flex-end !important;
- }
+ /* ----------------------
+ Vertically Aligned
+ ----------------------- */
+
+ /* Top Aligned */
+ .ui[class*="top aligned"].grid > .column:not(.row),
+ .ui[class*="top aligned"].grid > .row > .column,
+ .ui.grid > [class*="top aligned"].row > .column,
+ .ui.grid > [class*="top aligned"].column:not(.row),
+ .ui.grid > .row > [class*="top aligned"].column {
+ flex-direction: column;
+ vertical-align: top;
+ align-self: flex-start !important;
+ }
+
+ /* Middle Aligned */
+ .ui[class*="middle aligned"].grid > .column:not(.row),
+ .ui[class*="middle aligned"].grid > .row > .column,
+ .ui.grid > [class*="middle aligned"].row > .column,
+ .ui.grid > [class*="middle aligned"].column:not(.row),
+ .ui.grid > .row > [class*="middle aligned"].column {
+ flex-direction: column;
+ vertical-align: middle;
+ align-self: center !important;
+ }
+
+ /* Bottom Aligned */
+ .ui[class*="bottom aligned"].grid > .column:not(.row),
+ .ui[class*="bottom aligned"].grid > .row > .column,
+ .ui.grid > [class*="bottom aligned"].row > .column,
+ .ui.grid > [class*="bottom aligned"].column:not(.row),
+ .ui.grid > .row > [class*="bottom aligned"].column {
+ flex-direction: column;
+ vertical-align: bottom;
+ align-self: flex-end !important;
+ }
}
& when (@variationGridStretched) {
- /* Stretched */
- .ui.stretched.grid > .row > .column,
- .ui.stretched.grid > .column,
- .ui.grid > .stretched.row > .column,
- .ui.grid > .stretched.column:not(.row),
- .ui.grid > .row > .stretched.column {
- display: inline-flex !important;
- align-self: stretch;
- flex-direction: column;
- }
-
- .ui.stretched.grid > .row > .column > *,
- .ui.stretched.grid > .column > *,
- .ui.grid > .stretched.row > .column > *,
- .ui.grid > .stretched.column:not(.row) > *,
- .ui.grid > .row > .stretched.column > * {
- flex-grow: 1;
- }
+ /* Stretched */
+ .ui.stretched.grid > .row > .column,
+ .ui.stretched.grid > .column,
+ .ui.grid > .stretched.row > .column,
+ .ui.grid > .stretched.column:not(.row),
+ .ui.grid > .row > .stretched.column {
+ display: inline-flex !important;
+ align-self: stretch;
+ flex-direction: column;
+ }
+
+ .ui.stretched.grid > .row > .column > *,
+ .ui.stretched.grid > .column > *,
+ .ui.grid > .stretched.row > .column > *,
+ .ui.grid > .stretched.column:not(.row) > *,
+ .ui.grid > .row > .stretched.column > * {
+ flex-grow: 1;
+ }
}
& when (@variationGridAligned) {
- /*----------------------
- Horizontally Centered
- -----------------------*/
-
- /* Left Aligned */
-
- .ui[class*="left aligned"].grid > .column,
- .ui[class*="left aligned"].grid > .row > .column,
- .ui.grid > [class*="left aligned"].row > .column,
- .ui.grid > [class*="left aligned"].column.column,
- .ui.grid > .row > [class*="left aligned"].column.column {
- text-align: left;
- align-self: inherit;
- }
-
- /* Center Aligned */
-
- .ui[class*="center aligned"].grid > .column,
- .ui[class*="center aligned"].grid > .row > .column,
- .ui.grid > [class*="center aligned"].row > .column,
- .ui.grid > [class*="center aligned"].column.column,
- .ui.grid > .row > [class*="center aligned"].column.column {
- text-align: center;
- align-self: inherit;
- }
-
- .ui[class*="center aligned"].grid {
- justify-content: center;
- }
-
- /* Right Aligned */
-
- .ui[class*="right aligned"].grid > .column,
- .ui[class*="right aligned"].grid > .row > .column,
- .ui.grid > [class*="right aligned"].row > .column,
- .ui.grid > [class*="right aligned"].column.column,
- .ui.grid > .row > [class*="right aligned"].column.column {
- text-align: right;
- align-self: inherit;
- }
+ /* ----------------------
+ Horizontally Centered
+ ----------------------- */
+
+ /* Left Aligned */
+
+ .ui[class*="left aligned"].grid > .column,
+ .ui[class*="left aligned"].grid > .row > .column,
+ .ui.grid > [class*="left aligned"].row > .column,
+ .ui.grid > [class*="left aligned"].column.column,
+ .ui.grid > .row > [class*="left aligned"].column.column {
+ text-align: left;
+ align-self: inherit;
+ }
+
+ /* Center Aligned */
+
+ .ui[class*="center aligned"].grid > .column,
+ .ui[class*="center aligned"].grid > .row > .column,
+ .ui.grid > [class*="center aligned"].row > .column,
+ .ui.grid > [class*="center aligned"].column.column,
+ .ui.grid > .row > [class*="center aligned"].column.column {
+ text-align: center;
+ align-self: inherit;
+ }
+
+ .ui[class*="center aligned"].grid {
+ justify-content: center;
+ }
+
+ /* Right Aligned */
+
+ .ui[class*="right aligned"].grid > .column,
+ .ui[class*="right aligned"].grid > .row > .column,
+ .ui.grid > [class*="right aligned"].row > .column,
+ .ui.grid > [class*="right aligned"].column.column,
+ .ui.grid > .row > [class*="right aligned"].column.column {
+ text-align: right;
+ align-self: inherit;
+ }
}
& when (@variationGridJustified) {
- /* Justified */
- .ui.justified.grid > .column,
- .ui.justified.grid > .row > .column,
- .ui.grid > .justified.row > .column,
- .ui.grid > .justified.column.column,
- .ui.grid > .row > .justified.column.column {
- text-align: justify;
- hyphens: auto;
- }
-}
-
-/*----------------------
- Colored
------------------------*/
-& when not (@variationGridColors = false) {
- each(@variationGridColors, {
- @color: @value;
- @c: @colors[@@color][color];
-
- .ui.grid > .@{color}.row,
- .ui.grid > .@{color}.column,
- .ui.grid > .row > .@{color}.column {
- background-color: @c;
- color: @white;
+ /* Justified */
+ .ui.justified.grid > .column,
+ .ui.justified.grid > .row > .column,
+ .ui.grid > .justified.row > .column,
+ .ui.grid > .justified.column.column,
+ .ui.grid > .row > .justified.column.column {
+ text-align: justify;
+ hyphens: auto;
}
- })
}
+/* ----------------------
+ Colored
+----------------------- */
+& when not (@variationGridColors = false) {
+ each(@variationGridColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+
+ .ui.grid > .@{color}.row,
+ .ui.grid > .@{color}.column,
+ .ui.grid > .row > .@{color}.column {
+ background-color: @c;
+ color: @white;
+ }
+ });
+}
& when (@variationGridEqualWidth) {
- /*----------------------
- Equal Width
- -----------------------*/
+ /* ----------------------
+ Equal Width
+ ----------------------- */
- .ui[class*="equal width"].grid > .column:not(.row),
- .ui[class*="equal width"].grid > .row > .column,
- .ui.grid > [class*="equal width"].row > .column {
- display: inline-block;
- flex-grow: 1;
- }
- .ui[class*="equal width"].grid > .wide.column,
- .ui[class*="equal width"].grid > .row > .wide.column,
- .ui.grid > [class*="equal width"].row > .wide.column {
- flex-grow: 0;
- }
+ .ui[class*="equal width"].grid > .column:not(.row),
+ .ui[class*="equal width"].grid > .row > .column,
+ .ui.grid > [class*="equal width"].row > .column {
+ display: inline-block;
+ flex-grow: 1;
+ }
+ .ui[class*="equal width"].grid > .wide.column,
+ .ui[class*="equal width"].grid > .row > .wide.column,
+ .ui.grid > [class*="equal width"].row > .wide.column {
+ flex-grow: 0;
+ }
}
& when (@variationGridReversed) {
- /*----------------------
- Reverse
- -----------------------*/
-
-
- /* Mobile */
- @media only screen and (max-width: @largestMobileScreen) {
- .ui[class*="mobile reversed"].grid,
- .ui[class*="mobile reversed"].grid > .row,
- .ui.grid > [class*="mobile reversed"].row {
- flex-direction: row-reverse;
- }
- .ui[class*="mobile vertically reversed"].grid,
- .ui.stackable[class*="mobile reversed"] {
- flex-direction: column-reverse;
- }
- & when (@variationGridDivided) {
- /* Divided Reversed */
- .ui[class*="mobile reversed"].divided.grid:not([class*="vertically divided"]) > .column:first-child,
- .ui[class*="mobile reversed"].divided.grid:not([class*="vertically divided"]) > .row > .column:first-child {
- box-shadow: @dividedBorder;
- }
- .ui[class*="mobile reversed"].divided.grid:not([class*="vertically divided"]) > .column:last-child,
- .ui[class*="mobile reversed"].divided.grid:not([class*="vertically divided"]) > .row > .column:last-child {
- box-shadow: none;
- }
- /* Vertically Divided Reversed */
- .ui.grid[class*="vertically divided"][class*="mobile vertically reversed"] > .row:first-child::before {
- box-shadow: @verticallyDividedBorder;
- }
- .ui.grid[class*="vertically divided"][class*="mobile vertically reversed"] > .row:last-child::before {
- box-shadow: none;
- }
- }
- & when (@variationGridCelled) {
- /* Celled Reversed */
- .ui[class*="mobile reversed"].celled.grid > .row > .column:first-child {
- box-shadow: @celledColumnDivider;
- }
- .ui[class*="mobile reversed"].celled.grid > .row > .column:last-child {
- box-shadow: none;
- }
+ /* ----------------------
+ Reverse
+ ----------------------- */
+
+ /* Mobile */
+ @media only screen and (max-width: @largestMobileScreen) {
+ .ui[class*="mobile reversed"].grid,
+ .ui[class*="mobile reversed"].grid > .row,
+ .ui.grid > [class*="mobile reversed"].row {
+ flex-direction: row-reverse;
+ }
+ .ui[class*="mobile vertically reversed"].grid,
+ .ui.stackable[class*="mobile reversed"] {
+ flex-direction: column-reverse;
+ }
+ & when (@variationGridDivided) {
+ /* Divided Reversed */
+ .ui[class*="mobile reversed"].divided.grid:not([class*="vertically divided"]) > .column:first-child,
+ .ui[class*="mobile reversed"].divided.grid:not([class*="vertically divided"]) > .row > .column:first-child {
+ box-shadow: @dividedBorder;
+ }
+ .ui[class*="mobile reversed"].divided.grid:not([class*="vertically divided"]) > .column:last-child,
+ .ui[class*="mobile reversed"].divided.grid:not([class*="vertically divided"]) > .row > .column:last-child {
+ box-shadow: none;
+ }
+
+ /* Vertically Divided Reversed */
+ .ui.grid[class*="vertically divided"][class*="mobile vertically reversed"] > .row:first-child::before {
+ box-shadow: @verticallyDividedBorder;
+ }
+ .ui.grid[class*="vertically divided"][class*="mobile vertically reversed"] > .row:last-child::before {
+ box-shadow: none;
+ }
+ }
+ & when (@variationGridCelled) {
+ /* Celled Reversed */
+ .ui[class*="mobile reversed"].celled.grid > .row > .column:first-child {
+ box-shadow: @celledColumnDivider;
+ }
+ .ui[class*="mobile reversed"].celled.grid > .row > .column:last-child {
+ box-shadow: none;
+ }
+ }
}
- }
- /* Tablet */
- @media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) {
- .ui[class*="tablet reversed"].grid,
- .ui[class*="tablet reversed"].grid > .row,
- .ui.grid > [class*="tablet reversed"].row {
- flex-direction: row-reverse;
- }
- .ui[class*="tablet vertically reversed"].grid {
- flex-direction: column-reverse;
- }
- & when (@variationGridDivided) {
- /* Divided Reversed */
- .ui[class*="tablet reversed"].divided.grid:not([class*="vertically divided"]) > .column:first-child,
- .ui[class*="tablet reversed"].divided.grid:not([class*="vertically divided"]) > .row > .column:first-child {
- box-shadow: @dividedBorder;
- }
- .ui[class*="tablet reversed"].divided.grid:not([class*="vertically divided"]) > .column:last-child,
- .ui[class*="tablet reversed"].divided.grid:not([class*="vertically divided"]) > .row > .column:last-child {
- box-shadow: none;
- }
- /* Vertically Divided Reversed */
- .ui.grid[class*="vertically divided"][class*="tablet vertically reversed"] > .row:first-child::before {
- box-shadow: @verticallyDividedBorder;
- }
- .ui.grid[class*="vertically divided"][class*="tablet vertically reversed"] > .row:last-child::before {
- box-shadow: none;
- }
- }
- & when (@variationGridCelled) {
- /* Celled Reversed */
- .ui[class*="tablet reversed"].celled.grid > .row > .column:first-child {
- box-shadow: @celledColumnDivider;
- }
- .ui[class*="tablet reversed"].celled.grid > .row > .column:last-child {
- box-shadow: none;
- }
+ /* Tablet */
+ @media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) {
+ .ui[class*="tablet reversed"].grid,
+ .ui[class*="tablet reversed"].grid > .row,
+ .ui.grid > [class*="tablet reversed"].row {
+ flex-direction: row-reverse;
+ }
+ .ui[class*="tablet vertically reversed"].grid {
+ flex-direction: column-reverse;
+ }
+ & when (@variationGridDivided) {
+ /* Divided Reversed */
+ .ui[class*="tablet reversed"].divided.grid:not([class*="vertically divided"]) > .column:first-child,
+ .ui[class*="tablet reversed"].divided.grid:not([class*="vertically divided"]) > .row > .column:first-child {
+ box-shadow: @dividedBorder;
+ }
+ .ui[class*="tablet reversed"].divided.grid:not([class*="vertically divided"]) > .column:last-child,
+ .ui[class*="tablet reversed"].divided.grid:not([class*="vertically divided"]) > .row > .column:last-child {
+ box-shadow: none;
+ }
+
+ /* Vertically Divided Reversed */
+ .ui.grid[class*="vertically divided"][class*="tablet vertically reversed"] > .row:first-child::before {
+ box-shadow: @verticallyDividedBorder;
+ }
+ .ui.grid[class*="vertically divided"][class*="tablet vertically reversed"] > .row:last-child::before {
+ box-shadow: none;
+ }
+ }
+ & when (@variationGridCelled) {
+ /* Celled Reversed */
+ .ui[class*="tablet reversed"].celled.grid > .row > .column:first-child {
+ box-shadow: @celledColumnDivider;
+ }
+ .ui[class*="tablet reversed"].celled.grid > .row > .column:last-child {
+ box-shadow: none;
+ }
+ }
}
- }
- /* Computer */
- @media only screen and (min-width: @computerBreakpoint) {
- .ui[class*="computer reversed"].grid,
- .ui[class*="computer reversed"].grid > .row,
- .ui.grid > [class*="computer reversed"].row {
- flex-direction: row-reverse;
- }
- .ui[class*="computer vertically reversed"].grid {
- flex-direction: column-reverse;
- }
- & when (@variationGridDivided) {
- /* Divided Reversed */
- .ui[class*="computer reversed"].divided.grid:not([class*="vertically divided"]) > .column:first-child,
- .ui[class*="computer reversed"].divided.grid:not([class*="vertically divided"]) > .row > .column:first-child {
- box-shadow: @dividedBorder;
- }
- .ui[class*="computer reversed"].divided.grid:not([class*="vertically divided"]) > .column:last-child,
- .ui[class*="computer reversed"].divided.grid:not([class*="vertically divided"]) > .row > .column:last-child {
- box-shadow: none;
- }
- /* Vertically Divided Reversed */
- .ui.grid[class*="vertically divided"][class*="computer vertically reversed"] > .row:first-child::before {
- box-shadow: @verticallyDividedBorder;
- }
- .ui.grid[class*="vertically divided"][class*="computer vertically reversed"] > .row:last-child::before {
- box-shadow: none;
- }
- }
- & when (@variationGridCelled) {
- /* Celled Reversed */
- .ui[class*="computer reversed"].celled.grid > .row > .column:first-child {
- box-shadow: @celledColumnDivider;
- }
- .ui[class*="computer reversed"].celled.grid > .row > .column:last-child {
- box-shadow: none;
- }
+ /* Computer */
+ @media only screen and (min-width: @computerBreakpoint) {
+ .ui[class*="computer reversed"].grid,
+ .ui[class*="computer reversed"].grid > .row,
+ .ui.grid > [class*="computer reversed"].row {
+ flex-direction: row-reverse;
+ }
+ .ui[class*="computer vertically reversed"].grid {
+ flex-direction: column-reverse;
+ }
+ & when (@variationGridDivided) {
+ /* Divided Reversed */
+ .ui[class*="computer reversed"].divided.grid:not([class*="vertically divided"]) > .column:first-child,
+ .ui[class*="computer reversed"].divided.grid:not([class*="vertically divided"]) > .row > .column:first-child {
+ box-shadow: @dividedBorder;
+ }
+ .ui[class*="computer reversed"].divided.grid:not([class*="vertically divided"]) > .column:last-child,
+ .ui[class*="computer reversed"].divided.grid:not([class*="vertically divided"]) > .row > .column:last-child {
+ box-shadow: none;
+ }
+
+ /* Vertically Divided Reversed */
+ .ui.grid[class*="vertically divided"][class*="computer vertically reversed"] > .row:first-child::before {
+ box-shadow: @verticallyDividedBorder;
+ }
+ .ui.grid[class*="vertically divided"][class*="computer vertically reversed"] > .row:last-child::before {
+ box-shadow: none;
+ }
+ }
+ & when (@variationGridCelled) {
+ /* Celled Reversed */
+ .ui[class*="computer reversed"].celled.grid > .row > .column:first-child {
+ box-shadow: @celledColumnDivider;
+ }
+ .ui[class*="computer reversed"].celled.grid > .row > .column:last-child {
+ box-shadow: none;
+ }
+ }
}
- }
}
& when (@variationGridDoubling) {
- /*-------------------
- Doubling
- --------------------*/
-
- /* Tablet Only */
- @media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) {
- .ui.doubling.grid {
- width: auto;
- }
- .ui.grid > .doubling.row,
- .ui.doubling.grid > .row {
- margin: 0 !important;
- padding: 0 !important;
- }
- .ui.grid > .doubling.row > .column,
- .ui.doubling.grid > .row > .column {
- padding-top: (@rowSpacing / 2) !important;
- padding-bottom: (@rowSpacing / 2) !important;
- box-shadow: none !important;
- margin: 0;
- }
- .ui.grid:not(.stretched) > .doubling.row:not(.stretched) > .column:not(.stretched),
- .ui.doubling.grid:not(.stretched) > .row:not(.stretched) > .column:not(.stretched) {
- display: inline-block !important;
- }
- .ui[class*="two column"].doubling.grid > .row > .column,
- .ui[class*="two column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="two column"].doubling.row.row > .column {
- width: @oneColumn !important;
- }
- .ui[class*="three column"].doubling.grid > .row > .column,
- .ui[class*="three column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="three column"].doubling.row.row > .column {
- width: @twoColumn !important;
- }
- .ui[class*="four column"].doubling.grid > .row > .column,
- .ui[class*="four column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="four column"].doubling.row.row > .column {
- width: @twoColumn !important;
- }
- .ui[class*="five column"].doubling.grid > .row > .column,
- .ui[class*="five column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="five column"].doubling.row.row > .column {
- width: @threeColumn !important;
- }
- .ui[class*="six column"].doubling.grid > .row > .column,
- .ui[class*="six column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="six column"].doubling.row.row > .column {
- width: @threeColumn !important;
- }
- .ui[class*="seven column"].doubling.grid > .row > .column,
- .ui[class*="seven column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="seven column"].doubling.row.row > .column {
- width: @threeColumn !important;
- }
- .ui[class*="eight column"].doubling.grid > .row > .column,
- .ui[class*="eight column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="eight column"].doubling.row.row > .column {
- width: @fourColumn !important;
- }
- .ui[class*="nine column"].doubling.grid > .row > .column,
- .ui[class*="nine column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="nine column"].doubling.row.row > .column {
- width: @fourColumn !important;
- }
- .ui[class*="ten column"].doubling.grid > .row > .column,
- .ui[class*="ten column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="ten column"].doubling.row.row > .column {
- width: @fiveColumn !important;
- }
- .ui[class*="eleven column"].doubling.grid > .row > .column,
- .ui[class*="eleven column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="eleven column"].doubling.row.row > .column {
- width: @fiveColumn !important;
- }
- .ui[class*="twelve column"].doubling.grid > .row > .column,
- .ui[class*="twelve column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="twelve column"].doubling.row.row > .column {
- width: @sixColumn !important;
- }
- .ui[class*="thirteen column"].doubling.grid > .row > .column,
- .ui[class*="thirteen column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="thirteen column"].doubling.row.row > .column {
- width: @sixColumn !important;
- }
- .ui[class*="fourteen column"].doubling.grid > .row > .column,
- .ui[class*="fourteen column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="fourteen column"].doubling.row.row > .column {
- width: @sevenColumn !important;
- }
- .ui[class*="fifteen column"].doubling.grid > .row > .column,
- .ui[class*="fifteen column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="fifteen column"].doubling.row.row > .column {
- width: @sevenColumn !important;
- }
- .ui[class*="sixteen column"].doubling.grid > .row > .column,
- .ui[class*="sixteen column"].doubling.grid > .column:not(.row),
- .ui.grid > [class*="sixteen column"].doubling.row.row > .column {
- width: @eightColumn !important;
- }
- }
-
- /* Mobile Only */
- @media only screen and (max-width: @largestMobileScreen) {
- .ui.grid > .doubling.row,
- .ui.doubling.grid > .row {
- margin: 0 !important;
- padding: 0 !important;
- }
- .ui.grid > .doubling.row > .column,
- .ui.doubling.grid > .row > .column {
- padding-top: (@rowSpacing / 2) !important;
- padding-bottom: (@rowSpacing / 2) !important;
- margin: 0 !important;
- box-shadow: none !important;
- }
- .ui[class*="two column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="two column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="two column"].doubling:not(.stackable).row.row > .column {
- width: @oneColumn !important;
- }
- .ui[class*="three column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="three column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="three column"].doubling:not(.stackable).row.row > .column {
- width: @twoColumn !important;
- }
- .ui[class*="four column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="four column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="four column"].doubling:not(.stackable).row.row > .column {
- width: @twoColumn !important;
- }
- .ui[class*="five column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="five column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="five column"].doubling:not(.stackable).row.row > .column {
- width: @twoColumn !important;
- }
- .ui[class*="six column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="six column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="six column"].doubling:not(.stackable).row.row > .column {
- width: @twoColumn !important;
- }
- .ui[class*="seven column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="seven column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="seven column"].doubling:not(.stackable).row.row > .column {
- width: @twoColumn !important;
- }
- .ui[class*="eight column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="eight column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="eight column"].doubling:not(.stackable).row.row > .column {
- width: @twoColumn !important;
- }
- .ui[class*="nine column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="nine column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="nine column"].doubling:not(.stackable).row.row > .column {
- width: @threeColumn !important;
- }
- .ui[class*="ten column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="ten column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="ten column"].doubling:not(.stackable).row.row > .column {
- width: @threeColumn !important;
- }
- .ui[class*="eleven column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="eleven column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="eleven column"].doubling:not(.stackable).row.row > .column {
- width: @threeColumn !important;
- }
- .ui[class*="twelve column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="twelve column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="twelve column"].doubling:not(.stackable).row.row > .column {
- width: @threeColumn !important;
- }
- .ui[class*="thirteen column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="thirteen column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="thirteen column"].doubling:not(.stackable).row.row > .column {
- width: @threeColumn !important;
- }
- .ui[class*="fourteen column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="fourteen column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="fourteen column"].doubling:not(.stackable).row.row > .column {
- width: @fourColumn !important;
- }
- .ui[class*="fifteen column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="fifteen column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="fifteen column"].doubling:not(.stackable).row.row > .column {
- width: @fourColumn !important;
- }
- .ui[class*="sixteen column"].doubling:not(.stackable).grid > .row > .column,
- .ui[class*="sixteen column"].doubling:not(.stackable).grid > .column:not(.row),
- .ui.grid > [class*="sixteen column"].doubling:not(.stackable).row.row > .column {
- width: @fourColumn !important;
- }
- }
+ /* -------------------
+ Doubling
+ -------------------- */
+
+ /* Tablet Only */
+ @media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) {
+ .ui.doubling.grid {
+ width: auto;
+ }
+ .ui.grid > .doubling.row,
+ .ui.doubling.grid > .row {
+ margin: 0 !important;
+ padding: 0 !important;
+ }
+ .ui.grid > .doubling.row > .column,
+ .ui.doubling.grid > .row > .column {
+ padding-top: (@rowSpacing / 2) !important;
+ padding-bottom: (@rowSpacing / 2) !important;
+ box-shadow: none !important;
+ margin: 0;
+ }
+ .ui.grid:not(.stretched) > .doubling.row:not(.stretched) > .column:not(.stretched),
+ .ui.doubling.grid:not(.stretched) > .row:not(.stretched) > .column:not(.stretched) {
+ display: inline-block !important;
+ }
+ .ui[class*="two column"].doubling.grid > .row > .column,
+ .ui[class*="two column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="two column"].doubling.row.row > .column {
+ width: @oneColumn !important;
+ }
+ .ui[class*="three column"].doubling.grid > .row > .column,
+ .ui[class*="three column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="three column"].doubling.row.row > .column {
+ width: @twoColumn !important;
+ }
+ .ui[class*="four column"].doubling.grid > .row > .column,
+ .ui[class*="four column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="four column"].doubling.row.row > .column {
+ width: @twoColumn !important;
+ }
+ .ui[class*="five column"].doubling.grid > .row > .column,
+ .ui[class*="five column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="five column"].doubling.row.row > .column {
+ width: @threeColumn !important;
+ }
+ .ui[class*="six column"].doubling.grid > .row > .column,
+ .ui[class*="six column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="six column"].doubling.row.row > .column {
+ width: @threeColumn !important;
+ }
+ .ui[class*="seven column"].doubling.grid > .row > .column,
+ .ui[class*="seven column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="seven column"].doubling.row.row > .column {
+ width: @threeColumn !important;
+ }
+ .ui[class*="eight column"].doubling.grid > .row > .column,
+ .ui[class*="eight column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="eight column"].doubling.row.row > .column {
+ width: @fourColumn !important;
+ }
+ .ui[class*="nine column"].doubling.grid > .row > .column,
+ .ui[class*="nine column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="nine column"].doubling.row.row > .column {
+ width: @fourColumn !important;
+ }
+ .ui[class*="ten column"].doubling.grid > .row > .column,
+ .ui[class*="ten column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="ten column"].doubling.row.row > .column {
+ width: @fiveColumn !important;
+ }
+ .ui[class*="eleven column"].doubling.grid > .row > .column,
+ .ui[class*="eleven column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="eleven column"].doubling.row.row > .column {
+ width: @fiveColumn !important;
+ }
+ .ui[class*="twelve column"].doubling.grid > .row > .column,
+ .ui[class*="twelve column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="twelve column"].doubling.row.row > .column {
+ width: @sixColumn !important;
+ }
+ .ui[class*="thirteen column"].doubling.grid > .row > .column,
+ .ui[class*="thirteen column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="thirteen column"].doubling.row.row > .column {
+ width: @sixColumn !important;
+ }
+ .ui[class*="fourteen column"].doubling.grid > .row > .column,
+ .ui[class*="fourteen column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="fourteen column"].doubling.row.row > .column {
+ width: @sevenColumn !important;
+ }
+ .ui[class*="fifteen column"].doubling.grid > .row > .column,
+ .ui[class*="fifteen column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="fifteen column"].doubling.row.row > .column {
+ width: @sevenColumn !important;
+ }
+ .ui[class*="sixteen column"].doubling.grid > .row > .column,
+ .ui[class*="sixteen column"].doubling.grid > .column:not(.row),
+ .ui.grid > [class*="sixteen column"].doubling.row.row > .column {
+ width: @eightColumn !important;
+ }
+ }
+
+ /* Mobile Only */
+ @media only screen and (max-width: @largestMobileScreen) {
+ .ui.grid > .doubling.row,
+ .ui.doubling.grid > .row {
+ margin: 0 !important;
+ padding: 0 !important;
+ }
+ .ui.grid > .doubling.row > .column,
+ .ui.doubling.grid > .row > .column {
+ padding-top: (@rowSpacing / 2) !important;
+ padding-bottom: (@rowSpacing / 2) !important;
+ margin: 0 !important;
+ box-shadow: none !important;
+ }
+ .ui[class*="two column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="two column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="two column"].doubling:not(.stackable).row.row > .column {
+ width: @oneColumn !important;
+ }
+ .ui[class*="three column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="three column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="three column"].doubling:not(.stackable).row.row > .column {
+ width: @twoColumn !important;
+ }
+ .ui[class*="four column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="four column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="four column"].doubling:not(.stackable).row.row > .column {
+ width: @twoColumn !important;
+ }
+ .ui[class*="five column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="five column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="five column"].doubling:not(.stackable).row.row > .column {
+ width: @twoColumn !important;
+ }
+ .ui[class*="six column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="six column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="six column"].doubling:not(.stackable).row.row > .column {
+ width: @twoColumn !important;
+ }
+ .ui[class*="seven column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="seven column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="seven column"].doubling:not(.stackable).row.row > .column {
+ width: @twoColumn !important;
+ }
+ .ui[class*="eight column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="eight column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="eight column"].doubling:not(.stackable).row.row > .column {
+ width: @twoColumn !important;
+ }
+ .ui[class*="nine column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="nine column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="nine column"].doubling:not(.stackable).row.row > .column {
+ width: @threeColumn !important;
+ }
+ .ui[class*="ten column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="ten column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="ten column"].doubling:not(.stackable).row.row > .column {
+ width: @threeColumn !important;
+ }
+ .ui[class*="eleven column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="eleven column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="eleven column"].doubling:not(.stackable).row.row > .column {
+ width: @threeColumn !important;
+ }
+ .ui[class*="twelve column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="twelve column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="twelve column"].doubling:not(.stackable).row.row > .column {
+ width: @threeColumn !important;
+ }
+ .ui[class*="thirteen column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="thirteen column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="thirteen column"].doubling:not(.stackable).row.row > .column {
+ width: @threeColumn !important;
+ }
+ .ui[class*="fourteen column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="fourteen column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="fourteen column"].doubling:not(.stackable).row.row > .column {
+ width: @fourColumn !important;
+ }
+ .ui[class*="fifteen column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="fifteen column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="fifteen column"].doubling:not(.stackable).row.row > .column {
+ width: @fourColumn !important;
+ }
+ .ui[class*="sixteen column"].doubling:not(.stackable).grid > .row > .column,
+ .ui[class*="sixteen column"].doubling:not(.stackable).grid > .column:not(.row),
+ .ui.grid > [class*="sixteen column"].doubling:not(.stackable).row.row > .column {
+ width: @fourColumn !important;
+ }
+ }
}
& when (@variationGridStackable) {
- /*-------------------
- Stackable
- --------------------*/
-
- @media only screen and (max-width: @largestMobileScreen) {
- .ui.ui.ui.ui.stackable.grid {
- width: auto;
- margin-left: 0 !important;
- margin-right: 0 !important;
- }
- .ui.stackable.grid > .row > .wide.column,
- .ui.stackable.grid > .wide.column,
- .ui.stackable.grid > .column.grid > .column,
- .ui.stackable.grid > .column.row > .column,
- .ui.stackable.grid > .row > .column,
- .ui.stackable.grid > .column:not(.row),
- .ui.grid > .stackable.stackable.stackable.row > .column {
- width: 100% !important;
- margin: 0 0 !important;
- box-shadow: none !important;
- padding: (@stackableRowSpacing / 2) (@stackableGutter / 2);
- }
- .ui.stackable.grid:not(.vertically) > .row {
- margin: 0;
- padding: 0;
- }
-
- /* Coupling */
- .ui.container > .ui.stackable.grid > .column,
- .ui.container > .ui.stackable.grid > .row > .column {
- padding-left: 0 !important;
- padding-right: 0 !important;
- }
-
- /* Don't pad inside segment or nested grid */
- .ui.grid .ui.stackable.grid,
- .ui.segment:not(.vertical) .ui.stackable.page.grid {
- margin-left: -(@stackableGutter / 2) !important;
- margin-right: -(@stackableGutter / 2) !important;
- }
-
- /* Divided Stackable */
- .ui.stackable.divided.grid > .row:first-child > .column:first-child,
- .ui.stackable.celled.grid > .row:first-child > .column:first-child,
- .ui.stackable.divided.grid > .column:not(.row):first-child,
- .ui.stackable.celled.grid > .column:not(.row):first-child {
- border-top: none !important;
+ /* -------------------
+ Stackable
+ -------------------- */
+
+ @media only screen and (max-width: @largestMobileScreen) {
+ body > .ui.stackable.grid,
+ .ui:not(.segment):not(.grid) .ui.stackable.grid {
+ width: auto;
+ margin-left: @stackableMobileGutter;
+ margin-right: @stackableMobileGutter;
+ }
+ .ui.stackable.grid > .row > .wide.column,
+ .ui.stackable.grid > .wide.column,
+ .ui.stackable.grid > .column.grid > .column,
+ .ui.stackable.grid > .column.row > .column,
+ .ui.stackable.grid > .row > .column,
+ .ui.stackable.grid > .column:not(.row),
+ .ui.grid > .stackable.stackable.stackable.row > .column {
+ width: 100% !important;
+ margin: 0 !important;
+ box-shadow: none !important;
+ padding: (@stackableRowSpacing / 2) (@stackableGutter / 2);
+ }
+ .ui.stackable.grid:not(.vertically) > .row {
+ margin: 0;
+ padding: 0;
+ }
+
+ /* Coupling */
+ .ui.container > .ui.stackable.grid > .column,
+ .ui.container > .ui.stackable.grid > .row > .column {
+ padding-left: 0 !important;
+ padding-right: 0 !important;
+ }
+
+ /* Don't pad inside segment or nested grid */
+ .ui.grid .ui.stackable.grid,
+ .ui.segment:not(.vertical) .ui.stackable.page.grid {
+ margin-left: -(@stackableGutter / 2);
+ margin-right: -(@stackableGutter / 2);
+ }
+
+ /* Divided Stackable */
+ .ui.stackable.divided.grid > .row:first-child > .column:first-child,
+ .ui.stackable.celled.grid > .row:first-child > .column:first-child,
+ .ui.stackable.divided.grid > .column:not(.row):first-child,
+ .ui.stackable.celled.grid > .column:not(.row):first-child {
+ border-top: none !important;
+ }
+ & when (@variationGridInverted) {
+ .ui.inverted.stackable.celled.grid > .column:not(.row),
+ .ui.inverted.stackable.divided.grid > .column:not(.row),
+ .ui.inverted.stackable.celled.grid > .row > .column,
+ .ui.inverted.stackable.divided.grid > .row > .column {
+ border-top: @stackableInvertedMobileBorder;
+ }
+ }
+ .ui.stackable.celled.grid > .column:not(.row),
+ .ui.stackable.divided:not(.vertically).grid > .column:not(.row),
+ .ui.stackable.celled.grid > .row > .column,
+ .ui.stackable.divided:not(.vertically).grid > .row > .column {
+ border-top: @stackableMobileBorder;
+ box-shadow: none !important;
+ padding-top: @stackableRowSpacing !important;
+ padding-bottom: @stackableRowSpacing !important;
+ }
+ & when (@variationGridCelled) {
+ .ui.stackable.celled.grid > .row {
+ box-shadow: none !important;
+ }
+ }
+ & when (@variationGridDivided) {
+ .ui.stackable.divided:not(.vertically).grid > .column:not(.row),
+ .ui.stackable.divided:not(.vertically).grid > .row > .column {
+ padding-left: 0 !important;
+ padding-right: 0 !important;
+ }
+ }
}
- & when (@variationGridInverted) {
- .ui.inverted.stackable.celled.grid > .column:not(.row),
- .ui.inverted.stackable.divided.grid > .column:not(.row),
- .ui.inverted.stackable.celled.grid > .row > .column,
- .ui.inverted.stackable.divided.grid > .row > .column {
- border-top: @stackableInvertedMobileBorder;
- }
- }
- .ui.stackable.celled.grid > .column:not(.row),
- .ui.stackable.divided:not(.vertically).grid > .column:not(.row),
- .ui.stackable.celled.grid > .row > .column,
- .ui.stackable.divided:not(.vertically).grid > .row > .column {
- border-top: @stackableMobileBorder;
- box-shadow: none !important;
- padding-top: @stackableRowSpacing !important;
- padding-bottom: @stackableRowSpacing !important;
- }
- & when (@variationGridCelled) {
- .ui.stackable.celled.grid > .row {
- box-shadow: none !important;
- }
- }
- & when (@variationGridDivided) {
- .ui.stackable.divided:not(.vertically).grid > .column:not(.row),
- .ui.stackable.divided:not(.vertically).grid > .row > .column {
- padding-left: 0 !important;
- padding-right: 0 !important;
- }
- }
- }
-
-}
-
-/*----------------------
- Only (Device)
------------------------*/
+}
+/* ----------------------
+ Only (Device)
+----------------------- */
/* These include arbitrary class repetitions for forced specificity */
/* Mobile Only Hide */
@media only screen and (max-width: @largestMobileScreen) {
- .ui[class*="tablet only"].grid.grid.grid:not(.mobile),
- .ui.grid.grid.grid > [class*="tablet only"].row:not(.mobile),
- .ui.grid.grid.grid > [class*="tablet only"].column:not(.mobile),
- .ui.grid.grid.grid > .row > [class*="tablet only"].column:not(.mobile) {
- display: none !important;
- }
- .ui[class*="computer only"].grid.grid.grid:not(.mobile),
- .ui.grid.grid.grid > [class*="computer only"].row:not(.mobile),
- .ui.grid.grid.grid > [class*="computer only"].column:not(.mobile),
- .ui.grid.grid.grid > .row > [class*="computer only"].column:not(.mobile) {
- display: none !important;
- }
- .ui[class*="large screen only"].grid.grid.grid:not(.mobile),
- .ui.grid.grid.grid > [class*="large screen only"].row:not(.mobile),
- .ui.grid.grid.grid > [class*="large screen only"].column:not(.mobile),
- .ui.grid.grid.grid > .row > [class*="large screen only"].column:not(.mobile) {
- display: none !important;
- }
- .ui[class*="widescreen only"].grid.grid.grid:not(.mobile),
- .ui.grid.grid.grid > [class*="widescreen only"].row:not(.mobile),
- .ui.grid.grid.grid > [class*="widescreen only"].column:not(.mobile),
- .ui.grid.grid.grid > .row > [class*="widescreen only"].column:not(.mobile) {
- display: none !important;
- }
+ .ui[class*="tablet only"].grid.grid.grid:not(.mobile),
+ .ui.grid.grid.grid > [class*="tablet only"].row:not(.mobile),
+ .ui.grid.grid.grid > [class*="tablet only"].column:not(.mobile),
+ .ui.grid.grid.grid > .row > [class*="tablet only"].column:not(.mobile) {
+ display: none !important;
+ }
+ .ui[class*="computer only"].grid.grid.grid:not(.mobile),
+ .ui.grid.grid.grid > [class*="computer only"].row:not(.mobile),
+ .ui.grid.grid.grid > [class*="computer only"].column:not(.mobile),
+ .ui.grid.grid.grid > .row > [class*="computer only"].column:not(.mobile) {
+ display: none !important;
+ }
+ .ui[class*="large screen only"].grid.grid.grid:not(.mobile),
+ .ui.grid.grid.grid > [class*="large screen only"].row:not(.mobile),
+ .ui.grid.grid.grid > [class*="large screen only"].column:not(.mobile),
+ .ui.grid.grid.grid > .row > [class*="large screen only"].column:not(.mobile) {
+ display: none !important;
+ }
+ .ui[class*="widescreen only"].grid.grid.grid:not(.mobile),
+ .ui.grid.grid.grid > [class*="widescreen only"].row:not(.mobile),
+ .ui.grid.grid.grid > [class*="widescreen only"].column:not(.mobile),
+ .ui.grid.grid.grid > .row > [class*="widescreen only"].column:not(.mobile) {
+ display: none !important;
+ }
}
+
/* Tablet Only Hide */
@media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) {
- .ui[class*="mobile only"].grid.grid.grid:not(.tablet),
- .ui.grid.grid.grid > [class*="mobile only"].row:not(.tablet),
- .ui.grid.grid.grid > [class*="mobile only"].column:not(.tablet),
- .ui.grid.grid.grid > .row > [class*="mobile only"].column:not(.tablet) {
- display: none !important;
- }
- .ui[class*="computer only"].grid.grid.grid:not(.tablet),
- .ui.grid.grid.grid > [class*="computer only"].row:not(.tablet),
- .ui.grid.grid.grid > [class*="computer only"].column:not(.tablet),
- .ui.grid.grid.grid > .row > [class*="computer only"].column:not(.tablet) {
- display: none !important;
- }
- .ui[class*="large screen only"].grid.grid.grid:not(.mobile),
- .ui.grid.grid.grid > [class*="large screen only"].row:not(.mobile),
- .ui.grid.grid.grid > [class*="large screen only"].column:not(.mobile),
- .ui.grid.grid.grid > .row > [class*="large screen only"].column:not(.mobile) {
- display: none !important;
- }
- .ui[class*="widescreen only"].grid.grid.grid:not(.mobile),
- .ui.grid.grid.grid > [class*="widescreen only"].row:not(.mobile),
- .ui.grid.grid.grid > [class*="widescreen only"].column:not(.mobile),
- .ui.grid.grid.grid > .row > [class*="widescreen only"].column:not(.mobile) {
- display: none !important;
- }
+ .ui[class*="mobile only"].grid.grid.grid:not(.tablet),
+ .ui.grid.grid.grid > [class*="mobile only"].row:not(.tablet),
+ .ui.grid.grid.grid > [class*="mobile only"].column:not(.tablet),
+ .ui.grid.grid.grid > .row > [class*="mobile only"].column:not(.tablet) {
+ display: none !important;
+ }
+ .ui[class*="computer only"].grid.grid.grid:not(.tablet),
+ .ui.grid.grid.grid > [class*="computer only"].row:not(.tablet),
+ .ui.grid.grid.grid > [class*="computer only"].column:not(.tablet),
+ .ui.grid.grid.grid > .row > [class*="computer only"].column:not(.tablet) {
+ display: none !important;
+ }
+ .ui[class*="large screen only"].grid.grid.grid:not(.mobile),
+ .ui.grid.grid.grid > [class*="large screen only"].row:not(.mobile),
+ .ui.grid.grid.grid > [class*="large screen only"].column:not(.mobile),
+ .ui.grid.grid.grid > .row > [class*="large screen only"].column:not(.mobile) {
+ display: none !important;
+ }
+ .ui[class*="widescreen only"].grid.grid.grid:not(.mobile),
+ .ui.grid.grid.grid > [class*="widescreen only"].row:not(.mobile),
+ .ui.grid.grid.grid > [class*="widescreen only"].column:not(.mobile),
+ .ui.grid.grid.grid > .row > [class*="widescreen only"].column:not(.mobile) {
+ display: none !important;
+ }
}
/* Computer Only Hide */
@media only screen and (min-width: @computerBreakpoint) and (max-width: @largestSmallMonitor) {
- .ui[class*="mobile only"].grid.grid.grid:not(.computer),
- .ui.grid.grid.grid > [class*="mobile only"].row:not(.computer),
- .ui.grid.grid.grid > [class*="mobile only"].column:not(.computer),
- .ui.grid.grid.grid > .row > [class*="mobile only"].column:not(.computer) {
- display: none !important;
- }
- .ui[class*="tablet only"].grid.grid.grid:not(.computer),
- .ui.grid.grid.grid > [class*="tablet only"].row:not(.computer),
- .ui.grid.grid.grid > [class*="tablet only"].column:not(.computer),
- .ui.grid.grid.grid > .row > [class*="tablet only"].column:not(.computer) {
- display: none !important;
- }
- .ui[class*="large screen only"].grid.grid.grid:not(.mobile),
- .ui.grid.grid.grid > [class*="large screen only"].row:not(.mobile),
- .ui.grid.grid.grid > [class*="large screen only"].column:not(.mobile),
- .ui.grid.grid.grid > .row > [class*="large screen only"].column:not(.mobile) {
- display: none !important;
- }
- .ui[class*="widescreen only"].grid.grid.grid:not(.mobile),
- .ui.grid.grid.grid > [class*="widescreen only"].row:not(.mobile),
- .ui.grid.grid.grid > [class*="widescreen only"].column:not(.mobile),
- .ui.grid.grid.grid > .row > [class*="widescreen only"].column:not(.mobile) {
- display: none !important;
- }
+ .ui[class*="mobile only"].grid.grid.grid:not(.computer),
+ .ui.grid.grid.grid > [class*="mobile only"].row:not(.computer),
+ .ui.grid.grid.grid > [class*="mobile only"].column:not(.computer),
+ .ui.grid.grid.grid > .row > [class*="mobile only"].column:not(.computer) {
+ display: none !important;
+ }
+ .ui[class*="tablet only"].grid.grid.grid:not(.computer),
+ .ui.grid.grid.grid > [class*="tablet only"].row:not(.computer),
+ .ui.grid.grid.grid > [class*="tablet only"].column:not(.computer),
+ .ui.grid.grid.grid > .row > [class*="tablet only"].column:not(.computer) {
+ display: none !important;
+ }
+ .ui[class*="large screen only"].grid.grid.grid:not(.mobile),
+ .ui.grid.grid.grid > [class*="large screen only"].row:not(.mobile),
+ .ui.grid.grid.grid > [class*="large screen only"].column:not(.mobile),
+ .ui.grid.grid.grid > .row > [class*="large screen only"].column:not(.mobile) {
+ display: none !important;
+ }
+ .ui[class*="widescreen only"].grid.grid.grid:not(.mobile),
+ .ui.grid.grid.grid > [class*="widescreen only"].row:not(.mobile),
+ .ui.grid.grid.grid > [class*="widescreen only"].column:not(.mobile),
+ .ui.grid.grid.grid > .row > [class*="widescreen only"].column:not(.mobile) {
+ display: none !important;
+ }
}
/* Large Screen Only Hide */
@media only screen and (min-width: @largeMonitorBreakpoint) and (max-width: @largestLargeMonitor) {
- .ui[class*="mobile only"].grid.grid.grid:not(.computer),
- .ui.grid.grid.grid > [class*="mobile only"].row:not(.computer),
- .ui.grid.grid.grid > [class*="mobile only"].column:not(.computer),
- .ui.grid.grid.grid > .row > [class*="mobile only"].column:not(.computer) {
- display: none !important;
- }
- .ui[class*="tablet only"].grid.grid.grid:not(.computer),
- .ui.grid.grid.grid > [class*="tablet only"].row:not(.computer),
- .ui.grid.grid.grid > [class*="tablet only"].column:not(.computer),
- .ui.grid.grid.grid > .row > [class*="tablet only"].column:not(.computer) {
- display: none !important;
- }
- .ui[class*="widescreen only"].grid.grid.grid:not(.mobile),
- .ui.grid.grid.grid > [class*="widescreen only"].row:not(.mobile),
- .ui.grid.grid.grid > [class*="widescreen only"].column:not(.mobile),
- .ui.grid.grid.grid > .row > [class*="widescreen only"].column:not(.mobile) {
- display: none !important;
- }
+ .ui[class*="mobile only"].grid.grid.grid:not(.computer),
+ .ui.grid.grid.grid > [class*="mobile only"].row:not(.computer),
+ .ui.grid.grid.grid > [class*="mobile only"].column:not(.computer),
+ .ui.grid.grid.grid > .row > [class*="mobile only"].column:not(.computer) {
+ display: none !important;
+ }
+ .ui[class*="tablet only"].grid.grid.grid:not(.computer),
+ .ui.grid.grid.grid > [class*="tablet only"].row:not(.computer),
+ .ui.grid.grid.grid > [class*="tablet only"].column:not(.computer),
+ .ui.grid.grid.grid > .row > [class*="tablet only"].column:not(.computer) {
+ display: none !important;
+ }
+ .ui[class*="widescreen only"].grid.grid.grid:not(.mobile),
+ .ui.grid.grid.grid > [class*="widescreen only"].row:not(.mobile),
+ .ui.grid.grid.grid > [class*="widescreen only"].column:not(.mobile),
+ .ui.grid.grid.grid > .row > [class*="widescreen only"].column:not(.mobile) {
+ display: none !important;
+ }
}
/* Widescreen Only Hide */
@media only screen and (min-width: @widescreenMonitorBreakpoint) {
- .ui[class*="mobile only"].grid.grid.grid:not(.computer),
- .ui.grid.grid.grid > [class*="mobile only"].row:not(.computer),
- .ui.grid.grid.grid > [class*="mobile only"].column:not(.computer),
- .ui.grid.grid.grid > .row > [class*="mobile only"].column:not(.computer) {
- display: none !important;
- }
- .ui[class*="tablet only"].grid.grid.grid:not(.computer),
- .ui.grid.grid.grid > [class*="tablet only"].row:not(.computer),
- .ui.grid.grid.grid > [class*="tablet only"].column:not(.computer),
- .ui.grid.grid.grid > .row > [class*="tablet only"].column:not(.computer) {
- display: none !important;
- }
-}
-
-& when (@variationGridCompact) {
- /*-----------------
- Compact
- -----------------*/
-
- .ui.ui.ui.compact.grid {
- margin: -(@compactGutterWidth / 2);
- }
-
- .ui.ui.ui.compact.grid > .column:not(.row),
- .ui.ui.ui.compact.grid > .row > .column {
- padding-left: (@compactGutterWidth / 2);
- padding-right: (@compactGutterWidth / 2);
- }
-
- .ui.ui.ui.compact.grid > * {
- padding-left: (@compactGutterWidth / 2);
- padding-right: (@compactGutterWidth / 2);
- }
-
- /* Row */
- .ui.ui.ui.compact.grid > .row {
- padding-top: (@compactRowSpacing / 2);
- padding-bottom: (@compactRowSpacing / 2);
- padding-left: 0;
- padding-right: 0;
- }
-
- /* Columns */
- .ui.ui.ui.compact.grid > .column:not(.row) {
- padding-top: (@compactRowSpacing / 2);
- padding-bottom: (@compactRowSpacing / 2);
- }
- & when (@variationGridRelaxed) and (@variationGridCelled) {
- /* Relaxed + Celled */
- .ui.compact.relaxed.celled.grid > .column:not(.row),
- .ui.compact.relaxed.celled.grid > .row > .column {
- padding: @compactCelledRelaxedPadding;
+ .ui[class*="mobile only"].grid.grid.grid:not(.computer),
+ .ui.grid.grid.grid > [class*="mobile only"].row:not(.computer),
+ .ui.grid.grid.grid > [class*="mobile only"].column:not(.computer),
+ .ui.grid.grid.grid > .row > [class*="mobile only"].column:not(.computer) {
+ display: none !important;
}
- & when (@variationGridVeryRelaxed) {
- .ui.compact[class*="very relaxed"].celled.grid > .column:not(.row),
- .ui.compact[class*="very relaxed"].celled.grid > .row > .column {
- padding: @compactCelledVeryRelaxedPadding;
- }
+ .ui[class*="tablet only"].grid.grid.grid:not(.computer),
+ .ui.grid.grid.grid > [class*="tablet only"].row:not(.computer),
+ .ui.grid.grid.grid > [class*="tablet only"].column:not(.computer),
+ .ui.grid.grid.grid > .row > [class*="tablet only"].column:not(.computer) {
+ display: none !important;
}
- }
+}
- /*-----------------
- Very compact
- -----------------*/
+& when (@variationGridCompact) {
+ /* -----------------
+ Compact
+ ----------------- */
- & when (@variationGridVeryCompact) {
- .ui.ui.ui[class*="very compact"].grid {
- margin: -(@veryCompactGutterWidth / 2);
+ .ui.ui.ui.compact.grid {
+ margin: -(@compactGutterWidth / 2);
}
- .ui.ui.ui[class*="very compact"].grid > .column:not(.row),
- .ui.ui.ui[class*="very compact"].grid > .row > .column {
- padding-left: (@veryCompactGutterWidth / 2);
- padding-right: (@veryCompactGutterWidth / 2);
+ .ui.ui.ui.compact.grid > .column:not(.row),
+ .ui.ui.ui.compact.grid > .row > .column {
+ padding-left: (@compactGutterWidth / 2);
+ padding-right: (@compactGutterWidth / 2);
}
- .ui.ui.ui[class*="very compact"].grid > * {
- padding-left: (@veryCompactGutterWidth / 2);
- padding-right: (@veryCompactGutterWidth / 2);
+ .ui.ui.ui.compact.grid > * {
+ padding-left: (@compactGutterWidth / 2);
+ padding-right: (@compactGutterWidth / 2);
}
/* Row */
- .ui.ui.ui[class*="very compact"].grid > .row {
- padding-top: (@veryCompactRowSpacing / 2);
- padding-bottom: (@veryCompactRowSpacing / 2);
- padding-left: 0;
- padding-right: 0;
+ .ui.ui.ui.compact.grid > .row {
+ padding: (@compactRowSpacing / 2) 0;
}
/* Columns */
- .ui.ui.ui[class*="very compact"].grid > .column:not(.row) {
- padding-top: (@veryCompactRowSpacing / 2);
- padding-bottom: (@veryCompactRowSpacing / 2);
+ .ui.ui.ui.compact.grid > .column:not(.row) {
+ padding-top: (@compactRowSpacing / 2);
+ padding-bottom: (@compactRowSpacing / 2);
}
& when (@variationGridRelaxed) and (@variationGridCelled) {
- /* Relaxed + Celled */
- .ui[class*="very compact"].relaxed.celled.grid > .column:not(.row),
- .ui[class*="very compact"].relaxed.celled.grid > .row > .column {
- padding: @veryCompactCelledRelaxedPadding;
- }
- & when (@variationGridVeryRelaxed) {
- .ui[class*="very compact"][class*="very relaxed"].celled.grid > .column:not(.row),
- .ui[class*="very compact"][class*="very relaxed"].celled.grid > .row > .column {
- padding: @veryCompactCelledVeryRelaxedPadding;
+ /* Relaxed + Celled */
+ .ui.compact.relaxed.celled.grid > .column:not(.row),
+ .ui.compact.relaxed.celled.grid > .row > .column {
+ padding: @compactCelledRelaxedPadding;
+ }
+ & when (@variationGridVeryRelaxed) {
+ .ui.compact[class*="very relaxed"].celled.grid > .column:not(.row),
+ .ui.compact[class*="very relaxed"].celled.grid > .row > .column {
+ padding: @compactCelledVeryRelaxedPadding;
+ }
}
- }
}
- }
-}
+ /* -----------------
+ Very compact
+ ----------------- */
+
+ & when (@variationGridVeryCompact) {
+ .ui.ui.ui[class*="very compact"].grid {
+ margin: -(@veryCompactGutterWidth / 2);
+ }
+
+ .ui.ui.ui[class*="very compact"].grid > .column:not(.row),
+ .ui.ui.ui[class*="very compact"].grid > .row > .column {
+ padding-left: (@veryCompactGutterWidth / 2);
+ padding-right: (@veryCompactGutterWidth / 2);
+ }
+
+ .ui.ui.ui[class*="very compact"].grid > * {
+ padding-left: (@veryCompactGutterWidth / 2);
+ padding-right: (@veryCompactGutterWidth / 2);
+ }
+
+ /* Row */
+ .ui.ui.ui[class*="very compact"].grid > .row {
+ padding: (@veryCompactRowSpacing / 2) 0;
+ }
+
+ /* Columns */
+ .ui.ui.ui[class*="very compact"].grid > .column:not(.row) {
+ padding-top: (@veryCompactRowSpacing / 2);
+ padding-bottom: (@veryCompactRowSpacing / 2);
+ }
+ & when (@variationGridRelaxed) and (@variationGridCelled) {
+ /* Relaxed + Celled */
+ .ui[class*="very compact"].relaxed.celled.grid > .column:not(.row),
+ .ui[class*="very compact"].relaxed.celled.grid > .row > .column {
+ padding: @veryCompactCelledRelaxedPadding;
+ }
+ & when (@variationGridVeryRelaxed) {
+ .ui[class*="very compact"][class*="very relaxed"].celled.grid > .column:not(.row),
+ .ui[class*="very compact"][class*="very relaxed"].celled.grid > .row > .column {
+ padding: @veryCompactCelledVeryRelaxedPadding;
+ }
+ }
+ }
+ }
+}
.loadUIOverrides();
diff --git a/definitions/collections/menu.less b/definitions/collections/menu.less
index e4183d3..7c06697 100644
--- a/definitions/collections/menu.less
+++ b/definitions/collections/menu.less
@@ -1,2003 +1,1981 @@
/*
* # Fomantic - Menu
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Copyright 2015 Contributor
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-
/*******************************
Theme
*******************************/
-@type : 'collection';
-@element : 'menu';
+@type: "collection";
+@element: "menu";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Standard
*******************************/
-/*--------------
+/* --------------
Menu
----------------*/
+--------------- */
.ui.menu {
- display: flex;
- margin: @margin;
- font-family: @fontFamily;
- background: @background;
- font-weight: @fontWeight;
- border: @border;
- box-shadow: @boxShadow;
- border-radius: @borderRadius;
- min-height: @minHeight;
+ display: flex;
+ margin: @margin;
+ font-family: @fontFamily;
+ background: @background;
+ font-weight: @fontWeight;
+ border: @border;
+ box-shadow: @boxShadow;
+ border-radius: @borderRadius;
+ min-height: @minHeight;
}
.ui.menu::after {
- content: '';
- display: block;
- height: 0;
- clear: both;
- visibility: hidden;
+ content: "";
+ display: block;
+ height: 0;
+ clear: both;
+ visibility: hidden;
}
.ui.menu:first-child {
- margin-top: 0;
+ margin-top: 0;
}
.ui.menu:last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
-
-/*--------------
+/* --------------
Sub-Menu
----------------*/
+--------------- */
.ui.menu .menu {
- margin: 0;
+ margin: 0;
}
.ui.menu:not(.vertical) > .menu {
- display: flex;
+ display: flex;
}
-/*--------------
+/* --------------
Item
----------------*/
+--------------- */
.ui.menu:not(.vertical) .item {
- display: flex;
- align-items: center;
+ display: flex;
+ align-items: center;
}
.ui.menu .item {
- position: relative;
- vertical-align: middle;
- line-height: 1;
- text-decoration: none;
- -webkit-tap-highlight-color: transparent;
- flex: 0 0 auto;
- user-select: none;
-
- background: @itemBackground;
- padding: @itemVerticalPadding @itemHorizontalPadding;
- text-transform: @itemTextTransform;
- color: @itemTextColor;
- font-weight: @itemFontWeight;
- transition: @itemTransition;
+ position: relative;
+ vertical-align: middle;
+ line-height: 1;
+ text-decoration: none;
+ -webkit-tap-highlight-color: transparent;
+ flex: 0 0 auto;
+ user-select: none;
+ background: @itemBackground;
+ padding: @itemVerticalPadding @itemHorizontalPadding;
+ text-transform: @itemTextTransform;
+ color: @itemTextColor;
+ font-weight: @itemFontWeight;
+ transition: @itemTransition;
}
.ui.menu > .item:first-child {
- border-radius: @borderRadius 0 0 @borderRadius;
+ border-radius: @borderRadius 0 0 @borderRadius;
}
/* Border */
.ui.menu .item::before {
- position: absolute;
- content: '';
- top: 0;
- right: 0;
- height: 100%;
-
- width: @dividerSize;
- background: @dividerBackground;
+ position: absolute;
+ content: "";
+ top: 0;
+ right: 0;
+ height: 100%;
+ width: @dividerSize;
+ background: @dividerBackground;
}
-/*--------------
+/* --------------
Text Content
----------------*/
+--------------- */
.ui.menu .text.item > *,
.ui.menu .item > a:not(.ui),
.ui.menu .item > p:only-child {
- user-select: text;
- line-height: @textLineHeight;
+ user-select: text;
+ line-height: @textLineHeight;
}
.ui.menu .item > p:first-child {
- margin-top: 0;
+ margin-top: 0;
}
.ui.menu .item > p:last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
-/*--------------
+/* --------------
Icons
----------------*/
+--------------- */
.ui.menu .item > i.icon {
- opacity: @iconOpacity;
- float: @iconFloat;
- margin: @iconMargin;
+ opacity: @iconOpacity;
+ float: @iconFloat;
+ margin: @iconMargin;
}
-/*--------------
+/* --------------
Button
----------------*/
+--------------- */
.ui.menu:not(.vertical) .item > .button {
- position: relative;
- top: @buttonOffset;
- margin: @buttonMargin;
- padding-bottom: @buttonVerticalPadding;
- padding-top: @buttonVerticalPadding;
- font-size: @buttonSize;
+ position: relative;
+ top: @buttonOffset;
+ margin: @buttonMargin;
+ padding-bottom: @buttonVerticalPadding;
+ padding-top: @buttonVerticalPadding;
+ font-size: @buttonSize;
}
-/*----------------
+/* ----------------
Grid / Container
------------------*/
+----------------- */
-.ui.menu > .grid,
+.ui.menu > .grid,
.ui.menu > .container {
- display: flex;
- align-items: inherit;
- flex-direction: inherit;
+ display: flex;
+ align-items: inherit;
+ flex-direction: inherit;
}
-/*--------------
+/* --------------
Inputs
----------------*/
+--------------- */
.ui.menu .item > .input {
- width: 100%;
+ width: 100%;
}
.ui.menu:not(.vertical) .item > .input {
- position: relative;
- top: @inputOffset;
- margin: @inputVerticalMargin 0;
+ position: relative;
+ top: @inputOffset;
+ margin: @inputVerticalMargin 0;
}
.ui.menu .item > .input input {
- font-size: @inputSize;
- padding-top: @inputVerticalPadding;
- padding-bottom: @inputVerticalPadding;
+ font-size: @inputSize;
+ padding-top: @inputVerticalPadding;
+ padding-bottom: @inputVerticalPadding;
}
-
-/*--------------
+/* --------------
Header
----------------*/
+--------------- */
.ui.menu .header.item,
.ui.vertical.menu .header.item {
- margin: 0;
- background: @headerBackground;
- text-transform: @headerTextTransform;
- font-weight: @headerWeight;
+ margin: 0;
+ background: @headerBackground;
+ text-transform: @headerTextTransform;
+ font-weight: @headerWeight;
}
& when (@variationMenuVertical) {
- .ui.vertical.menu .item > .header:not(.ui) {
- margin: @verticalHeaderMargin;
- font-size: @verticalHeaderFontSize;
- font-weight: @verticalHeaderFontWeight;
- }
+ .ui.vertical.menu .item > .header:not(.ui) {
+ margin: @verticalHeaderMargin;
+ font-size: @verticalHeaderFontSize;
+ font-weight: @verticalHeaderFontWeight;
+ }
}
-/*--------------
+/* --------------
Dropdowns
----------------*/
-
+--------------- */
/* Dropdown Icon */
.ui.menu .item > i.dropdown.icon {
- padding: 0;
- float: @dropdownIconFloat;
- margin: 0 0 0 @dropdownIconDistance;
+ padding: 0;
+ float: @dropdownIconFloat;
+ margin: 0 0 0 @dropdownIconDistance;
}
/* Menu */
.ui.menu .dropdown.item .menu {
- min-width: e("calc(100% - 1px)");
- border-radius: 0 0 @dropdownMenuBorderRadius @dropdownMenuBorderRadius;
- background: @dropdownBackground;
- margin: @dropdownMenuDistance 0 0;
- box-shadow: @dropdownMenuBoxShadow;
+ min-width: e("calc(100% - 1px)");
+ border-radius: 0 0 @dropdownMenuBorderRadius @dropdownMenuBorderRadius;
+ background: @dropdownBackground;
+ margin: @dropdownMenuDistance 0 0;
+ box-shadow: @dropdownMenuBoxShadow;
}
.ui.menu .dropdown.item:not(.column) .menu {
- flex-direction: column;
+ flex-direction: column;
}
-
/* Menu Items */
.ui.menu .ui.dropdown .menu > .item {
- margin: 0;
- text-align: left;
- font-size: @dropdownItemFontSize !important;
- padding: @dropdownItemPadding !important;
- background: @dropdownItemBackground !important;
- color: @dropdownItemColor !important;
- text-transform: @dropdownItemTextTransform !important;
- font-weight: @dropdownItemFontWeight !important;
- box-shadow: @dropdownItemBoxShadow !important;
- transition: @dropdownItemTransition !important;
+ margin: 0;
+ text-align: left;
+ font-size: @dropdownItemFontSize !important;
+ padding: @dropdownItemPadding !important;
+ background: @dropdownItemBackground !important;
+ color: @dropdownItemColor !important;
+ text-transform: @dropdownItemTextTransform !important;
+ font-weight: @dropdownItemFontWeight !important;
+ box-shadow: @dropdownItemBoxShadow !important;
+ transition: @dropdownItemTransition !important;
}
.ui.menu .ui.dropdown .menu > .item:hover {
- background: @dropdownHoveredItemBackground !important;
- color: @dropdownHoveredItemColor !important;
+ background: @dropdownHoveredItemBackground !important;
+ color: @dropdownHoveredItemColor !important;
}
.ui.menu .ui.dropdown .menu > .selected.item {
- background: @dropdownSelectedItemBackground !important;
- color: @dropdownSelectedItemColor !important;
+ background: @dropdownSelectedItemBackground !important;
+ color: @dropdownSelectedItemColor !important;
}
.ui.menu .ui.dropdown .menu > .active.item {
- background: @dropdownActiveItemBackground !important;
- font-weight: @dropdownActiveItemFontWeight !important;
- color: @dropdownActiveItemColor !important;
+ background: @dropdownActiveItemBackground !important;
+ font-weight: @dropdownActiveItemFontWeight !important;
+ color: @dropdownActiveItemColor !important;
}
.ui.menu .ui.dropdown.item .menu .item:not(.filtered) {
- display: block;
+ display: block;
}
.ui.menu .ui.dropdown .menu > .item > .icons,
.ui.menu .ui.dropdown .menu > .item > i.icon:not(.dropdown) {
- display: inline-block;
- font-size: @dropdownItemIconFontSize !important;
- float: @dropdownItemIconFloat;
- margin: @dropdownItemIconMargin !important;
+ display: inline-block;
+ font-size: @dropdownItemIconFontSize !important;
+ float: @dropdownItemIconFloat;
+ margin: @dropdownItemIconMargin !important;
}
& when (@variationMenuSecondary) or (@variationMenuText) {
- /* Secondary */
- .ui.secondary.menu .dropdown.item > .menu,
- .ui.text.menu .dropdown.item > .menu {
- border-radius: @dropdownMenuBorderRadius;
- margin-top: @secondaryDropdownMenuDistance;
- }
+ /* Secondary */
+ .ui.secondary.menu .dropdown.item > .menu,
+ .ui.text.menu .dropdown.item > .menu {
+ border-radius: @dropdownMenuBorderRadius;
+ margin-top: @secondaryDropdownMenuDistance;
+ }
}
- /* Pointing */
- .ui.menu .pointing.dropdown.item .menu {
+/* Pointing */
+.ui.menu .pointing.dropdown.item .menu {
margin-top: @pointingDropdownMenuDistance;
}
& when (@variationMenuInverted) {
- /* Inverted */
- .ui.inverted.menu .search.dropdown.item > .search,
- .ui.inverted.menu .search.dropdown.item > .text {
- color: @invertedSelectionDropdownColor;
- }
+ /* Inverted */
+ .ui.inverted.menu .search.dropdown.item > .search,
+ .ui.inverted.menu .search.dropdown.item > .text {
+ color: @invertedSelectionDropdownColor;
+ }
}
& when (@variationMenuVertical) {
- /* Vertical */
- .ui.vertical.menu .dropdown.item > i.icon {
- float: right;
- content: "\f0da";
- margin-left: 1em;
- }
- .ui.vertical.menu .dropdown.item .menu {
- left: 100%;
- & when (@supportIE) {
- /* IE needs 0, all others support max-content to show dropdown icon inline, so keep both settings! */
- min-width: 0;
- }
- min-width: max-content;
- margin: 0 0 0 @dropdownMenuDistance;
- box-shadow: @dropdownVerticalMenuBoxShadow;
- border-radius: 0 @dropdownMenuBorderRadius @dropdownMenuBorderRadius @dropdownMenuBorderRadius;
- }
- .ui.vertical.menu .dropdown.item.upward .menu {
- bottom: 0;
- }
- .ui.vertical.menu .dropdown.item:not(.upward) .menu {
- top: 0;
- }
- .ui.vertical.menu .active.dropdown.item {
- border-top-right-radius: 0;
- border-bottom-right-radius: 0;
- }
- .ui.vertical.menu .dropdown.active.item {
- box-shadow: none;
- }
+ /* Vertical */
+ .ui.vertical.menu .dropdown.item > i.icon {
+ float: right;
+ content: "\f0da";
+ margin-left: 1em;
+ }
+ .ui.vertical.menu .dropdown.item .menu {
+ left: 100%;
+ & when (@supportIE) {
+ /* IE needs 0, all others support max-content to show dropdown icon inline, so keep both settings! */
+ min-width: 0;
+ }
+
+ min-width: max-content;
+ margin: 0 0 0 @dropdownMenuDistance;
+ box-shadow: @dropdownVerticalMenuBoxShadow;
+ border-radius: 0 @dropdownMenuBorderRadius @dropdownMenuBorderRadius @dropdownMenuBorderRadius;
+ }
+ .ui.vertical.menu .dropdown.item.upward .menu {
+ bottom: 0;
+ }
+ .ui.vertical.menu .dropdown.item:not(.upward) .menu {
+ top: 0;
+ }
+ .ui.vertical.menu .active.dropdown.item {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+ }
+ .ui.vertical.menu .dropdown.active.item {
+ box-shadow: none;
+ }
}
/* Evenly Divided */
.ui.item.menu .dropdown .menu .item {
- width: 100%;
+ width: 100%;
}
-/*--------------
+/* --------------
Labels
----------------*/
+--------------- */
.ui.menu .item > .label:not(.floating) {
- margin-left: @labelTextMargin;
- padding: @labelVerticalPadding @labelHorizontalPadding;
+ margin-left: @labelTextMargin;
+ padding: @labelVerticalPadding @labelHorizontalPadding;
}
& when (@variationMenuVertical) {
- .ui.vertical.menu .item > .label {
- margin-top: @labelOffset;
- margin-bottom: @labelOffset;
- padding: @labelVerticalPadding @labelHorizontalPadding;
- }
+ .ui.vertical.menu .item > .label {
+ margin-top: @labelOffset;
+ margin-bottom: @labelOffset;
+ padding: @labelVerticalPadding @labelHorizontalPadding;
+ }
}
.ui.menu .item > .floating.label {
- padding: @labelVerticalPadding @labelHorizontalPadding;
+ padding: @labelVerticalPadding @labelHorizontalPadding;
}
.ui.menu .item > .label {
- background: @labelBackground;
- color: @labelTextColor;
+ background: @labelBackground;
+ color: @labelTextColor;
}
.ui.menu .item > .image.label img {
- margin: @imageLabelImageMargin;
- height: @imageLabelHeight;
+ margin: @imageLabelImageMargin;
+ height: @imageLabelHeight;
}
-/*--------------
+
+/* --------------
Images
----------------*/
+--------------- */
.ui.menu .item > img:not(.ui) {
- display: inline-block;
- vertical-align: middle;
- margin: @imageMargin;
- width: @imageWidth;
+ display: inline-block;
+ vertical-align: middle;
+ margin: @imageMargin;
+ width: @imageWidth;
}
& when (@variationMenuVertical) {
- .ui.vertical.menu .item > img:not(.ui):only-child {
- display: block;
- max-width: 100%;
- width: @verticalImageWidth;
- }
+ .ui.vertical.menu .item > img:not(.ui):only-child {
+ display: block;
+ max-width: 100%;
+ width: @verticalImageWidth;
+ }
}
/*******************************
Coupling
*******************************/
-/*--------------
+/* --------------
List
----------------*/
+--------------- */
/* Menu divider shouldn't apply */
.ui.menu .list .item::before {
- background: none !important;
+ background: none !important;
}
& when (@variationMenuVertical) {
- /*--------------
- Sidebar
- ---------------*/
+ /* --------------
+ Sidebar
+ --------------- */
- /* Show vertical dividers below last */
+ /* Show vertical dividers below last */
- .ui.vertical.sidebar.menu > .item:first-child::before {
- display: block !important;
- }
- .ui.vertical.sidebar.menu > .item::before {
- top: auto;
- bottom: 0;
- }
+ .ui.vertical.sidebar.menu > .item:first-child::before {
+ display: block !important;
+ }
+ .ui.vertical.sidebar.menu > .item::before {
+ top: auto;
+ bottom: 0;
+ }
}
-/*--------------
+/* --------------
Container
----------------*/
+--------------- */
@media only screen and (max-width: @largestMobileScreen) {
- .ui.menu > .ui.container {
- width: 100% !important;
- margin-left: 0 !important;
- margin-right: 0 !important;
- }
+ .ui.menu > .ui.container {
+ width: 100% !important;
+ margin-left: 0 !important;
+ margin-right: 0 !important;
+ }
}
@media only screen and (min-width: @tabletBreakpoint) {
- .ui.menu:not(.secondary):not(.text):not(.tabular):not(.borderless) > .container > .item:not(.right):not(.borderless):first-child {
- border-left: @dividerSize solid @dividerBackground;
- }
- .ui.menu:not(.secondary):not(.text):not(.tabular):not(.borderless) > .container > .right.item:not(.borderless):last-child,
- .ui.menu:not(.secondary):not(.text):not(.tabular):not(.borderless) > .container > .right.menu > .item:not(.borderless):last-child {
- border-right: @dividerSize solid @dividerBackground;
- }
+ .ui.menu:not(.secondary):not(.text):not(.tabular):not(.borderless) > .container > .item:not(.right):not(.borderless):first-child {
+ border-left: @dividerSize solid @dividerBackground;
+ }
+ .ui.menu:not(.secondary):not(.text):not(.tabular):not(.borderless) > .container > .right.item:not(.borderless):last-child,
+ .ui.menu:not(.secondary):not(.text):not(.tabular):not(.borderless) > .container > .right.menu > .item:not(.borderless):last-child {
+ border-right: @dividerSize solid @dividerBackground;
+ }
}
-
/*******************************
States
*******************************/
-/*--------------
+/* --------------
Hover
----------------*/
-
+--------------- */
.ui.link.menu .item:hover,
.ui.menu .dropdown.item:hover,
.ui.menu .link.item:hover,
.ui.menu a.item:hover {
- cursor: pointer;
- background: @hoverItemBackground;
- color: @hoverItemTextColor;
+ cursor: pointer;
+ background: @hoverItemBackground;
+ color: @hoverItemTextColor;
}
-
-/*--------------
+/* --------------
Pressed
----------------*/
+--------------- */
.ui.link.menu .item:active,
.ui.menu .link.item:active,
.ui.menu a.item:active {
- background: @pressedItemBackground;
- color: @pressedItemTextColor;
+ background: @pressedItemBackground;
+ color: @pressedItemTextColor;
}
-
-/*--------------
+/* --------------
Active
----------------*/
+--------------- */
-.ui.menu .active.item {
- background: @activeItemBackground;
- color: @activeItemTextColor;
- font-weight: @activeItemFontWeight;
- box-shadow: @activeItemBoxShadow;
+.ui.menu .active.item {
+ background: @activeItemBackground;
+ color: @activeItemTextColor;
+ font-weight: @activeItemFontWeight;
+ box-shadow: @activeItemBoxShadow;
}
.ui.menu .active.item > i.icon {
- opacity: @activeIconOpacity;
+ opacity: @activeIconOpacity;
}
-/*--------------
+/* --------------
Active Hover
----------------*/
+--------------- */
.ui.menu .active.item:hover,
.ui.vertical.menu .active.item:hover {
- background-color: @activeHoverItemBackground;
- color: @activeHoverItemColor;
+ background-color: @activeHoverItemBackground;
+ color: @activeHoverItemColor;
}
-
-/*--------------
+/* --------------
Disabled
----------------*/
+--------------- */
.ui.ui.menu .item.disabled {
- cursor: default;
- background-color: transparent;
- color: @disabledTextColor;
- pointer-events: none;
+ cursor: default;
+ background-color: transparent;
+ color: @disabledTextColor;
+ pointer-events: none;
}
-
/*******************************
Types
*******************************/
-/*------------------
+/* ------------------
Floated Menu / Item
--------------------*/
+------------------- */
/* Left Floated */
.ui.menu:not(.vertical) .left.item,
.ui.menu:not(.vertical) .left.menu {
- display: flex;
- margin-right: auto !important;
+ display: flex;
+ margin-right: auto !important;
}
+
/* Right Floated */
.ui.menu:not(.vertical) .right.item,
.ui.menu:not(.vertical) .right.menu {
- display: flex;
- margin-left: auto !important;
+ display: flex;
+ margin-left: auto !important;
}
.ui.menu:not(.vertical) :not(.dropdown) > .left.menu,
.ui.menu:not(.vertical) :not(.dropdown) > .right.menu {
- display: inherit;
+ display: inherit;
}
/* Center */
.ui.menu:not(.vertical) .center.item,
.ui.menu:not(.vertical) .center.menu {
- display: flex;
- margin-left: auto !important;
- margin-right: auto !important;
+ display: flex;
+ margin-left: auto !important;
+ margin-right: auto !important;
}
/* Swapped Borders */
.ui.menu .right.item::before,
.ui.menu .right.menu > .item::before {
- right: auto;
- left: 0;
+ right: auto;
+ left: 0;
}
/* Remove Outer Borders */
.ui.menu .center.item:last-child::before,
.ui.menu .center.menu > .item:last-child::before {
- display: none;
+ display: none;
}
& when (@variationMenuVertical) {
- /*--------------
- Vertical
- ---------------*/
+ /* --------------
+ Vertical
+ --------------- */
- .ui.vertical.menu {
- display: block;
- flex-direction: column;
- background: @verticalBackground;
- box-shadow: @verticalBoxShadow;
- }
+ .ui.vertical.menu {
+ display: block;
+ flex-direction: column;
+ background: @verticalBackground;
+ box-shadow: @verticalBoxShadow;
+ }
- /*--- Item ---*/
- .ui.vertical.menu .item {
- display: block;
- background: @verticalItemBackground;
- border-top: none;
- border-right: none;
- }
- .ui.vertical.menu > .item:first-child {
- border-radius: @borderRadius @borderRadius 0 0;
- }
- .ui.vertical.menu > .item:last-child {
- border-radius: 0 0 @borderRadius @borderRadius;
- }
-
- /*--- Label ---*/
- .ui.vertical.menu .item > .label {
- float: right;
- text-align: center;
- }
-
- /*--- Icon ---*/
- .ui.vertical.menu .item > i.icon,
- .ui.vertical.menu .item > i.icons {
- width: @iconWidth;
- float: @verticalIconFloat;
- margin: @verticalIconMargin;
- }
- .ui.vertical.menu .item > .label + i.icon {
- float: @labelAndIconFloat;
- margin: @labelAndIconMargin;
- }
-
-
- /*--- Border ---*/
- .ui.vertical.menu .item::before {
- position: absolute;
- content: '';
- top: 0;
- left: 0;
- width: 100%;
- height: @dividerSize;
- background: @verticalDividerBackground;
- }
-
- .ui.vertical.menu .item:first-child::before {
- display: none !important;
- }
-
-
- /*--- Sub Menu ---*/
- .ui.vertical.menu .item > .menu {
- margin: @subMenuMargin;
- }
- .ui.vertical.menu .menu .item {
- background: none;
- padding: @subMenuVerticalPadding @subMenuHorizontalPadding;
- font-size: @subMenuFontSize;
- color: @subMenuTextColor;
- }
- .ui.vertical.menu .item .menu a.item:hover,
- .ui.vertical.menu .item .menu .link.item:hover {
- color: @darkTextColor;
- }
- .ui.vertical.menu .menu .item::before {
- display: none;
- }
+ /* --- Item --- */
+ .ui.vertical.menu .item {
+ display: block;
+ background: @verticalItemBackground;
+ border-top: none;
+ border-right: none;
+ }
+ .ui.vertical.menu > .item:first-child {
+ border-radius: @borderRadius @borderRadius 0 0;
+ }
+ .ui.vertical.menu > .item:last-child {
+ border-radius: 0 0 @borderRadius @borderRadius;
+ }
- /* Vertical Active */
- .ui.vertical.menu .active.item {
- background: @activeItemBackground;
- border-radius: 0;
- box-shadow: @verticalActiveBoxShadow;
- }
- .ui.vertical.menu > .active.item:first-child {
- border-radius: @borderRadius @borderRadius 0 0;
- }
- .ui.vertical.menu > .active.item:last-child {
- border-radius: 0 0 @borderRadius @borderRadius;
- }
- .ui.vertical.menu > .active.item:only-child {
- border-radius: @borderRadius;
- }
- .ui.vertical.menu .active.item .menu .active.item {
- border-left: none;
- }
- .ui.vertical.menu .item .menu .active.item {
- background-color: @subMenuActiveBackground;
- font-weight: @subMenuActiveFontWeight;
- color: @subMenuActiveTextColor;
- }
-}
+ /* --- Label --- */
+ .ui.vertical.menu .item > .label {
+ float: right;
+ text-align: center;
+ }
-& when (@variationMenuTabular) {
- /*--------------
- Tabular
- ---------------*/
-
- .ui.tabular.menu {
- border-radius: 0;
- box-shadow: none !important;
- border: none;
- background: @tabularBackground;
- border-bottom: @tabularBorderWidth solid @tabularBorderColor;
- }
- .ui.tabular.fluid.menu {
- width: @tabularFluidWidth !important;
- }
- .ui.tabular.menu .item {
- background: transparent;
- border-bottom: none;
-
- border-left: @tabularBorderWidth solid transparent;
- border-right: @tabularBorderWidth solid transparent;
- border-top: @tabularOppositeBorderWidth solid transparent;
- padding: @tabularVerticalPadding @tabularHorizontalPadding;
- color: @tabularTextColor;
- }
- .ui.tabular.menu .item::before {
- display: none;
- }
+ /* --- Icon --- */
+ .ui.vertical.menu .item > i.icon,
+ .ui.vertical.menu .item > i.icons {
+ width: @iconWidth;
+ float: @verticalIconFloat;
+ margin: @verticalIconMargin;
+ }
+ .ui.vertical.menu .item > .label + i.icon {
+ float: @labelAndIconFloat;
+ margin: @labelAndIconMargin;
+ }
- /* Hover */
- .ui.tabular.menu .item:hover {
- background-color: transparent;
- color: @tabularHoveredTextColor;
- }
-
- /* Active */
- .ui.tabular.menu .active.item {
- background: @tabularActiveBackground;
- color: @tabularActiveColor;
- border-top-width: @tabularBorderWidth;
- border-color: @tabularBorderColor;
- font-weight: @tabularActiveWeight;
- margin-bottom: -@tabularBorderWidth;
- box-shadow: @tabularActiveBoxShadow;
- border-radius: @tabularBorderRadius @tabularBorderRadius 0 0 !important;
- &:hover {
- cursor: default;
- }
- }
-
- /* Coupling with segment for attachment */
- .ui.tabular.menu ~ .attached:not(.top).segment {
- border-top: none;
- margin-left: 0;
- margin-top: 0;
- margin-right: 0;
- width: 100%;
- }
- .top.attached.segment + .ui.bottom.tabular.menu {
- position: relative;
- width: @tabularFluidWidth;
- left: -@tabularFluidOffset;
- }
-
- /* Bottom Vertical Tabular */
- .ui.bottom.tabular.menu {
- background: @tabularBackground;
- border-radius: 0;
- box-shadow: none !important;
- border-bottom: none;
- border-top: @tabularBorderWidth solid @tabularBorderColor;
- }
- .ui.bottom.tabular.menu .item {
- background: none;
- border-left: @tabularBorderWidth solid transparent;
- border-right: @tabularBorderWidth solid transparent;
- border-bottom: @tabularBorderWidth solid transparent;
- border-top: none;
- }
- .ui.bottom.tabular.menu .active.item {
- background: @tabularActiveBackground;
- color: @tabularActiveColor;
- border-color: @tabularBorderColor;
- margin: -@tabularBorderWidth 0 0 0;
- border-radius: 0 0 @tabularBorderRadius @tabularBorderRadius !important;
- }
- & when (@variationMenuVertical) {
- /* Vertical Tabular (Left) */
- .ui.vertical.tabular.menu {
- background: @tabularVerticalBackground;
- border-radius: 0;
- box-shadow: none !important;
- border-bottom: none;
- border-right: @tabularBorderWidth solid @tabularBorderColor;
- }
- .ui.vertical.tabular.menu .item {
- background: none;
- border-left: @tabularBorderWidth solid transparent;
- border-bottom: @tabularBorderWidth solid transparent;
- border-top: @tabularBorderWidth solid transparent;
- border-right: none;
- }
- .ui.vertical.tabular.menu .active.item {
- background: @tabularActiveBackground;
- color: @tabularActiveColor;
- border-color: @tabularBorderColor;
- margin: 0 -@tabularBorderWidth 0 0;
- border-radius: @tabularBorderRadius 0 0 @tabularBorderRadius !important;
- }
-
- /* Vertical Right Tabular */
- .ui.vertical.right.tabular.menu {
- background: @tabularVerticalBackground;
- border-radius: 0;
- box-shadow: none !important;
- border-bottom: none;
- border-right: none;
- border-left: @tabularBorderWidth solid @tabularBorderColor;
- }
- .ui.vertical.right.tabular.menu .item {
- background: none;
- border-right: @tabularBorderWidth solid transparent;
- border-bottom: @tabularBorderWidth solid transparent;
- border-top: @tabularBorderWidth solid transparent;
- border-left: none;
- }
- .ui.vertical.right.tabular.menu .active.item {
- background: @tabularActiveBackground;
- color: @tabularActiveColor;
- border-color: @tabularBorderColor;
- margin: 0 0 0 -@tabularBorderWidth;
- border-radius: 0 @tabularBorderRadius @tabularBorderRadius 0 !important;
- }
- }
- /* Dropdown */
- .ui.tabular.menu .active.dropdown.item {
- margin-bottom: 0;
- border-left: @tabularBorderWidth solid transparent;
- border-right: @tabularBorderWidth solid transparent;
- border-top: @tabularOppositeBorderWidth solid transparent;
- border-bottom: none;
- }
- & when (@variationMenuInverted) {
- .ui.inverted.tabular.menu .active.item,
- .ui.inverted.tabular.menu .active.item:hover {
- background: @invertedTabularActiveBackground;
- border-color: @invertedTabularBorderColor;
+ /* --- Border --- */
+ .ui.vertical.menu .item::before {
+ position: absolute;
+ content: "";
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: @dividerSize;
+ background: @verticalDividerBackground;
}
- .ui.inverted.tabular.menu .item:not(.active):hover {
- color: @invertedTabularHoveredTextColor;
- background: transparent;
- cursor: pointer;
+
+ .ui.vertical.menu .item:first-child::before {
+ display: none !important;
+ }
+
+ /* --- Sub Menu --- */
+ .ui.vertical.menu .item > .menu {
+ margin: @subMenuMargin;
+ }
+ .ui.vertical.menu .menu .item {
+ background: none;
+ padding: @subMenuVerticalPadding @subMenuHorizontalPadding;
+ font-size: @subMenuFontSize;
+ color: @subMenuTextColor;
+ }
+ .ui.vertical.menu .item .menu a.item:hover,
+ .ui.vertical.menu .item .menu .link.item:hover {
+ color: @darkTextColor;
+ }
+ .ui.vertical.menu .menu .item::before {
+ display: none;
+ }
+
+ /* Vertical Active */
+ .ui.vertical.menu .active.item {
+ background: @activeItemBackground;
+ border-radius: 0;
+ box-shadow: @verticalActiveBoxShadow;
+ }
+ .ui.vertical.menu > .active.item:first-child {
+ border-radius: @borderRadius @borderRadius 0 0;
+ }
+ .ui.vertical.menu > .active.item:last-child {
+ border-radius: 0 0 @borderRadius @borderRadius;
+ }
+ .ui.vertical.menu > .active.item:only-child {
+ border-radius: @borderRadius;
+ }
+ .ui.vertical.menu .active.item .menu .active.item {
+ border-left: none;
+ }
+ .ui.vertical.menu .item .menu .active.item {
+ background-color: @subMenuActiveBackground;
+ font-weight: @subMenuActiveFontWeight;
+ color: @subMenuActiveTextColor;
}
- }
}
+& when (@variationMenuTabular) {
+ /* --------------
+ Tabular
+ --------------- */
+
+ .ui.tabular.menu {
+ border-radius: 0;
+ box-shadow: none !important;
+ border: none;
+ background: @tabularBackground;
+ border-bottom: @tabularBorderWidth solid @tabularBorderColor;
+ }
+ .ui.tabular.fluid.menu {
+ width: @tabularFluidWidth !important;
+ }
+ .ui.tabular.menu .item {
+ background: transparent;
+ border-bottom: none;
+ border-left: @tabularBorderWidth solid transparent;
+ border-right: @tabularBorderWidth solid transparent;
+ border-top: @tabularOppositeBorderWidth solid transparent;
+ padding: @tabularVerticalPadding @tabularHorizontalPadding;
+ color: @tabularTextColor;
+ }
+ .ui.tabular.menu .item::before {
+ display: none;
+ }
-& when (@variationMenuPagination) {
- /*--------------
- Pagination
- ---------------*/
+ /* Hover */
+ .ui.tabular.menu .item:hover {
+ background-color: transparent;
+ color: @tabularHoveredTextColor;
+ }
- .ui.pagination.menu {
- margin: 0;
- display: inline-flex;
- vertical-align: middle;
- }
- .ui.pagination.menu .item:last-child {
- border-radius: 0 @borderRadius @borderRadius 0;
- }
- .ui.compact.menu .item:last-child {
- border-radius: 0 @borderRadius @borderRadius 0;
- }
- .ui.pagination.menu .item:last-child::before {
- display: none;
- }
+ /* Active */
+ .ui.tabular.menu .active.item {
+ background: @tabularActiveBackground;
+ color: @tabularActiveColor;
+ border-top-width: @tabularBorderWidth;
+ border-color: @tabularBorderColor;
+ font-weight: @tabularActiveWeight;
+ margin-bottom: -@tabularBorderWidth;
+ box-shadow: @tabularActiveBoxShadow;
+ border-radius: @tabularBorderRadius @tabularBorderRadius 0 0 !important;
+ &:hover {
+ cursor: default;
+ }
+ }
- .ui.pagination.menu .item {
- min-width: @paginationMinWidth;
- text-align: center;
- }
- .ui.pagination.menu .icon.item i.icon {
- vertical-align: top;
- }
+ /* Coupling with segment for attachment */
+ .ui.tabular.menu ~ .attached:not(.top).segment {
+ border-top: none;
+ margin-left: 0;
+ margin-top: 0;
+ margin-right: 0;
+ width: 100%;
+ }
+ .top.attached.segment + .ui.bottom.tabular.menu {
+ position: relative;
+ width: @tabularFluidWidth;
+ left: -@tabularFluidOffset;
+ }
- /* Active */
- .ui.pagination.menu .active.item {
- border-top: none;
- padding-top: @itemVerticalPadding;
- background-color: @paginationActiveBackground;
- color: @paginationActiveTextColor;
- box-shadow: none;
- }
-}
+ /* Bottom Vertical Tabular */
+ .ui.bottom.tabular.menu {
+ background: @tabularBackground;
+ border-radius: 0;
+ box-shadow: none !important;
+ border-bottom: none;
+ border-top: @tabularBorderWidth solid @tabularBorderColor;
+ }
+ .ui.bottom.tabular.menu .item {
+ background: none;
+ border-left: @tabularBorderWidth solid transparent;
+ border-right: @tabularBorderWidth solid transparent;
+ border-bottom: @tabularBorderWidth solid transparent;
+ border-top: none;
+ }
+ .ui.bottom.tabular.menu .active.item {
+ background: @tabularActiveBackground;
+ color: @tabularActiveColor;
+ border-color: @tabularBorderColor;
+ margin: -@tabularBorderWidth 0 0 0;
+ border-radius: 0 0 @tabularBorderRadius @tabularBorderRadius !important;
+ }
+ & when (@variationMenuVertical) {
+ /* Vertical Tabular (Left) */
+ .ui.vertical.tabular.menu {
+ background: @tabularVerticalBackground;
+ border-radius: 0;
+ box-shadow: none !important;
+ border-bottom: none;
+ border-right: @tabularBorderWidth solid @tabularBorderColor;
+ }
+ .ui.vertical.tabular.menu .item {
+ background: none;
+ border-left: @tabularBorderWidth solid transparent;
+ border-bottom: @tabularBorderWidth solid transparent;
+ border-top: @tabularBorderWidth solid transparent;
+ border-right: none;
+ }
+ .ui.vertical.tabular.menu .active.item {
+ background: @tabularActiveBackground;
+ color: @tabularActiveColor;
+ border-color: @tabularBorderColor;
+ margin: 0 -@tabularBorderWidth 0 0;
+ border-radius: @tabularBorderRadius 0 0 @tabularBorderRadius !important;
+ }
-& when (@variationMenuSecondary) {
- /*--------------
- Secondary
- ---------------*/
-
- .ui.secondary.menu {
- background: @secondaryBackground;
- margin-left: -@secondaryItemSpacing;
- margin-right: -@secondaryItemSpacing;
- border-radius: 0;
- border: none;
- box-shadow: none;
- }
-
- /* Item */
- .ui.secondary.menu .item {
- align-self: center;
- box-shadow: none;
- border: none;
- padding: @secondaryItemPadding;
- margin: @secondaryItemMargin;
- background: @secondaryItemBackground;
- transition: @secondaryItemTransition;
- border-radius: @secondaryItemBorderRadius;
- }
-
- /* No Divider */
- .ui.secondary.menu .item::before {
- display: none !important;
- }
-
- /* Header */
- .ui.secondary.menu .header.item {
- border-radius: 0;
- border-right: @secondaryHeaderBorder;
- background: @secondaryHeaderBackground;
- }
-
- /* Image */
- .ui.secondary.menu .item > img:not(.ui) {
- margin: 0;
- }
-
- /* Hover */
- .ui.secondary.menu .dropdown.item:hover,
- .ui.secondary.menu .link.item:hover,
- .ui.secondary.menu a.item:hover {
- background: @secondaryHoverItemBackground;
- color: @secondaryHoverItemColor;
- }
-
- /* Active */
- .ui.secondary.menu .active.item {
- box-shadow: none;
- background: @secondaryActiveItemBackground;
- color: @secondaryActiveItemColor;
- border-radius: @secondaryItemBorderRadius;
- }
-
- /* Active Hover */
- .ui.secondary.menu .active.item:hover {
- box-shadow: none;
- background: @secondaryActiveHoverItemBackground;
- color: @secondaryActiveHoverItemColor;
- }
-
- & when (@variationMenuInverted) {
- /* Inverted */
- .ui.secondary.inverted.menu .link.item:not(.disabled),
- .ui.secondary.inverted.menu a.item:not(.disabled) {
- color: @secondaryInvertedColor;
- }
- .ui.secondary.inverted.menu .dropdown.item:hover,
- .ui.secondary.inverted.menu .link.item:hover,
- .ui.secondary.inverted.menu a.item:hover {
- background: @secondaryInvertedHoverBackground;
- color: @secondaryInvertedHoverColor;
- }
- .ui.secondary.inverted.menu .active.item {
- background: @secondaryInvertedActiveBackground;
- color: @secondaryInvertedActiveColor;
- }
- }
- /* Fix item margins */
- .ui.secondary.item.menu {
- margin-left: 0;
- margin-right: 0;
- }
- .ui.secondary.item.menu .item:last-child {
- margin-right: 0;
- }
- & when (@variationMenuAttached) {
- .ui.secondary.attached.menu {
- box-shadow: none;
- }
- }
- & when (@variationMenuVertical) {
- /*---------------------
- Secondary Vertical
- -----------------------*/
-
- /* Sub Menu */
- .ui.vertical.secondary.menu .item:not(.dropdown) > .menu {
- margin: @secondaryMenuSubMenuMargin;
- }
- .ui.vertical.secondary.menu .item:not(.dropdown) > .menu > .item {
- margin: @secondaryMenuSubMenuItemMargin;
- padding: @secondaryMenuSubMenuItemPadding;
- }
-
-
- .ui.secondary.vertical.menu > .item {
- border: none;
- margin: @secondaryVerticalItemMargin;
- border-radius: @secondaryVerticalItemBorderRadius !important;
- }
- .ui.secondary.vertical.menu > .header.item {
- border-radius: 0;
- }
-
- /* Sub Menu */
- .ui.vertical.secondary.menu .item > .menu .item {
- background-color: transparent;
+ /* Vertical Right Tabular */
+ .ui.vertical.right.tabular.menu {
+ background: @tabularVerticalBackground;
+ border-radius: 0;
+ box-shadow: none !important;
+ border-bottom: none;
+ border-right: none;
+ border-left: @tabularBorderWidth solid @tabularBorderColor;
+ }
+ .ui.vertical.right.tabular.menu .item {
+ background: none;
+ border-right: @tabularBorderWidth solid transparent;
+ border-bottom: @tabularBorderWidth solid transparent;
+ border-top: @tabularBorderWidth solid transparent;
+ border-left: none;
+ }
+ .ui.vertical.right.tabular.menu .active.item {
+ background: @tabularActiveBackground;
+ color: @tabularActiveColor;
+ border-color: @tabularBorderColor;
+ margin: 0 0 0 -@tabularBorderWidth;
+ border-radius: 0 @tabularBorderRadius @tabularBorderRadius 0 !important;
+ }
+ }
+
+ /* Dropdown */
+ .ui.tabular.menu .active.dropdown.item {
+ margin-bottom: 0;
+ border-left: @tabularBorderWidth solid transparent;
+ border-right: @tabularBorderWidth solid transparent;
+ border-top: @tabularOppositeBorderWidth solid transparent;
+ border-bottom: none;
}
& when (@variationMenuInverted) {
- /* Inverted */
- .ui.secondary.inverted.menu {
- background-color: transparent;
- }
+ .ui.inverted.tabular.menu .active.item,
+ .ui.inverted.tabular.menu .active.item:hover {
+ background: @invertedTabularActiveBackground;
+ border-color: @invertedTabularBorderColor;
+ }
+ .ui.inverted.tabular.menu .item:not(.active):hover {
+ color: @invertedTabularHoveredTextColor;
+ background: transparent;
+ cursor: pointer;
+ }
}
- }
+}
- & when (@variationMenuPointing) {
- /*---------------------
- Secondary Pointing
- -----------------------*/
+& when (@variationMenuPagination) {
+ /* --------------
+ Pagination
+ --------------- */
- .ui.secondary.pointing.menu {
- margin-left: 0;
- margin-right: 0;
- border-bottom: @secondaryPointingBorderWidth solid @secondaryPointingBorderColor;
+ .ui.pagination.menu {
+ margin: 0;
+ display: inline-flex;
+ vertical-align: middle;
+ }
+ .ui.pagination.menu .item:last-child {
+ border-radius: 0 @borderRadius @borderRadius 0;
+ }
+ .ui.compact.menu .item:last-child {
+ border-radius: 0 @borderRadius @borderRadius 0;
+ }
+ .ui.pagination.menu .item:last-child::before {
+ display: none;
}
- .ui.secondary.pointing.menu .item {
- border-bottom-color: transparent;
- border-bottom-style: solid;
- border-radius: 0;
- align-self: flex-end;
-
- margin: 0 0 -@secondaryPointingBorderWidth;
- padding: @secondaryPointingItemVerticalPadding @secondaryPointingItemHorizontalPadding;
- border-bottom-width: @secondaryPointingBorderWidth;
- transition: @secondaryItemTransition;
+ .ui.pagination.menu .item {
+ min-width: @paginationMinWidth;
+ text-align: center;
}
- .ui.secondary.pointing.menu .ui.dropdown .menu .item {
- border-bottom-width: 0;
+ .ui.pagination.menu .icon.item i.icon {
+ vertical-align: top;
}
- .ui.secondary.pointing.menu .item > .label:not(.floating) {
- margin-top: -@labelVerticalPadding;
- margin-bottom: -@labelVerticalPadding;
+ /* Active */
+ .ui.pagination.menu .active.item {
+ border-top: none;
+ padding-top: @itemVerticalPadding;
+ background-color: @paginationActiveBackground;
+ color: @paginationActiveTextColor;
+ box-shadow: none;
}
- .ui.secondary.pointing.menu .item > .circular.label {
- margin-top: -@circularLabelVerticalPadding;
- margin-bottom: -@circularLabelVerticalPadding;
+}
+
+& when (@variationMenuSecondary) {
+ /* --------------
+ Secondary
+ --------------- */
+
+ .ui.secondary.menu {
+ background: @secondaryBackground;
+ margin-left: -@secondaryItemSpacing;
+ margin-right: -@secondaryItemSpacing;
+ border-radius: 0;
+ border: none;
+ box-shadow: none;
}
- /* Item Types */
- .ui.secondary.pointing.menu .header.item {
- color: @secondaryPointingHeaderColor !important;
+ /* Item */
+ .ui.secondary.menu .item {
+ align-self: center;
+ box-shadow: none;
+ border: none;
+ padding: @secondaryItemPadding;
+ margin: @secondaryItemMargin;
+ background: @secondaryItemBackground;
+ transition: @secondaryItemTransition;
+ border-radius: @secondaryItemBorderRadius;
}
- .ui.secondary.pointing.menu .text.item {
- box-shadow: none !important;
+
+ /* No Divider */
+ .ui.secondary.menu .item::before {
+ display: none !important;
}
- .ui.secondary.pointing.menu .item::after {
- display: none;
+
+ /* Header */
+ .ui.secondary.menu .header.item {
+ border-radius: 0;
+ border-right: @secondaryHeaderBorder;
+ background: @secondaryHeaderBackground;
}
- /* Hover */
- .ui.secondary.pointing.menu .dropdown.item:hover,
- .ui.secondary.pointing.menu .link.item:hover,
- .ui.secondary.pointing.menu a.item:hover {
- background-color: transparent;
- color: @secondaryPointingHoverTextColor;
+ /* Image */
+ .ui.secondary.menu .item > img:not(.ui) {
+ margin: 0;
}
- /* Pressed */
- .ui.secondary.pointing.menu .dropdown.item:active,
- .ui.secondary.pointing.menu .link.item:active,
- .ui.secondary.pointing.menu a.item:active {
- background-color: transparent;
- border-color: @secondaryPointingBorderColor;
+ /* Hover */
+ .ui.secondary.menu .dropdown.item:hover,
+ .ui.secondary.menu .link.item:hover,
+ .ui.secondary.menu a.item:hover {
+ background: @secondaryHoverItemBackground;
+ color: @secondaryHoverItemColor;
}
/* Active */
- .ui.secondary.pointing.menu .active.item {
- background-color: transparent;
- box-shadow: none;
- border-color: @secondaryPointingActiveBorderColor;
- font-weight: @secondaryPointingActiveFontWeight;
- color: @secondaryPointingActiveTextColor;
+ .ui.secondary.menu .active.item {
+ box-shadow: none;
+ background: @secondaryActiveItemBackground;
+ color: @secondaryActiveItemColor;
+ border-radius: @secondaryItemBorderRadius;
}
/* Active Hover */
- .ui.secondary.pointing.menu .active.item:hover {
- border-color: @secondaryPointingActiveHoverBorderColor;
- color: @secondaryPointingActiveHoverTextColor;
+ .ui.secondary.menu .active.item:hover {
+ box-shadow: none;
+ background: @secondaryActiveHoverItemBackground;
+ color: @secondaryActiveHoverItemColor;
}
- /* Active Dropdown */
- .ui.secondary.pointing.menu .active.dropdown.item {
- border-color: @secondaryPointingActiveDropdownBorderColor;
+ & when (@variationMenuInverted) {
+ /* Inverted */
+ .ui.secondary.inverted.menu .link.item:not(.disabled),
+ .ui.secondary.inverted.menu a.item:not(.disabled) {
+ color: @secondaryInvertedColor;
+ }
+ .ui.secondary.inverted.menu .dropdown.item:hover,
+ .ui.secondary.inverted.menu .link.item:hover,
+ .ui.secondary.inverted.menu a.item:hover {
+ background: @secondaryInvertedHoverBackground;
+ color: @secondaryInvertedHoverColor;
+ }
+ .ui.secondary.inverted.menu .active.item {
+ background: @secondaryInvertedActiveBackground;
+ color: @secondaryInvertedActiveColor;
+ }
+ }
+
+ /* Fix item margins */
+ .ui.secondary.item.menu {
+ margin-left: 0;
+ margin-right: 0;
+ }
+ .ui.secondary.item.menu .item:last-child {
+ margin-right: 0;
+ }
+ & when (@variationMenuAttached) {
+ .ui.secondary.attached.menu {
+ box-shadow: none;
+ }
}
& when (@variationMenuVertical) {
- /* Vertical Pointing */
- .ui.secondary.vertical.pointing.menu {
- border-bottom-width: 0;
- border-right-width: @secondaryPointingBorderWidth;
- border-right-style: solid;
- border-right-color: @secondaryPointingBorderColor;
- }
- .ui.secondary.vertical.pointing.menu .item {
- border-bottom: none;
- border-right-style: solid;
- border-right-color: transparent;
- border-radius: 0 !important;
- margin: @secondaryVerticalPointingItemMargin;
- border-right-width: @secondaryPointingBorderWidth;
- }
+ /* ---------------------
+ Secondary Vertical
+ ----------------------- */
+
+ /* Sub Menu */
+ .ui.vertical.secondary.menu .item:not(.dropdown) > .menu {
+ margin: @secondaryMenuSubMenuMargin;
+ }
+ .ui.vertical.secondary.menu .item:not(.dropdown) > .menu > .item {
+ margin: @secondaryMenuSubMenuItemMargin;
+ padding: @secondaryMenuSubMenuItemPadding;
+ }
+
+ .ui.secondary.vertical.menu > .item {
+ border: none;
+ margin: @secondaryVerticalItemMargin;
+ border-radius: @secondaryVerticalItemBorderRadius !important;
+ }
+ .ui.secondary.vertical.menu > .header.item {
+ border-radius: 0;
+ }
- /* Vertical Active */
- .ui.secondary.vertical.pointing.menu .active.item {
- border-color: @secondaryPointingActiveBorderColor;
- }
+ /* Sub Menu */
+ .ui.vertical.secondary.menu .item > .menu .item {
+ background-color: transparent;
+ }
+ & when (@variationMenuInverted) {
+ /* Inverted */
+ .ui.secondary.inverted.menu {
+ background-color: transparent;
+ }
+ }
}
- & when (@variationMenuInverted) {
- /* Inverted */
- .ui.secondary.inverted.pointing.menu {
- border-color: @secondaryPointingInvertedBorderColor;
- }
-
- .ui.secondary.inverted.pointing.menu .item:not(.disabled) {
- color: @secondaryPointingInvertedItemTextColor;
- }
- .ui.secondary.inverted.pointing.menu .header.item {
- color: @secondaryPointingInvertedItemHeaderColor !important;
- }
-
- /* Hover */
- .ui.secondary.inverted.pointing.menu .link.item:hover,
- .ui.secondary.inverted.pointing.menu a.item:hover {
- color: @secondaryPointingInvertedItemHoverTextColor;
- }
-
-
- /* Active */
- .ui.ui.secondary.inverted.pointing.menu .active.item {
- border-color: @secondaryPointingInvertedActiveBorderColor;
- color: @secondaryPointingInvertedActiveColor;
- background-color: transparent;
- }
+
+ & when (@variationMenuPointing) {
+ /* ---------------------
+ Secondary Pointing
+ ----------------------- */
+
+ .ui.secondary.pointing.menu {
+ margin-left: 0;
+ margin-right: 0;
+ border-bottom: @secondaryPointingBorderWidth solid @secondaryPointingBorderColor;
+ }
+
+ .ui.secondary.pointing.menu .item {
+ border-bottom: @secondaryPointingBorderWidth solid transparent;
+ border-radius: 0;
+ align-self: flex-end;
+ margin: 0 0 -@secondaryPointingBorderWidth;
+ padding: @secondaryPointingItemVerticalPadding @secondaryPointingItemHorizontalPadding;
+ transition: @secondaryItemTransition;
+ }
+ .ui.secondary.pointing.menu .ui.dropdown .menu .item {
+ border-bottom-width: 0;
+ }
+
+ .ui.secondary.pointing.menu .item > .label:not(.floating) {
+ margin-top: -@labelVerticalPadding;
+ margin-bottom: -@labelVerticalPadding;
+ }
+ .ui.secondary.pointing.menu .item > .circular.label {
+ margin-top: -@circularLabelVerticalPadding;
+ margin-bottom: -@circularLabelVerticalPadding;
+ }
+
+ /* Item Types */
+ .ui.secondary.pointing.menu .header.item {
+ color: @secondaryPointingHeaderColor !important;
+ }
+ .ui.secondary.pointing.menu .text.item {
+ box-shadow: none !important;
+ }
+ .ui.secondary.pointing.menu .item::after {
+ display: none;
+ }
+
+ /* Hover */
+ .ui.secondary.pointing.menu .dropdown.item:hover,
+ .ui.secondary.pointing.menu .link.item:hover,
+ .ui.secondary.pointing.menu a.item:hover {
+ background-color: transparent;
+ color: @secondaryPointingHoverTextColor;
+ }
+
+ /* Pressed */
+ .ui.secondary.pointing.menu .dropdown.item:active,
+ .ui.secondary.pointing.menu .link.item:active,
+ .ui.secondary.pointing.menu a.item:active {
+ background-color: transparent;
+ border-color: @secondaryPointingBorderColor;
+ }
+
+ /* Active */
+ .ui.secondary.pointing.menu .active.item {
+ background-color: transparent;
+ box-shadow: none;
+ border-color: @secondaryPointingActiveBorderColor;
+ font-weight: @secondaryPointingActiveFontWeight;
+ color: @secondaryPointingActiveTextColor;
+ }
+
+ /* Active Hover */
+ .ui.secondary.pointing.menu .active.item:hover {
+ border-color: @secondaryPointingActiveHoverBorderColor;
+ color: @secondaryPointingActiveHoverTextColor;
+ }
+
+ /* Active Dropdown */
+ .ui.secondary.pointing.menu .active.dropdown.item {
+ border-color: @secondaryPointingActiveDropdownBorderColor;
+ }
+ & when (@variationMenuVertical) {
+ /* Vertical Pointing */
+ .ui.secondary.vertical.pointing.menu {
+ border-bottom-width: 0;
+ border-right: @secondaryPointingBorderWidth solid @secondaryPointingBorderColor;
+ }
+ .ui.secondary.vertical.pointing.menu .item {
+ border-bottom: none;
+ border-right: @secondaryPointingBorderWidth solid transparent;
+ border-radius: 0 !important;
+ margin: @secondaryVerticalPointingItemMargin;
+ }
+
+ /* Vertical Active */
+ .ui.secondary.vertical.pointing.menu .active.item {
+ border-color: @secondaryPointingActiveBorderColor;
+ }
+ }
+ & when (@variationMenuInverted) {
+ /* Inverted */
+ .ui.secondary.inverted.pointing.menu {
+ border-color: @secondaryPointingInvertedBorderColor;
+ }
+
+ .ui.secondary.inverted.pointing.menu .item:not(.disabled) {
+ color: @secondaryPointingInvertedItemTextColor;
+ }
+ .ui.secondary.inverted.pointing.menu .header.item {
+ color: @secondaryPointingInvertedItemHeaderColor !important;
+ }
+
+ /* Hover */
+ .ui.secondary.inverted.pointing.menu .link.item:hover,
+ .ui.secondary.inverted.pointing.menu a.item:hover {
+ color: @secondaryPointingInvertedItemHoverTextColor;
+ }
+
+ /* Active */
+ .ui.ui.secondary.inverted.pointing.menu .active.item {
+ border-color: @secondaryPointingInvertedActiveBorderColor;
+ color: @secondaryPointingInvertedActiveColor;
+ background-color: transparent;
+ }
+ }
}
- }
}
& when (@variationMenuText) {
- /*--------------
- Text Menu
- ---------------*/
-
- .ui.text.menu {
- background: none transparent;
- border-radius: 0;
- box-shadow: none;
- border: none;
-
- margin: @textMenuMargin;
- }
- .ui.text.menu .item {
- border-radius: 0;
- box-shadow: none;
- align-self: center;
- margin: @textMenuItemMargin;
- padding: @textMenuItemPadding;
- font-weight: @textMenuItemFontWeight;
- color: @textMenuItemColor;
- transition: @textMenuItemTransition;
- }
-
- /* Border */
- .ui.text.menu .item::before,
- .ui.text.menu .menu .item::before {
- display: none !important;
- }
-
- /* Header */
- .ui.text.menu .header.item {
- background-color: transparent;
- opacity: 1;
- color: @textMenuHeaderColor;
- font-size: @textMenuHeaderSize;
- text-transform: @textMenuHeaderTextTransform;
- font-weight: @textMenuHeaderFontWeight;
- }
-
- /* Image */
- .ui.text.menu .item > img:not(.ui) {
- margin: 0;
- }
-
- /*--- fluid text ---*/
- .ui.text.item.menu .item {
- margin: 0;
- }
- & when (@variationMenuVertical) {
- /*--- vertical text ---*/
- .ui.vertical.text.menu {
- margin: @textVerticalMenuMargin;
+ /* --------------
+ Text Menu
+ --------------- */
+
+ .ui.text.menu {
+ background: none transparent;
+ border-radius: 0;
+ box-shadow: none;
+ border: none;
+ margin: @textMenuMargin;
+ }
+ .ui.text.menu .item {
+ border-radius: 0;
+ box-shadow: none;
+ align-self: center;
+ margin: @textMenuItemMargin;
+ padding: @textMenuItemPadding;
+ font-weight: @textMenuItemFontWeight;
+ color: @textMenuItemColor;
+ transition: @textMenuItemTransition;
+ }
+
+ /* Border */
+ .ui.text.menu .item::before,
+ .ui.text.menu .menu .item::before {
+ display: none !important;
+ }
+
+ /* Header */
+ .ui.text.menu .header.item {
+ background-color: transparent;
+ opacity: 1;
+ color: @textMenuHeaderColor;
+ font-size: @textMenuHeaderSize;
+ text-transform: @textMenuHeaderTextTransform;
+ font-weight: @textMenuHeaderFontWeight;
}
- .ui.vertical.text.menu:first-child {
- margin-top: 0;
+
+ /* Image */
+ .ui.text.menu .item > img:not(.ui) {
+ margin: 0;
}
- .ui.vertical.text.menu:last-child {
- margin-bottom: 0;
+
+ /* --- fluid text --- */
+ .ui.text.item.menu .item {
+ margin: 0;
}
- .ui.vertical.text.menu .item {
- margin: @textVerticalMenuItemMargin;
- padding-left: 0;
- padding-right: 0;
+ & when (@variationMenuVertical) {
+ /* --- vertical text --- */
+ .ui.vertical.text.menu {
+ margin: @textVerticalMenuMargin;
+ }
+ .ui.vertical.text.menu:first-child {
+ margin-top: 0;
+ }
+ .ui.vertical.text.menu:last-child {
+ margin-bottom: 0;
+ }
+ .ui.vertical.text.menu .item {
+ margin: @textVerticalMenuItemMargin;
+ padding-left: 0;
+ padding-right: 0;
+ }
+ .ui.vertical.text.menu .item > i.icon {
+ float: @textVerticalMenuIconFloat;
+ margin: @iconMargin;
+ }
+ .ui.vertical.text.menu .header.item {
+ margin: @textVerticalMenuHeaderMargin;
+ }
+
+ /* Vertical Sub Menu */
+ .ui.vertical.text.menu .item:not(.dropdown) > .menu {
+ margin: @textMenuSubMenuMargin;
+ }
+ .ui.vertical.text.menu .item:not(.dropdown) > .menu > .item {
+ margin: @textMenuSubMenuItemMargin;
+ padding: @textMenuSubMenuItemPadding;
+ }
}
- .ui.vertical.text.menu .item > i.icon {
- float: @textVerticalMenuIconFloat;
- margin: @iconMargin;
+
+ /* --- hover --- */
+ .ui.text.menu .item:hover {
+ opacity: 1;
+ background-color: transparent;
}
- .ui.vertical.text.menu .header.item {
- margin: @textVerticalMenuHeaderMargin;
+
+ /* --- active --- */
+ .ui.text.menu .active.item {
+ background-color: transparent;
+ border: none;
+ box-shadow: none;
+ font-weight: @textMenuActiveItemFontWeight;
+ color: @textMenuActiveItemColor;
}
- /* Vertical Sub Menu */
- .ui.vertical.text.menu .item:not(.dropdown) > .menu {
- margin: @textMenuSubMenuMargin;
+ /* --- active hover --- */
+ .ui.text.menu .active.item:hover {
+ background-color: transparent;
}
- .ui.vertical.text.menu .item:not(.dropdown) > .menu > .item {
- margin: @textMenuSubMenuItemMargin;
- padding: @textMenuSubMenuItemPadding;
+ & when (@variationMenuPointing) {
+ /* Disable Bariations */
+ .ui.text.pointing.menu .active.item::after {
+ box-shadow: none;
+ }
}
- }
- /*--- hover ---*/
- .ui.text.menu .item:hover {
- opacity: 1;
- background-color: transparent;
- }
-
- /*--- active ---*/
- .ui.text.menu .active.item {
- background-color: transparent;
- border: none;
- box-shadow: none;
- font-weight: @textMenuActiveItemFontWeight;
- color: @textMenuActiveItemColor;
- }
-
- /*--- active hover ---*/
- .ui.text.menu .active.item:hover {
- background-color: transparent;
- }
- & when (@variationMenuPointing) {
- /* Disable Bariations */
- .ui.text.pointing.menu .active.item::after {
- box-shadow: none;
- }
- }
- & when (@variationMenuAttached) {
- .ui.text.attached.menu {
- box-shadow: none;
- }
- }
- & when (@variationMenuInverted) {
- /* Inverted */
- .ui.inverted.text.menu,
- .ui.inverted.text.menu .item,
- .ui.inverted.text.menu .item:hover,
- .ui.inverted.text.menu .active.item {
- background-color: transparent;
+ & when (@variationMenuAttached) {
+ .ui.text.attached.menu {
+ box-shadow: none;
+ }
+ }
+ & when (@variationMenuInverted) {
+ /* Inverted */
+ .ui.inverted.text.menu,
+ .ui.inverted.text.menu .item,
+ .ui.inverted.text.menu .item:hover,
+ .ui.inverted.text.menu .active.item {
+ background-color: transparent;
+ }
}
- }
- & when (@variationMenuFluid) {
- /* Fluid */
- .ui.fluid.text.menu {
- margin-left: 0;
- margin-right: 0;
+ & when (@variationMenuFluid) {
+ /* Fluid */
+ .ui.fluid.text.menu {
+ margin-left: 0;
+ margin-right: 0;
+ }
}
- }
}
& when (@variationMenuIcon) {
- /*--------------
- Icon Only
- ---------------*/
-
- & when (@variationMenuVertical) {
- /* Vertical Menu */
- .ui.vertical.icon.menu {
- display: inline-block;
- width: auto;
- }
- }
-
- /* Item */
- .ui.icon.menu .item {
- height: auto;
- text-align: @iconMenuTextAlign;
- color: @iconMenuItemColor;
- }
-
- /* Icon */
- .ui.icon.menu .item > i.icon:not(.dropdown) {
- margin: 0;
- opacity: 1;
- }
+ /* --------------
+ Icon Only
+ --------------- */
- /* Icon Glyph */
- .ui.icon.menu i.icon::before {
- opacity: 1;
- }
+ & when (@variationMenuVertical) {
+ /* Vertical Menu */
+ .ui.vertical.icon.menu {
+ display: inline-block;
+ width: auto;
+ }
+ }
- /* (x) Item Icon */
- .ui.menu .icon.item > i.icon {
- width: auto;
- margin: 0 auto;
- }
+ /* Item */
+ .ui.icon.menu .item {
+ height: auto;
+ text-align: @iconMenuTextAlign;
+ color: @iconMenuItemColor;
+ }
- /* Vertical Icon */
- & when (@variationMenuVertical) {
- .ui.vertical.icon.menu .item > i.icon:not(.dropdown) {
- display: block;
- opacity: 1;
- margin: 0 auto;
- float: none;
+ /* Icon */
+ .ui.icon.menu .item > i.icon:not(.dropdown) {
+ margin: 0;
+ opacity: 1;
}
- }
- /* Inverted */
- & when (@variationMenuInverted) {
- .ui.inverted.icon.menu .item {
- color: @iconMenuInvertedItemColor;
+ /* Icon Glyph */
+ .ui.icon.menu i.icon::before {
+ opacity: 1;
+ }
+
+ /* (x) Item Icon */
+ .ui.menu .icon.item > i.icon {
+ width: auto;
+ margin: 0 auto;
+ }
+
+ /* Vertical Icon */
+ & when (@variationMenuVertical) {
+ .ui.vertical.icon.menu .item > i.icon:not(.dropdown) {
+ display: block;
+ opacity: 1;
+ margin: 0 auto;
+ float: none;
+ }
+ }
+
+ /* Inverted */
+ & when (@variationMenuInverted) {
+ .ui.inverted.icon.menu .item {
+ color: @iconMenuInvertedItemColor;
+ }
}
- }
}
& when (@variationMenuLabeled) {
- /*--------------
- Labeled Icon
- ---------------*/
+ /* --------------
+ Labeled Icon
+ --------------- */
- /* Menu */
- .ui.labeled.icon.menu {
- text-align: center;
- }
+ /* Menu */
+ .ui.labeled.icon.menu {
+ text-align: center;
+ }
- /* Item */
- .ui.labeled.icon.menu .item {
- min-width: @labeledIconMinWidth;
- flex-direction: column;
- }
+ /* Item */
+ .ui.labeled.icon.menu .item {
+ min-width: @labeledIconMinWidth;
+ flex-direction: column;
+ }
- /* Icon */
- .ui.labeled.icon.menu > .item > i.icon:not(.dropdown) {
- height: 1em;
- display: block;
- font-size: @labeledIconSize !important;
- margin: 0 auto @labeledIconTextMargin !important;
- }
- & when (@variationMenuFluid) {
- /* Fluid */
- .ui.fluid.labeled.icon.menu > .item {
- min-width: 0;
+ /* Icon */
+ .ui.labeled.icon.menu > .right.menu > .item > i.icon:not(.dropdown),
+ .ui.labeled.icon.menu > .item > i.icon:not(.dropdown) {
+ height: 1em;
+ display: block;
+ font-size: @labeledIconSize !important;
+ margin: 0 auto @labeledIconTextMargin !important;
+ }
+ & when (@variationMenuFluid) {
+ /* Fluid */
+ .ui.fluid.labeled.icon.menu > .item {
+ min-width: 0;
+ }
}
- }
}
-
/*******************************
Variations
*******************************/
& when (@variationMenuStackable) {
- /*--------------
- Stackable
- ---------------*/
+ /* --------------
+ Stackable
+ --------------- */
- @media only screen and (max-width: @largestMobileScreen) {
- .ui.stackable.menu {
- flex-direction: column;
+ @media only screen and (max-width: @largestMobileScreen) {
+ .ui.stackable.menu {
+ flex-direction: column;
- &.pointing .active.item::after when (@variationMenuPointing) {
- display: none;
- }
+ &.pointing .active.item::after when (@variationMenuPointing) {
+ display: none;
+ }
+ }
+ .ui.stackable.menu .item {
+ width: 100% !important;
+ }
+ .ui.stackable.menu .item::before {
+ position: absolute;
+ content: "";
+ top: auto;
+ bottom: 0;
+ left: 0;
+ width: 100%;
+ height: @dividerSize;
+ background: @verticalDividerBackground;
+ }
+
+ .ui.stackable.menu .left.menu,
+ .ui.stackable.menu .left.item {
+ margin-right: 0 !important;
+ }
+ .ui.stackable.menu .right.menu,
+ .ui.stackable.menu .right.item {
+ margin-left: 0 !important;
+ }
+ .ui.stackable.menu .center.menu,
+ .ui.stackable.menu .center.item {
+ margin-left: 0 !important;
+ margin-right: 0 !important;
+ }
+
+ .ui.stackable.menu .right.menu,
+ .ui.stackable.menu .center.menu,
+ .ui.stackable.menu .left.menu {
+ flex-direction: column;
+ }
+ }
+}
+
+/* --------------
+ Colors
+--------------- */
+& when not (@variationMenuColors = false) {
+ each(@variationMenuColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+
+ & when not (@color=secondary) {
+ .ui.ui.ui.menu .@{color}.active.item,
+ .ui.ui.@{color}.menu .active.item:hover,
+ .ui.ui.@{color}.menu .active.item {
+ & when not (@secondaryPointingActiveBorderColor = currentColor) {
+ border-color: @c;
+ }
+ color: @c;
+ }
+ }
+ });
+}
+
+& when (@variationMenuInverted) {
+ /* --------------
+ Inverted
+ --------------- */
+
+ .ui.inverted.menu {
+ border: @invertedBorder;
+ background: @invertedBackground;
+ box-shadow: @invertedBoxShadow;
+ }
+
+ /* Menu Item */
+ .ui.inverted.menu .item,
+ .ui.inverted.menu .item > a:not(.ui) {
+ background: @invertedItemBackground;
+ color: @invertedItemTextColor;
}
- .ui.stackable.menu .item {
- width: 100% !important;
+ .ui.inverted.menu .item.menu {
+ background: @invertedSubMenuBackground;
}
- .ui.stackable.menu .item::before {
- position: absolute;
- content: '';
- top: auto;
- bottom: 0;
- left: 0;
- width: 100%;
- height: @dividerSize;
- background: @verticalDividerBackground;
+
+ /* --- Border --- */
+ .ui.inverted.menu .item::before {
+ background: @invertedDividerBackground;
}
+ & when (@variationMenuVertical) {
+ .ui.vertical.inverted.menu .item::before {
+ background: @invertedVerticalDividerBackground;
+ }
- .ui.stackable.menu .left.menu,
- .ui.stackable.menu .left.item {
- margin-right: 0 !important;
+ /* Sub Menu */
+ .ui.vertical.inverted.menu .menu .item,
+ .ui.vertical.inverted.menu .menu .item a:not(.ui) {
+ color: @invertedSubMenuColor;
+ }
}
- .ui.stackable.menu .right.menu,
- .ui.stackable.menu .right.item {
- margin-left: 0 !important;
+
+ /* Header */
+ .ui.inverted.menu .header.item {
+ margin: 0;
+ background: @invertedHeaderBackground;
+ box-shadow: none;
}
- .ui.stackable.menu .center.menu,
- .ui.stackable.menu .center.item {
- margin-left: 0 !important;
- margin-right: 0 !important;
+
+ /* Disabled */
+ .ui.ui.inverted.menu .item.disabled {
+ color: @invertedDisabledTextColor;
}
- .ui.stackable.menu .right.menu,
- .ui.stackable.menu .center.menu,
- .ui.stackable.menu .left.menu {
- flex-direction: column;
+ /* --- Hover --- */
+ .ui.link.inverted.menu .item:hover,
+ .ui.inverted.menu .dropdown.item:hover,
+ .ui.inverted.menu .link.item:hover,
+ .ui.inverted.menu a.item:hover {
+ background: @invertedHoverBackground;
+ color: @invertedHoverColor;
+ }
+ & when (@variationMenuVertical) {
+ .ui.vertical.inverted.menu .item .menu a.item:hover,
+ .ui.vertical.inverted.menu .item .menu .link.item:hover {
+ background: @invertedSubMenuBackground;
+ color: @invertedSubMenuHoverColor;
+ }
}
- }
-}
-/*--------------
- Colors
----------------*/
-& when not (@variationMenuColors = false) {
- each(@variationMenuColors, {
- @color: @value;
- @c: @colors[@@color][color];
+ /* --- Pressed --- */
+ .ui.inverted.menu a.item:active,
+ .ui.inverted.menu .link.item:active {
+ background: @invertedMenuPressedBackground;
+ color: @invertedMenuPressedColor;
+ }
- & when not (@color=secondary) {
- .ui.ui.ui.menu .@{color}.active.item,
- .ui.ui.@{color}.menu .active.item:hover,
- .ui.ui.@{color}.menu .active.item {
- & when not (@secondaryPointingActiveBorderColor = currentColor) {
- border-color: @c;
+ /* --- Active --- */
+ .ui.inverted.menu .active.item {
+ background: @invertedActiveBackground;
+ color: @invertedActiveColor !important;
+ }
+ & when (@variationMenuVertical) {
+ .ui.inverted.vertical.menu .item .menu .active.item {
+ background: @invertedSubMenuActiveBackground;
+ color: @invertedSubMenuActiveColor;
+ }
+ }
+ & when (@variationMenuPointing) {
+ .ui.inverted.pointing.menu .active.item::after {
+ background: @invertedArrowActiveColor;
+ margin: 0 !important;
+ box-shadow: none !important;
+ border: none !important;
}
- color: @c;
- }
}
- })
-}
-& when (@variationMenuInverted) {
- /*--------------
- Inverted
- ---------------*/
-
- .ui.inverted.menu {
- border: @invertedBorder;
- background: @invertedBackground;
- box-shadow: @invertedBoxShadow;
- }
-
- /* Menu Item */
- .ui.inverted.menu .item,
- .ui.inverted.menu .item > a:not(.ui) {
- background: @invertedItemBackground;
- color: @invertedItemTextColor;
- }
- .ui.inverted.menu .item.menu {
- background: @invertedSubMenuBackground;
- }
-
- /*--- Border ---*/
- .ui.inverted.menu .item::before {
- background: @invertedDividerBackground;
- }
- & when (@variationMenuVertical) {
- .ui.vertical.inverted.menu .item::before {
- background: @invertedVerticalDividerBackground;
- }
- /* Sub Menu */
- .ui.vertical.inverted.menu .menu .item,
- .ui.vertical.inverted.menu .menu .item a:not(.ui) {
- color: @invertedSubMenuColor;
- }
- }
- /* Header */
- .ui.inverted.menu .header.item {
- margin: 0;
- background: @invertedHeaderBackground;
- box-shadow: none;
- }
-
- /* Disabled */
- .ui.ui.inverted.menu .item.disabled {
- color: @invertedDisabledTextColor;
- }
-
- /*--- Hover ---*/
- .ui.link.inverted.menu .item:hover,
- .ui.inverted.menu .dropdown.item:hover,
- .ui.inverted.menu .link.item:hover,
- .ui.inverted.menu a.item:hover {
- background: @invertedHoverBackground;
- color: @invertedHoverColor;
- }
- & when (@variationMenuVertical) {
- .ui.vertical.inverted.menu .item .menu a.item:hover,
- .ui.vertical.inverted.menu .item .menu .link.item:hover {
- background: @invertedSubMenuBackground;
- color: @invertedSubMenuHoverColor;
- }
- }
- /*--- Pressed ---*/
- .ui.inverted.menu a.item:active,
- .ui.inverted.menu .link.item:active{
- background: @invertedMenuPressedBackground;
- color: @invertedMenuPressedColor;
- }
-
- /*--- Active ---*/
- .ui.inverted.menu .active.item {
- background: @invertedActiveBackground;
- color: @invertedActiveColor !important;
- }
- & when (@variationMenuVertical) {
- .ui.inverted.vertical.menu .item .menu .active.item {
- background: @invertedSubMenuActiveBackground;
- color: @invertedSubMenuActiveColor;
- }
- }
- & when (@variationMenuPointing) {
- .ui.inverted.pointing.menu .active.item::after {
- background: @invertedArrowActiveColor;
- margin: 0 !important;
- box-shadow: none !important;
- border: none !important;
- }
- }
-
- /*--- Active Hover ---*/
- .ui.inverted.menu .active.item:hover {
- background: @invertedActiveHoverBackground;
- color: @invertedActiveHoverColor !important;
- }
- & when (@variationMenuPointing) {
- .ui.inverted.pointing.menu .active.item:hover::after {
- background: @invertedArrowActiveHoverColor;
- }
- }
+ /* --- Active Hover --- */
+ .ui.inverted.menu .active.item:hover {
+ background: @invertedActiveHoverBackground;
+ color: @invertedActiveHoverColor !important;
+ }
+ & when (@variationMenuPointing) {
+ .ui.inverted.pointing.menu .active.item:hover::after {
+ background: @invertedArrowActiveHoverColor;
+ }
+ }
}
& when (@variationMenuFloated) {
- /*--------------
- Floated
- ---------------*/
-
- .ui.floated.menu {
- float: left;
- margin: 0 @floatedDistance 0 0;
- }
- .ui.floated.menu .item:last-child::before {
- display: none;
- }
+ /* --------------
+ Floated
+ --------------- */
+
+ .ui.floated.menu {
+ float: left;
+ margin: 0 @floatedDistance 0 0;
+ }
+ .ui.floated.menu .item:last-child::before {
+ display: none;
+ }
- .ui.right.floated.menu {
- float: right;
- margin: 0 0 0 @floatedDistance;
- }
+ .ui.right.floated.menu {
+ float: right;
+ margin: 0 0 0 @floatedDistance;
+ }
}
& when (@variationMenuCentered) {
- .ui.center.aligned.menu,
- .ui.centered.menu {
- display: inline-flex;
- transform: translateX(-50%);
- margin-left:50%;
- }
+ .ui.center.aligned.menu,
+ .ui.centered.menu {
+ display: inline-flex;
+ transform: translateX(-50%);
+ margin-left: 50%;
+ }
}
& when (@variationMenuInverted) {
- /*--------------
- Inverted
- ---------------*/
- & when not (@variationMenuColors = false) {
- each(@variationMenuColors, {
- @color: @value;
- @c: @colors[@@color][color];
- @h: @colors[@@color][hover];
-
- & when not (@color=secondary) {
- .ui.ui.ui.inverted.menu .@{color}.active.item,
- .ui.ui.inverted.@{color}.menu {
- background-color: @c;
- }
- .ui.inverted.@{color}.menu .item::before {
- background-color: @invertedColoredDividerBackground;
- }
- .ui.ui.inverted.@{color}.menu .active.item {
- background-color: @invertedColoredActiveBackground;
- }
- & when (@variationMenuPointing) {
- .ui.inverted.pointing.@{color}.menu .active.item {
- background-color: @h;
- }
+ /* --------------
+ Inverted
+ --------------- */
+ & when not (@variationMenuColors = false) {
+ each(@variationMenuColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+ @h: @colors[@@color][hover];
+
+ & when not (@color=secondary) {
+ .ui.ui.ui.inverted.menu .@{color}.active.item,
+ .ui.ui.inverted.@{color}.menu {
+ background-color: @c;
+ }
+ .ui.inverted.@{color}.menu .item::before {
+ background-color: @invertedColoredDividerBackground;
+ }
+ .ui.ui.inverted.@{color}.menu .active.item {
+ background-color: @invertedColoredActiveBackground;
+ }
+ & when (@variationMenuPointing) {
+ .ui.inverted.pointing.@{color}.menu .active.item {
+ background-color: @h;
+ }
+ }
+ }
+ });
+ }
+
+ & when (@variationMenuPointing) {
+ .ui.ui.ui.inverted.pointing.menu .active.item::after {
+ background-color: inherit;
}
- }
- })
- }
-
- & when (@variationMenuPointing) {
- .ui.ui.ui.inverted.pointing.menu .active.item::after {
- background-color: inherit;
}
- }
}
& when (@variationMenuFitted) {
- /*--------------
- Fitted
- ---------------*/
+ /* --------------
+ Fitted
+ --------------- */
- .ui.fitted.menu .item,
- .ui.fitted.menu .item .menu .item,
- .ui.menu .fitted.item {
- padding: 0;
- }
- .ui.horizontally.fitted.menu .item,
- .ui.horizontally.fitted.menu .item .menu .item,
- .ui.menu .horizontally.fitted.item {
- padding-top: @itemVerticalPadding;
- padding-bottom: @itemVerticalPadding;
- }
- .ui.vertically.fitted.menu .item,
- .ui.vertically.fitted.menu .item .menu .item,
- .ui.menu .vertically.fitted.item {
- padding-left: @itemHorizontalPadding;
- padding-right: @itemHorizontalPadding;
- }
+ .ui.fitted.menu .item,
+ .ui.fitted.menu .item .menu .item,
+ .ui.menu .fitted.item {
+ padding: 0;
+ }
+ .ui.horizontally.fitted.menu .item,
+ .ui.horizontally.fitted.menu .item .menu .item,
+ .ui.menu .horizontally.fitted.item {
+ padding-top: @itemVerticalPadding;
+ padding-bottom: @itemVerticalPadding;
+ }
+ .ui.vertically.fitted.menu .item,
+ .ui.vertically.fitted.menu .item .menu .item,
+ .ui.menu .vertically.fitted.item {
+ padding-left: @itemHorizontalPadding;
+ padding-right: @itemHorizontalPadding;
+ }
}
& when (@variationMenuBorderless) {
- /*--------------
- Borderless
- ---------------*/
+ /* --------------
+ Borderless
+ --------------- */
- .ui.borderless.menu .item::before,
- .ui.borderless.menu .item .menu .item::before,
- .ui.menu .borderless.item::before {
- background: none !important;
- }
+ .ui.borderless.menu .item::before,
+ .ui.borderless.menu .item .menu .item::before,
+ .ui.menu .borderless.item::before {
+ background: none !important;
+ }
}
& when (@variationMenuCompact) {
- /*-------------------
- Compact
- --------------------*/
+ /* -------------------
+ Compact
+ -------------------- */
- .ui.compact.menu {
- display: inline-flex;
- margin: 0;
- vertical-align: middle;
- }
- & when (@variationMenuVertical) {
- .ui.compact.vertical.menu {
- & when (@supportIE) {
- /* IE hack to make dropdown icons appear inline */
- display: -ms-inline-flexbox !important;
- }
- display: inline-block;
- }
- }
- .ui.compact.menu:not(.secondary) .item:last-child {
- border-radius: 0 @borderRadius @borderRadius 0;
- }
- .ui.compact.menu .item:last-child::before {
- display: none;
- }
- & when (@variationMenuVertical) {
- .ui.compact.vertical.menu {
- width: auto !important;
+ .ui.compact.menu {
+ display: inline-flex;
+ margin: 0;
+ vertical-align: middle;
+ }
+ & when (@variationMenuVertical) {
+ .ui.compact.vertical.menu {
+ & when (@supportIE) {
+ /* IE hack to make dropdown icons appear inline */
+ // stylelint-disable-next-line value-no-vendor-prefix
+ display: -ms-inline-flexbox !important;
+ }
+
+ display: inline-block;
+ }
}
- .ui.compact.vertical.menu .item:last-child::before {
- display: block;
+ .ui.compact.menu:not(.secondary) .item:last-child {
+ border-radius: 0 @borderRadius @borderRadius 0;
+ }
+ .ui.compact.menu .item:last-child::before {
+ display: none;
+ }
+ & when (@variationMenuVertical) {
+ .ui.compact.vertical.menu {
+ width: auto !important;
+ }
+ .ui.compact.vertical.menu .item:last-child::before {
+ display: block;
+ }
}
- }
}
& when (@variationMenuFluid) {
- /*-------------------
- Fluid
- --------------------*/
+ /* -------------------
+ Fluid
+ -------------------- */
- .ui.menu.fluid,
- .ui.vertical.menu.fluid {
- width: 100% !important;
- }
+ .ui.menu.fluid,
+ .ui.vertical.menu.fluid {
+ width: 100% !important;
+ }
}
-
-/*-------------------
+/* -------------------
Evenly Sized
---------------------*/
+-------------------- */
.ui.item.menu,
.ui.item.menu .item {
- width: 100%;
- padding-left: 0 !important;
- padding-right: 0 !important;
- margin-left: 0 !important;
- margin-right: 0 !important;
- text-align: center;
- justify-content: center;
+ width: 100%;
+ padding-left: 0 !important;
+ padding-right: 0 !important;
+ margin-left: 0 !important;
+ margin-right: 0 !important;
+ text-align: center;
+ justify-content: center;
}
.ui.attached.item.menu:not(.tabular) {
- margin: 0 @attachedHorizontalOffset !important;
+ margin: 0 @attachedHorizontalOffset !important;
}
.ui.item.menu .item:last-child::before {
- display: none;
+ display: none;
}
& when (@variationMenuEqualWidth) {
- .ui.menu.two.item .item {
- width: 50%;
- }
- .ui.menu.three.item .item {
- width: 33.333%;
- }
- .ui.menu.four.item .item {
- width: 25%;
- }
- .ui.menu.five.item .item {
- width: 20%;
- }
- .ui.menu.six.item .item {
- width: 16.666%;
- }
- .ui.menu.seven.item .item {
- width: 14.285%;
- }
- .ui.menu.eight.item .item {
- width: 12.500%;
- }
- .ui.menu.nine.item .item {
- width: 11.11%;
- }
- .ui.menu.ten.item .item {
- width: 10.0%;
- }
- .ui.menu.eleven.item .item {
- width: 9.09%;
- }
- .ui.menu.twelve.item .item {
- width: 8.333%;
- }
+ .ui.menu.two.item .item {
+ width: 50%;
+ }
+ .ui.menu.three.item .item {
+ width: 33.333%;
+ }
+ .ui.menu.four.item .item {
+ width: 25%;
+ }
+ .ui.menu.five.item .item {
+ width: 20%;
+ }
+ .ui.menu.six.item .item {
+ width: 16.666%;
+ }
+ .ui.menu.seven.item .item {
+ width: 14.285%;
+ }
+ .ui.menu.eight.item .item {
+ width: 12.5%;
+ }
+ .ui.menu.nine.item .item {
+ width: 11.11%;
+ }
+ .ui.menu.ten.item .item {
+ width: 10%;
+ }
+ .ui.menu.eleven.item .item {
+ width: 9.09%;
+ }
+ .ui.menu.twelve.item .item {
+ width: 8.333%;
+ }
}
& when (@variationMenuFixed) {
- /*--------------
- Fixed
- ---------------*/
+ /* --------------
+ Fixed
+ --------------- */
+
+ .ui.menu.fixed {
+ position: fixed;
+ z-index: 101;
+ margin: 0;
+ width: 100%;
+ }
+ .ui.menu.fixed,
+ .ui.menu.fixed .item:first-child,
+ .ui.menu.fixed .item:last-child {
+ border-radius: 0 !important;
+ }
- .ui.menu.fixed {
- position: fixed;
- z-index: 101;
- margin: 0;
- width: 100%;
- }
- .ui.menu.fixed,
- .ui.menu.fixed .item:first-child,
- .ui.menu.fixed .item:last-child {
- border-radius: 0 !important;
- }
-
- .ui.fixed.menu,
- .ui[class*="top fixed"].menu {
- top: 0;
- left: 0;
- right: auto;
- bottom: auto;
- }
- .ui[class*="top fixed"].menu {
- border-top: none;
- border-left: none;
- border-right: none;
- }
- .ui[class*="right fixed"].menu {
- border-top: none;
- border-bottom: none;
- border-right: none;
- top: 0;
- right: 0;
- left: auto;
- bottom: auto;
- width: auto;
- height: 100%;
- }
- .ui[class*="bottom fixed"].menu {
- border-bottom: none;
- border-left: none;
- border-right: none;
- bottom: 0;
- left: 0;
- top: auto;
- right: auto;
- }
- .ui[class*="left fixed"].menu {
- border-top: none;
- border-bottom: none;
- border-left: none;
- top: 0;
- left: 0;
- right: auto;
- bottom: auto;
- width: auto;
- height: 100%;
- }
+ .ui.fixed.menu,
+ .ui[class*="top fixed"].menu {
+ top: 0;
+ left: 0;
+ right: auto;
+ bottom: auto;
+ }
+ .ui[class*="top fixed"].menu {
+ border-top: none;
+ border-left: none;
+ border-right: none;
+ }
+ .ui[class*="right fixed"].menu {
+ border-top: none;
+ border-bottom: none;
+ border-right: none;
+ top: 0;
+ right: 0;
+ left: auto;
+ bottom: auto;
+ width: auto;
+ height: 100%;
+ }
+ .ui[class*="bottom fixed"].menu {
+ border-bottom: none;
+ border-left: none;
+ border-right: none;
+ bottom: 0;
+ left: 0;
+ top: auto;
+ right: auto;
+ }
+ .ui[class*="left fixed"].menu {
+ border-top: none;
+ border-bottom: none;
+ border-left: none;
+ top: 0;
+ left: 0;
+ right: auto;
+ bottom: auto;
+ width: auto;
+ height: 100%;
+ }
- /* Coupling with Grid */
- .ui.fixed.menu + .ui.grid {
- padding-top: @fixedPrecedingGridMargin;
- }
+ /* Coupling with Grid */
+ .ui.fixed.menu + .ui.grid {
+ padding-top: @fixedPrecedingGridMargin;
+ }
}
& when (@variationMenuPointing) {
- /*-------------------
- Pointing
- --------------------*/
-
- .ui.pointing.menu .item::after {
- visibility: hidden;
- position: absolute;
- content: '';
- top: 100%;
- left: 50%;
- transform: translateX(-50%) translateY(-50%) rotate(45deg);
- background: none;
-
- margin: (@arrowBorderWidth / 2) 0 0;
- width: @arrowSize;
- height: @arrowSize;
-
- border: none;
- border-bottom: @arrowBorder;
- border-right: @arrowBorder;
-
- z-index: @arrowZIndex;
- transition: @arrowTransition;
- }
- & when (@variationMenuVertical) {
- .ui.vertical.pointing.menu .item::after {
- position: absolute;
- top: 50%;
- right: 0;
- bottom: auto;
- left: auto;
-
- transform: translateX(50%) translateY(-50%) rotate(45deg);
- margin: 0 -(@arrowBorderWidth / 2) 0 0;
-
- border: none;
- border-top: @arrowBorder;
- border-right: @arrowBorder;
- }
- }
- .ui.pointing.menu .ui.dropdown .menu .item::after,
- .ui.vertical.pointing.menu .ui.dropdown .menu .item::after {
- display: none;
- }
+ /* -------------------
+ Pointing
+ -------------------- */
+
+ .ui.pointing.menu .item::after {
+ visibility: hidden;
+ position: absolute;
+ content: "";
+ top: 100%;
+ left: 50%;
+ transform: translateX(-50%) translateY(-50%) rotate(45deg);
+ background: none;
+ margin: (@arrowBorderWidth / 2) 0 0;
+ width: @arrowSize;
+ height: @arrowSize;
+ border: none;
+ border-bottom: @arrowBorder;
+ border-right: @arrowBorder;
+ z-index: @arrowZIndex;
+ transition: @arrowTransition;
+ }
+ & when (@variationMenuVertical) {
+ .ui.vertical.pointing.menu .item::after {
+ position: absolute;
+ top: 50%;
+ right: 0;
+ bottom: auto;
+ left: auto;
+ transform: translateX(50%) translateY(-50%) rotate(45deg);
+ margin: 0 -(@arrowBorderWidth / 2) 0 0;
+ border: none;
+ border-top: @arrowBorder;
+ border-right: @arrowBorder;
+ }
+ }
+ .ui.pointing.menu .ui.dropdown .menu .item::after,
+ .ui.vertical.pointing.menu .ui.dropdown .menu .item::after {
+ display: none;
+ }
- /* Active */
- .ui.pointing.menu .active.item::after {
- visibility: visible;
- }
- .ui.pointing.menu .active.dropdown.item::after {
- visibility: hidden;
- }
+ /* Active */
+ .ui.pointing.menu .active.item::after {
+ visibility: visible;
+ }
+ .ui.pointing.menu .active.dropdown.item::after {
+ visibility: hidden;
+ }
- /* Don't double up pointers */
- .ui.pointing.menu .dropdown.active.item::after,
- .ui.pointing.menu .active.item .menu .active.item::after {
- display: none;
- }
+ /* Don't double up pointers */
+ .ui.pointing.menu .dropdown.active.item::after,
+ .ui.pointing.menu .active.item .menu .active.item::after {
+ display: none;
+ }
- /* Colors */
- .ui.pointing.menu .active.item:hover::after {
- background-color: @arrowHoverColor;
- }
- .ui.pointing.menu .active.item::after {
- background-color: @arrowActiveColor;
- }
- .ui.pointing.menu .active.item:hover::after {
- background-color: @arrowActiveHoverColor;
- }
- & when (@variationMenuVertical) {
- .ui.vertical.pointing.menu .active.item:hover::after {
- background-color: @arrowVerticalHoverColor;
+ /* Colors */
+ .ui.pointing.menu .active.item:hover::after {
+ background-color: @arrowHoverColor;
}
- .ui.vertical.pointing.menu .active.item::after {
- background-color: @arrowVerticalActiveColor;
+ .ui.pointing.menu .active.item::after {
+ background-color: @arrowActiveColor;
}
- .ui.vertical.pointing.menu .menu .active.item::after {
- background-color: @arrowVerticalSubMenuColor;
+ .ui.pointing.menu .active.item:hover::after {
+ background-color: @arrowActiveHoverColor;
}
- & when (@variationMenuFluid) and (@variationGridStackable) {
- @media only screen and (max-width: @largestMobileScreen) {
- .ui.stackable.grid .ui.fluid.vertical.pointing.menu .active.item::after {
- display: none;
+ & when (@variationMenuVertical) {
+ .ui.vertical.pointing.menu .active.item:hover::after {
+ background-color: @arrowVerticalHoverColor;
+ }
+ .ui.vertical.pointing.menu .active.item::after {
+ background-color: @arrowVerticalActiveColor;
+ }
+ .ui.vertical.pointing.menu .menu .active.item::after {
+ background-color: @arrowVerticalSubMenuColor;
+ }
+ & when (@variationMenuFluid) and (@variationGridStackable) {
+ @media only screen and (max-width: @largestMobileScreen) {
+ .ui.stackable.grid .ui.fluid.vertical.pointing.menu .active.item::after {
+ display: none;
+ }
+ }
}
- }
}
- }
}
& when not (@variationMenuColors = false) {
- each(@variationMenuColors, {
- @color: @value;
- @c: @colors[@@color][color];
+ each(@variationMenuColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
- .ui.inverted.pointing.menu .@{color}.active.item::after {
- background-color: @c;
- }
- })
+ .ui.inverted.pointing.menu .@{color}.active.item::after {
+ background-color: @c;
+ }
+ });
}
& when (@variationMenuAttached) {
- /*--------------
- Attached
- ---------------*/
+ /* --------------
+ Attached
+ --------------- */
- /* Middle */
- .ui.attached.menu {
- top: 0;
- bottom: 0;
- border-radius: 0;
- margin: 0 @attachedHorizontalOffset;
- width: @attachedWidth;
- max-width: @attachedWidth;
- box-shadow: @attachedBoxShadow;
- }
- .ui.attached + .ui.attached.menu:not(.top) {
- border-top: none;
- }
-
- /* Top */
- .ui[class*="top attached"].menu {
- bottom: 0;
- margin-bottom: 0;
- top: @attachedTopOffset;
- margin-top: @verticalMargin;
- border-radius: @borderRadius @borderRadius 0 0;
- }
- .ui.menu[class*="top attached"]:first-child {
- margin-top: 0;
- }
+ /* Middle */
+ .ui.attached.menu {
+ top: 0;
+ bottom: 0;
+ border-radius: 0;
+ margin: 0 @attachedHorizontalOffset;
+ width: @attachedWidth;
+ max-width: @attachedWidth;
+ box-shadow: @attachedBoxShadow;
+ }
+ .ui.attached + .ui.attached.menu:not(.top) {
+ border-top: none;
+ }
- /* Bottom */
- .ui[class*="bottom attached"].menu {
- bottom: 0;
- margin-top: 0;
- top: @attachedBottomOffset;
- margin-bottom: @verticalMargin;
- box-shadow: @attachedBottomBoxShadow;
- border-radius: 0 0 @borderRadius @borderRadius;
- }
- .ui[class*="bottom attached"].menu:last-child {
- margin-bottom: 0;
- }
-
- /* Attached Menu Item */
- .ui.top.attached.menu > .item:first-child {
- border-radius: @borderRadius 0 0 0;
- }
- .ui.bottom.attached.menu > .item:first-child {
- border-radius: 0 0 0 @borderRadius;
- }
-
- /* Tabular Attached */
- .ui.attached.menu:not(.tabular):not(.text) {
- border: @attachedBorder;
- }
- & when (@variationMenuInverted) {
- .ui.attached.inverted.menu {
- border: none;
+ /* Top */
+ .ui[class*="top attached"].menu {
+ bottom: 0;
+ margin-bottom: 0;
+ top: @attachedTopOffset;
+ margin-top: @verticalMargin;
+ border-radius: @borderRadius @borderRadius 0 0;
}
- & when (@variationMenuTabular) {
- .ui[class*="top attached"].inverted.tabular.menu {
- border-bottom: @invertedTabularBorder;
- }
+ .ui.menu[class*="top attached"]:first-child {
+ margin-top: 0;
+ }
+
+ /* Bottom */
+ .ui[class*="bottom attached"].menu {
+ bottom: 0;
+ margin-top: 0;
+ top: @attachedBottomOffset;
+ margin-bottom: @verticalMargin;
+ box-shadow: @attachedBottomBoxShadow;
+ border-radius: 0 0 @borderRadius @borderRadius;
+ }
+ .ui[class*="bottom attached"].menu:last-child {
+ margin-bottom: 0;
}
- }
- & when (@variationMenuTabular) {
- .ui.attached.tabular.menu {
- margin-left: 0;
- margin-right: 0;
- width: 100%;
+
+ /* Attached Menu Item */
+ .ui.top.attached.menu > .item:first-child {
+ border-radius: @borderRadius 0 0 0;
+ }
+ .ui.bottom.attached.menu > .item:first-child {
+ border-radius: 0 0 0 @borderRadius;
+ }
+
+ /* Tabular Attached */
+ .ui.attached.menu:not(.tabular):not(.text) {
+ border: @attachedBorder;
+ }
+ & when (@variationMenuInverted) {
+ .ui.attached.inverted.menu {
+ border: none;
+ }
+ & when (@variationMenuTabular) {
+ .ui[class*="top attached"].inverted.tabular.menu {
+ border-bottom: @invertedTabularBorder;
+ }
+ }
+ }
+ & when (@variationMenuTabular) {
+ .ui.attached.tabular.menu {
+ margin-left: 0;
+ margin-right: 0;
+ width: 100%;
+ }
}
- }
}
-/*--------------
+/* --------------
Sizes
----------------*/
+--------------- */
.ui.menu {
- font-size: @medium;
+ font-size: @medium;
}
& when (@variationMenuVertical) {
- .ui.vertical.menu {
- width: @mediumWidth;
- }
+ .ui.vertical.menu {
+ width: @mediumWidth;
+ }
}
& when not (@variationMenuSizes = false) {
- each(@variationMenuSizes, {
- @w: @{value}Width;
- @s: @@value;
- .ui.@{value}.menu,
- .ui.@{value}.menu .dropdown,
- .ui.@{value}.menu .dropdown .menu > .item {
- font-size: @s;
- }
- & when (@variationMenuVertical) {
- .ui.@{value}.vertical.menu:not(.icon) {
- width: @@w;
- }
- }
- })
+ each(@variationMenuSizes, {
+ @w: @{value}Width;
+ @s: @@value;
+ .ui.@{value}.menu,
+ .ui.@{value}.menu .dropdown,
+ .ui.@{value}.menu .dropdown .menu > .item {
+ font-size: @s;
+ }
+ & when (@variationMenuVertical) {
+ .ui.@{value}.vertical.menu:not(.icon) {
+ width: @@w;
+ }
+ }
+ });
}
-/*-------------------
+/* -------------------
Inverted dropdowns
---------------------*/
+-------------------- */
.ui.menu .ui.inverted.inverted.dropdown.item .menu {
- background: @invertedDropdownBackground;
- box-shadow: @invertedDropdownMenuBoxShadow;
+ background: @invertedDropdownBackground;
+ box-shadow: @invertedDropdownMenuBoxShadow;
}
.ui.menu .ui.inverted.dropdown .menu > .item {
- color: @invertedDropdownItemColor !important;
+ color: @invertedDropdownItemColor !important;
}
.ui.menu .ui.inverted.dropdown .menu > .active.item {
- background: @invertedDropdownActiveItemBackground !important;
- color: @invertedDropdownActiveItemColor !important;
+ background: @invertedDropdownActiveItemBackground !important;
+ color: @invertedDropdownActiveItemColor !important;
}
.ui.menu .ui.inverted.dropdown .menu > .item:hover {
- background: @invertedDropdownHoveredItemBackground !important;
- color: @invertedDropdownHoveredItemColor !important;
+ background: @invertedDropdownHoveredItemBackground !important;
+ color: @invertedDropdownHoveredItemColor !important;
}
.ui.menu .ui.inverted.dropdown .menu > .selected.item {
- background: @invertedDropdownSelectedItemBackground !important;
- color: @invertedDropdownSelectedItemColor !important;
+ background: @invertedDropdownSelectedItemBackground !important;
+ color: @invertedDropdownSelectedItemColor !important;
}
& when (@variationMenuVertical) {
- /* Vertical */
- .ui.vertical.menu .inverted.dropdown.item .menu {
- box-shadow: @invertedDropdownMenuBoxShadow;
- }
+ /* Vertical */
+ .ui.vertical.menu .inverted.dropdown.item .menu {
+ box-shadow: @invertedDropdownMenuBoxShadow;
+ }
}
.loadUIOverrides();
diff --git a/definitions/collections/message.less b/definitions/collections/message.less
index f73b10f..e53dcc7 100644
--- a/definitions/collections/message.less
+++ b/definitions/collections/message.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Message
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,130 +12,129 @@
Theme
*******************************/
-@type : 'collection';
-@element : 'message';
+@type: "collection";
+@element: "message";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Message
*******************************/
.ui.message {
- position: relative;
- min-height: 1em;
- margin: @verticalMargin 0;
- background: @background;
- padding: @padding;
- line-height: @lineHeight;
- color: @textColor;
- transition: @transition;
- border-radius: @borderRadius;
- box-shadow: @boxShadow;
+ position: relative;
+ min-height: 1em;
+ margin: @verticalMargin 0;
+ background: @background;
+ padding: @padding;
+ line-height: @lineHeight;
+ color: @textColor;
+ transition: @transition;
+ border-radius: @borderRadius;
+ box-shadow: @boxShadow;
}
.ui.message:first-child {
- margin-top: 0;
+ margin-top: 0;
}
.ui.message:last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
-
-/*--------------
+/* --------------
Content
----------------*/
+--------------- */
/* Header */
.ui.message .header {
- display: @headerDisplay;
- font-family: @headerFont;
- font-weight: @headerFontWeight;
- margin: @headerMargin;
+ display: @headerDisplay;
+ font-family: @headerFont;
+ font-weight: @headerFontWeight;
+ margin: @headerMargin;
}
/* Default font size */
.ui.message .header:not(.ui) {
- font-size: @headerFontSize;
+ font-size: @headerFontSize;
}
/* Paragraph */
.ui.message p {
- opacity: @messageTextOpacity;
- margin: @messageParagraphMargin 0;
+ opacity: @messageTextOpacity;
+ margin: @messageParagraphMargin 0;
}
.ui.message p:first-child {
- margin-top: 0;
+ margin-top: 0;
}
.ui.message p:last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
.ui.message .header + p {
- margin-top: @headerParagraphDistance;
+ margin-top: @headerParagraphDistance;
}
/* List */
.ui.message .list:not(.ui) {
- text-align: left;
- padding: 0;
- opacity: @listOpacity;
- list-style-position: @listStylePosition;
- margin: @listMargin 0 0;
+ text-align: left;
+ padding: 0;
+ opacity: @listOpacity;
+ list-style-position: @listStylePosition;
+ margin: @listMargin 0 0;
}
.ui.message .list:not(.ui):first-child {
- margin-top: 0;
+ margin-top: 0;
}
.ui.message .list:not(.ui):last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
.ui.message .list:not(.ui) li {
- position: relative;
- list-style-type: none;
- margin: 0 0 @listItemMargin @listItemIndent;
- padding: 0;
+ position: relative;
+ list-style-type: none;
+ margin: 0 0 @listItemMargin @listItemIndent;
+ padding: 0;
}
.ui.message .list:not(.ui) li::before {
- position: absolute;
- content: 'ā¢';
- left: -1em;
- height: 100%;
- vertical-align: baseline;
+ position: absolute;
+ content: "ā¢";
+ left: -1em;
+ height: 100%;
+ vertical-align: baseline;
}
.ui.message .list:not(.ui) li:last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
& when (@variationMessageIcon) {
- /* Icon */
- .ui.icon.message > .icons,
- .ui.icon.message > i.icon {
- margin-right: @iconDistance;
- &:last-child {
- margin: 0 0 0 @iconDistance;
+ /* Icon */
+ .ui.icon.message > .icons,
+ .ui.icon.message > i.icon {
+ margin-right: @iconDistance;
+ &:last-child {
+ margin: 0 0 0 @iconDistance;
+ }
}
- }
}
/* Close Icon */
.ui.message > .close.icon {
- cursor: pointer;
- position: absolute;
- margin: 0;
- top: @closeTopDistance;
- right: @closeRightDistance;
- opacity: @closeOpacity;
- transition: @closeTransition;
+ cursor: pointer;
+ position: absolute;
+ margin: 0;
+ top: @closeTopDistance;
+ right: @closeRightDistance;
+ opacity: @closeOpacity;
+ transition: @closeTransition;
}
.ui.message > .close.icon:hover {
- opacity: 1;
+ opacity: 1;
}
/* First / Last Element */
.ui.message > :first-child {
- margin-top: 0;
+ margin-top: 0;
}
.ui.message > :last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
/*******************************
@@ -143,307 +142,304 @@
*******************************/
.ui.dropdown .menu > .message {
- margin: 0 -@borderWidth;
+ margin: 0 -@borderWidth;
}
/*******************************
States
*******************************/
-/*--------------
+/* --------------
Visible
----------------*/
+--------------- */
.ui.visible.visible.visible.visible.message {
- display: block;
+ display: block;
}
.ui.icon.visible.visible.visible.visible.message {
- display: flex;
+ display: flex;
}
-/*--------------
+/* --------------
Hidden
----------------*/
+--------------- */
.ui.hidden.hidden.hidden.hidden.message {
- display: none;
+ display: none;
}
-
/*******************************
Variations
*******************************/
& when (@variationMessageCentered) {
- .ui.centered.message,
- .ui.center.aligned.message {
- text-align: center;
- justify-content: center;
- & > .content {
- flex: 0 0 auto;
+ .ui.centered.message,
+ .ui.center.aligned.message {
+ text-align: center;
+ justify-content: center;
+ & > .content {
+ flex: 0 0 auto;
+ }
}
- }
}
& when (@variationMessageRightAligned) {
- .ui.right.aligned.message {
- text-align: right;
- }
+ .ui.right.aligned.message {
+ text-align: right;
+ }
}
& when (@variationMessageCompact) {
- /*--------------
- Compact
- ---------------*/
+ /* --------------
+ Compact
+ --------------- */
- .ui.compact.message {
- display: inline-block;
- }
- .ui.compact.icon.message {
- display: inline-flex;
- width: auto;
- }
+ .ui.compact.message {
+ display: inline-block;
+ }
+ .ui.compact.icon.message {
+ display: inline-flex;
+ width: auto;
+ }
}
& when (@variationMessageAttached) {
- /*--------------
- Attached
- ---------------*/
-
- .ui.attached.message {
- margin-bottom: @attachedYOffset;
- border-radius: @borderRadius @borderRadius 0 0;
- box-shadow: @attachedBoxShadow;
- margin-left: @attachedXOffset;
- margin-right: @attachedXOffset;
- }
- .ui.attached + .ui.attached.message:not(.top):not(.bottom) {
- margin-top: @attachedYOffset;
- border-radius: 0;
- }
- .ui.bottom.attached.message {
- margin-top: @attachedYOffset;
- border-radius: 0 0 @borderRadius @borderRadius;
- box-shadow: @attachedBottomBoxShadow;
- }
- .ui.bottom.attached.message:not(:last-child) {
- margin-bottom: @verticalMargin;
- }
- & when (@variationMessageIcon) {
- .ui.attached.icon.message {
- width: auto;
+ /* --------------
+ Attached
+ --------------- */
+
+ .ui.attached.message {
+ margin-bottom: @attachedYOffset;
+ border-radius: @borderRadius @borderRadius 0 0;
+ box-shadow: @attachedBoxShadow;
+ margin-left: @attachedXOffset;
+ margin-right: @attachedXOffset;
+ }
+ .ui.attached + .ui.attached.message:not(.top):not(.bottom) {
+ margin-top: @attachedYOffset;
+ border-radius: 0;
+ }
+ .ui.bottom.attached.message {
+ margin-top: @attachedYOffset;
+ border-radius: 0 0 @borderRadius @borderRadius;
+ box-shadow: @attachedBottomBoxShadow;
+ }
+ .ui.bottom.attached.message:not(:last-child) {
+ margin-bottom: @verticalMargin;
+ }
+ & when (@variationMessageIcon) {
+ .ui.attached.icon.message {
+ width: auto;
+ }
}
- }
}
& when (@variationMessageIcon) {
- /*--------------
- Icon
- ---------------*/
-
- .ui.icon.message {
- display: flex;
- width: 100%;
- align-items: center;
- }
- .ui.icon.message > .icons,
- .ui.icon.message > i.icon:not(.close) {
- display: block;
- flex: 0 0 auto;
- width: auto;
- line-height: 1;
- vertical-align: @iconVerticalAlign;
- font-size: @iconSize;
- opacity: @iconOpacity;
- }
- .ui.icon.message > .content {
- display: block;
- flex: 1 1 auto;
- vertical-align: @iconVerticalAlign;
- }
+ /* --------------
+ Icon
+ --------------- */
+
+ .ui.icon.message {
+ display: flex;
+ width: 100%;
+ align-items: center;
+ }
+ .ui.icon.message > .icons,
+ .ui.icon.message > i.icon:not(.close) {
+ display: block;
+ flex: 0 0 auto;
+ width: auto;
+ line-height: 1;
+ vertical-align: @iconVerticalAlign;
+ font-size: @iconSize;
+ opacity: @iconOpacity;
+ }
+ .ui.icon.message > .content {
+ display: block;
+ flex: 1 1 auto;
+ vertical-align: @iconVerticalAlign;
+ }
- .ui.icon.message > .icons + .content,
- .ui.icon.message > i.icon:not(.close) + .content {
- padding-left: @iconContentDistance;
- }
- .ui.icon.message > i.circular {
- width: 1em;
- }
+ .ui.icon.message > .icons + .content,
+ .ui.icon.message > i.icon:not(.close) + .content {
+ padding-left: @iconContentDistance;
+ }
+ .ui.icon.message > i.circular {
+ width: 1em;
+ }
}
& when (@variationMessageFloating) {
- /*--------------
- Floating
- ---------------*/
+ /* --------------
+ Floating
+ --------------- */
- .ui.floating.message {
- box-shadow: @floatingBoxShadow;
- }
+ .ui.floating.message {
+ box-shadow: @floatingBoxShadow;
+ }
}
-
-/*--------------
+/* --------------
Colors
----------------*/
+--------------- */
-/*--------------
+/* --------------
Types
----------------*/
+--------------- */
& when not (@variationMessageConsequences = false) {
-
- @consequences: {
- @positive: {
- background : @positiveBackgroundColor;
- header : @positiveHeaderColor;
- boxShadow : @positiveBoxShadow;
- boxFloatShadow : @positiveBoxFloatingShadow;
- text : @positiveTextColor;
- invertedText : @positiveBorderColor;
- };
- @negative: {
- background : @negativeBackgroundColor;
- header : @negativeHeaderColor;
- boxShadow : @negativeBoxShadow;
- boxFloatShadow : @negativeBoxFloatingShadow;
- text : @negativeTextColor;
- invertedText : @negativeBorderColor;
- };
- @info: {
- background : @infoBackgroundColor;
- header : @infoHeaderColor;
- boxShadow : @infoBoxShadow;
- boxFloatShadow : @infoBoxFloatingShadow;
- text : @infoTextColor;
- invertedText : @formInfoLabelBackground;
- };
- @warning: {
- background : @warningBackgroundColor;
- header : @warningHeaderColor;
- boxShadow : @warningBoxShadow;
- boxFloatShadow : @warningBoxFloatingShadow;
- text : @warningTextColor;
- invertedText : @formWarningLabelBackground;
- };
- @error: {
- background : @errorBackgroundColor;
- header : @errorHeaderColor;
- boxShadow : @errorBoxShadow;
- boxFloatShadow : @errorBoxFloatingShadow;
- text : @errorTextColor;
- invertedText : @formErrorLabelBackground;
+ @consequences: {
+ @positive: {
+ background: @positiveBackgroundColor;
+ header: @positiveHeaderColor;
+ boxShadow: @positiveBoxShadow;
+ boxFloatShadow: @positiveBoxFloatingShadow;
+ text: @positiveTextColor;
+ invertedText: @positiveBorderColor;
+ };
+ @negative: {
+ background: @negativeBackgroundColor;
+ header: @negativeHeaderColor;
+ boxShadow: @negativeBoxShadow;
+ boxFloatShadow: @negativeBoxFloatingShadow;
+ text: @negativeTextColor;
+ invertedText: @negativeBorderColor;
+ };
+ @info: {
+ background: @infoBackgroundColor;
+ header: @infoHeaderColor;
+ boxShadow: @infoBoxShadow;
+ boxFloatShadow: @infoBoxFloatingShadow;
+ text: @infoTextColor;
+ invertedText: @formInfoLabelBackground;
+ };
+ @warning: {
+ background: @warningBackgroundColor;
+ header: @warningHeaderColor;
+ boxShadow: @warningBoxShadow;
+ boxFloatShadow: @warningBoxFloatingShadow;
+ text: @warningTextColor;
+ invertedText: @formWarningLabelBackground;
+ };
+ @error: {
+ background: @errorBackgroundColor;
+ header: @errorHeaderColor;
+ boxShadow: @errorBoxShadow;
+ boxFloatShadow: @errorBoxFloatingShadow;
+ text: @errorTextColor;
+ invertedText: @formErrorLabelBackground;
+ };
+ @success: {
+ background: @successBackgroundColor;
+ header: @successHeaderColor;
+ boxShadow: @successBoxShadow;
+ boxFloatShadow: @successBoxFloatingShadow;
+ text: @successTextColor;
+ invertedText: @formSuccessLabelBackground;
+ };
};
- @success: {
- background : @successBackgroundColor;
- header : @successHeaderColor;
- boxShadow : @successBoxShadow;
- boxFloatShadow : @successBoxFloatingShadow;
- text : @successTextColor;
- invertedText : @formSuccessLabelBackground;
- };
- }
-
- /* Colors */
-
- each(@variationMessageConsequences, {
- @color: @value;
- @bg: @consequences[@@color][background];
- @hd: @consequences[@@color][header];
- @bs: @consequences[@@color][boxShadow];
- @bfs: @consequences[@@color][boxFloatShadow];
- @t: @consequences[@@color][text];
- @it: @consequences[@@color][invertedText];
-
- .ui.@{color}.message {
- background-color: @bg;
- color: @t;
- }
- .ui.@{color}.message,
- .ui.attached.@{color}.message {
- box-shadow: @bs;
- }
- & when (@variationMessageFloating) {
- .ui.floating.@{color}.message {
- box-shadow: @bfs;
- }
- }
- .ui.@{color}.message .header {
- color: @hd;
- }
- & when (@variationMessageInverted) {
- .ui.inverted.@{color}.message,
- .ui.inverted.@{color}.message .header {
- color: @it;
- }
- }
- })
+ /* Colors */
+
+ each(@variationMessageConsequences, {
+ @color: @value;
+ @bg: @consequences[@@color][background];
+ @hd: @consequences[@@color][header];
+ @bs: @consequences[@@color][boxShadow];
+ @bfs: @consequences[@@color][boxFloatShadow];
+ @t: @consequences[@@color][text];
+ @it: @consequences[@@color][invertedText];
+
+ .ui.@{color}.message {
+ background-color: @bg;
+ color: @t;
+ }
+
+ .ui.@{color}.message,
+ .ui.attached.@{color}.message {
+ box-shadow: @bs;
+ }
+ & when (@variationMessageFloating) {
+ .ui.floating.@{color}.message {
+ box-shadow: @bfs;
+ }
+ }
+ .ui.@{color}.message .header {
+ color: @hd;
+ }
+ & when (@variationMessageInverted) {
+ .ui.inverted.@{color}.message,
+ .ui.inverted.@{color}.message .header {
+ color: @it;
+ }
+ }
+ });
}
& when not (@variationMessageColors = false) {
- each(@variationMessageColors, {
- @color: @value;
- @bg: @colors[@@color][background];
- @hd: @colors[@@color][header];
- @bs: @colors[@@color][boxShadow];
- @bfs: @colors[@@color][boxFloatShadow];
- @t: @colors[@@color][text];
- @isVeryDark: @colors[@@color][isVeryDark];
-
- .ui.@{color}.message {
- & when not (@isVeryDark) {
- background-color: @bg;
- color: @t;
- }
- & when (@isVeryDark) {
- background-color: @black;
- color: @invertedTextColor;
- }
- }
+ each(@variationMessageColors, {
+ @color: @value;
+ @bg: @colors[@@color][background];
+ @hd: @colors[@@color][header];
+ @bs: @colors[@@color][boxShadow];
+ @bfs: @colors[@@color][boxFloatShadow];
+ @t: @colors[@@color][text];
+ @isVeryDark: @colors[@@color][isVeryDark];
+
+ .ui.@{color}.message {
+ & when not (@isVeryDark) {
+ background-color: @bg;
+ color: @t;
+ }
+ & when (@isVeryDark) {
+ background-color: @black;
+ color: @invertedTextColor;
+ }
+ }
- .ui.@{color}.message,
- .ui.attached.@{color}.message {
- & when not (@isVeryDark) {
- box-shadow: @bs;
- }
- }
- & when (@variationMessageFloating) {
- .ui.floating.@{color}.message {
- & when not (@isVeryDark) {
- box-shadow: @bfs;
+ .ui.@{color}.message,
+ .ui.attached.@{color}.message {
+ & when not (@isVeryDark) {
+ box-shadow: @bs;
+ }
+ }
+ & when (@variationMessageFloating) {
+ .ui.floating.@{color}.message {
+ & when not (@isVeryDark) {
+ box-shadow: @bfs;
+ }
+ }
}
- }
- }
- .ui.@{color}.message .header {
- & when not (@isVeryDark) {
- color: @hd;
- }
- & when (@isVeryDark) {
- color: @invertedTextColor;
- }
- }
- })
+ .ui.@{color}.message .header {
+ & when not (@isVeryDark) {
+ color: @hd;
+ }
+ & when (@isVeryDark) {
+ color: @invertedTextColor;
+ }
+ }
+ });
}
& when (@variationMessageInverted) {
- .ui.inverted.message {
- background-color: @black;
- color: @invertedTextColor;
- }
+ .ui.inverted.message {
+ background-color: @black;
+ color: @invertedTextColor;
+ }
}
-/*--------------
+/* --------------
Sizes
----------------*/
+--------------- */
.ui.message {
- font-size: @relativeMedium;
+ font-size: @relativeMedium;
}
& when not (@variationMessageSizes = false) {
- each(@variationMessageSizes, {
- @s: @{value}MessageSize;
- .ui.@{value}.message {
- font-size: @@s;
- }
- })
+ each(@variationMessageSizes, {
+ @s: @{value}MessageSize;
+ .ui.@{value}.message {
+ font-size: @@s;
+ }
+ });
}
.loadUIOverrides();
diff --git a/definitions/collections/table.less b/definitions/collections/table.less
index 5b0915d..56d9cc2 100644
--- a/definitions/collections/table.less
+++ b/definitions/collections/table.less
@@ -1,22 +1,21 @@
/*!
* # Fomantic-UI - Table
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-
/*******************************
Theme
*******************************/
-@type : 'collection';
-@element : 'table';
+@type: "collection";
+@element: "table";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Table
@@ -24,29 +23,29 @@
/* Prototype */
.ui.table {
- width: 100%;
- background: @background;
- margin: @margin;
- border: @border;
- box-shadow: @boxShadow;
- border-radius: @borderRadius;
- text-align: @textAlign;
- vertical-align: @verticalAlign;
- color: @color;
- border-collapse: @borderCollapse;
- border-spacing: @borderSpacing;
+ width: 100%;
+ background: @background;
+ margin: @margin;
+ border: @border;
+ box-shadow: @boxShadow;
+ border-radius: @borderRadius;
+ text-align: @textAlign;
+ vertical-align: @verticalAlign;
+ color: @color;
+ border-collapse: @borderCollapse;
+ border-spacing: @borderSpacing;
}
.ui.table:first-child {
- margin-top: 0;
+ margin-top: 0;
}
.ui.table:last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
.ui.table > thead,
.ui.table > tbody {
- text-align: inherit;
- vertical-align: inherit;
+ text-align: inherit;
+ vertical-align: inherit;
}
/*******************************
@@ -56,527 +55,527 @@
/* Table Content */
.ui.table th,
.ui.table td {
- transition: @transition;
+ transition: @transition;
}
/* Rowspan helper class */
.ui.table th.rowspanned,
.ui.table td.rowspanned {
- display:none;
+ display: none;
}
/* Headers */
.ui.table > thead {
- box-shadow: @headerBoxShadow;
+ box-shadow: @headerBoxShadow;
}
.ui.table > thead > tr > th {
- cursor: auto;
- background: @headerBackground;
- text-align: @headerAlign;
- color: @headerColor;
- padding: @headerVerticalPadding @headerHorizontalPadding;
- vertical-align: @headerVerticalAlign;
- font-style: @headerFontStyle;
- font-weight: @headerFontWeight;
- text-transform: @headerTextTransform;
- border-bottom: @headerBorder;
- border-left: @headerDivider;
+ cursor: auto;
+ background: @headerBackground;
+ text-align: @headerAlign;
+ color: @headerColor;
+ padding: @headerVerticalPadding @headerHorizontalPadding;
+ vertical-align: @headerVerticalAlign;
+ font-style: @headerFontStyle;
+ font-weight: @headerFontWeight;
+ text-transform: @headerTextTransform;
+ border-bottom: @headerBorder;
+ border-left: @headerDivider;
}
.ui.table > thead > tr > th:first-child {
- border-left: none;
+ border-left: none;
}
.ui.table > thead > tr:first-child > th:first-child {
- border-radius: @borderRadius 0 0 0;
+ border-radius: @borderRadius 0 0 0;
}
.ui.table > thead > tr:first-child > th:last-child {
- border-radius: 0 @borderRadius 0 0;
+ border-radius: 0 @borderRadius 0 0;
}
.ui.table > thead > tr:first-child > th:only-child {
- border-radius: @borderRadius @borderRadius 0 0;
+ border-radius: @borderRadius @borderRadius 0 0;
}
/* Footer */
.ui.table > tfoot {
- box-shadow: @footerBoxShadow;
+ box-shadow: @footerBoxShadow;
}
.ui.table > tfoot > tr > th,
.ui.table > tfoot > tr > td {
- cursor: auto;
- border-top: @footerBorder;
- background: @footerBackground;
- text-align: @footerAlign;
- color: @footerColor;
- padding: @footerVerticalPadding @footerHorizontalPadding;
- vertical-align: @footerVerticalAlign;
- font-style: @footerFontStyle;
- font-weight: @footerFontWeight;
- text-transform: @footerTextTransform;
+ cursor: auto;
+ border-top: @footerBorder;
+ background: @footerBackground;
+ text-align: @footerAlign;
+ color: @footerColor;
+ padding: @footerVerticalPadding @footerHorizontalPadding;
+ vertical-align: @footerVerticalAlign;
+ font-style: @footerFontStyle;
+ font-weight: @footerFontWeight;
+ text-transform: @footerTextTransform;
}
.ui.table > tfoot > tr > th:first-child,
.ui.table > tfoot > tr > td:first-child {
- border-left: none;
+ border-left: none;
}
.ui.table > tfoot > tr:first-child > th:first-child,
.ui.table > tfoot > tr:first-child > td:first-child {
- border-radius: 0 0 0 @borderRadius;
+ border-radius: 0 0 0 @borderRadius;
}
.ui.table > tfoot > tr:first-child > th:last-child,
.ui.table > tfoot > tr:first-child > td:last-child {
- border-radius: 0 0 @borderRadius 0;
+ border-radius: 0 0 @borderRadius 0;
}
.ui.table > tfoot > tr:first-child > th:only-child,
.ui.table > tfoot > tr:first-child > td:only-child {
- border-radius: 0 0 @borderRadius @borderRadius;
+ border-radius: 0 0 @borderRadius @borderRadius;
}
/* Table Row */
.ui.table > tr > td,
.ui.table > tbody > tr > td {
- border-top: @rowBorder;
+ border-top: @rowBorder;
}
.ui.table > tr:first-child > td,
.ui.table > tbody > tr:first-child > td {
- border-top: none;
+ border-top: none;
}
/* Repeated tbody */
.ui.table > tbody + tbody tr:first-child > td {
- border-top: @rowBorder;
+ border-top: @rowBorder;
}
/* Table Cells */
.ui.table > tbody > tr > td,
.ui.table > tr > td {
- padding: @cellVerticalPadding @cellHorizontalPadding;
- text-align: @cellTextAlign;
+ padding: @cellVerticalPadding @cellHorizontalPadding;
+ text-align: @cellTextAlign;
}
/* Icons */
.ui.table > i.icon {
- vertical-align: @iconVerticalAlign;
+ vertical-align: @iconVerticalAlign;
}
.ui.table > i.icon:only-child {
- margin: 0;
+ margin: 0;
}
/* Table Segment */
.ui.table.segment {
- padding: 0;
+ padding: 0;
}
.ui.table.segment::after {
- display: none;
+ display: none;
}
.ui.table.segment.stacked::after {
- display: block;
+ display: block;
}
-
/* Responsive */
-@media only screen and (max-width : @largestMobileScreen) {
- .ui.table:not(.unstackable) {
- width: 100%;
- padding: 0;
- }
- .ui.table:not(.unstackable) > thead,
- .ui.table:not(.unstackable) > thead > tr,
- .ui.table:not(.unstackable) > tfoot,
- .ui.table:not(.unstackable) > tfoot > tr,
- .ui.table:not(.unstackable) > tbody,
- .ui.table:not(.unstackable) > tr,
- .ui.table:not(.unstackable) > tbody > tr,
- .ui.table:not(.unstackable) > tr > th:not(.rowspanned),
- .ui.table:not(.unstackable) > thead > tr > th:not(.rowspanned),
- .ui.table:not(.unstackable) > tbody > tr > th:not(.rowspanned),
- .ui.table:not(.unstackable) > tfoot > tr > th:not(.rowspanned),
- .ui.table:not(.unstackable) > tr > td:not(.rowspanned),
- .ui.table:not(.unstackable) > tbody > tr > td:not(.rowspanned),
- .ui.table:not(.unstackable) > tfoot > tr > td:not(.rowspanned) {
- display: block !important;
- width: auto !important;
- }
-
- .ui.table:not(.unstackable) > thead {
- display: @responsiveHeaderDisplay;
- }
- .ui.table:not(.unstackable) > tfoot {
- display: @responsiveFooterDisplay;
- }
- .ui.ui.ui.ui.table:not(.unstackable) > tr,
- .ui.ui.ui.ui.table:not(.unstackable) > thead > tr,
- .ui.ui.ui.ui.table:not(.unstackable) > tbody > tr,
- .ui.ui.ui.ui.table:not(.unstackable) > tfoot > tr {
- padding-top: @responsiveRowVerticalPadding;
- padding-bottom: @responsiveRowVerticalPadding;
- box-shadow: @responsiveRowBoxShadow;
- }
-
- .ui.ui.ui.ui.table:not(.unstackable) > tr > th,
- .ui.ui.ui.ui.table:not(.unstackable) > thead > tr > th,
- .ui.ui.ui.ui.table:not(.unstackable) > tbody > tr > th,
- .ui.ui.ui.ui.table:not(.unstackable) > tfoot > tr > th,
- .ui.ui.ui.ui.table:not(.unstackable) > tr > td,
- .ui.ui.ui.ui.table:not(.unstackable) > tbody > tr > td,
- .ui.ui.ui.ui.table:not(.unstackable) > tfoot > tr > td {
- background: none;
- border: none;
- padding: @responsiveCellVerticalPadding @responsiveCellHorizontalPadding;
- box-shadow: @responsiveCellBoxShadow;
- }
- .ui.table:not(.unstackable) > tr > th:first-child,
- .ui.table:not(.unstackable) > thead > tr > th:first-child,
- .ui.table:not(.unstackable) > tbody > tr > th:first-child,
- .ui.table:not(.unstackable) > tfoot > tr > th:first-child,
- .ui.table:not(.unstackable) > tr > td:first-child,
- .ui.table:not(.unstackable) > tbody > tr > td:first-child,
- .ui.table:not(.unstackable) > tfoot > tr > td:first-child {
- font-weight: @responsiveCellHeaderFontWeight;
- }
-
- /* Definition Table */
- .ui.definition.table:not(.unstackable) > thead > tr > th:first-child {
- box-shadow: none !important;
- }
- & when (@variationTableMarked) and not (@variationTableColors = false) {
- each(@variationTableColors, {
- @color: @value;
- @c: @colors[@@color][color];
- @l: @colors[@@color][light];
- .ui.ui.ui.ui.table:not(.unstackable) tr[class*="@{color} marked"] {
- &.left {
- box-shadow: @responsiveRowBoxShadow, @coloredBorderSize 0 0 0 @c inset;
- }
- &.right {
- box-shadow: @responsiveRowBoxShadow, -@coloredBorderSize 0 0 0 @c inset;
- }
- }
- & when (@variationTableInverted) {
- .ui.ui.ui.ui.inverted.table:not(.unstackable) tr[class*="@{color} marked"] {
- &.left {
- box-shadow: @responsiveRowBoxShadow, @coloredBorderSize 0 0 0 @l inset;
- }
- &.right {
- box-shadow: @responsiveRowBoxShadow, -@coloredBorderSize 0 0 0 @l inset;
- }
- }
- }
- })
- }
- & when (@variationTableScrolling) {
- & when (@variationTableScrollingShort) {
- .ui.scrolling.table.short > tbody {
- max-height: @scrollingMobileMaxBodyHeight * 0.75;
- }
- }
- & when (@variationTableScrollingVeryShort) {
- .ui.scrolling.table[class*="very short"] > tbody {
- max-height: @scrollingMobileMaxBodyHeight * 0.5;
- }
- }
- .ui.scrolling.table > tbody {
- max-height: @scrollingMobileMaxBodyHeight;
- }
- & when (@variationTableScrollingLong) {
- .ui.scrolling.table.long > tbody {
- max-height: @scrollingMobileMaxBodyHeight * 2;
- }
- }
- & when (@variationTableScrollingVeryLong) {
- .ui.scrolling.table[class*="very long"] > tbody {
- max-height: @scrollingMobileMaxBodyHeight * 3;
- }
- }
- }
- & when (@variationTableOverflowing) {
- & when (@variationTableOverflowingShort) {
- .ui.overflowing.table.short {
- max-height: @overflowingMobileMaxHeight * 0.75;
- }
- }
- & when (@variationTableOverflowingVeryShort) {
- .ui.overflowing.table[class*="very short"] {
- max-height: @overflowingMobileMaxHeight * 0.5;
- }
+@media only screen and (max-width: @largestMobileScreen) {
+ .ui.table:not(.unstackable) {
+ width: 100%;
+ padding: 0;
+ }
+ .ui.table:not(.unstackable) > thead,
+ .ui.table:not(.unstackable) > thead > tr,
+ .ui.table:not(.unstackable) > tfoot,
+ .ui.table:not(.unstackable) > tfoot > tr,
+ .ui.table:not(.unstackable) > tbody,
+ .ui.table:not(.unstackable) > tr,
+ .ui.table:not(.unstackable) > tbody > tr,
+ .ui.table:not(.unstackable) > tr > th:not(.rowspanned),
+ .ui.table:not(.unstackable) > thead > tr > th:not(.rowspanned),
+ .ui.table:not(.unstackable) > tbody > tr > th:not(.rowspanned),
+ .ui.table:not(.unstackable) > tfoot > tr > th:not(.rowspanned),
+ .ui.table:not(.unstackable) > tr > td:not(.rowspanned),
+ .ui.table:not(.unstackable) > tbody > tr > td:not(.rowspanned),
+ .ui.table:not(.unstackable) > tfoot > tr > td:not(.rowspanned) {
+ display: block !important;
+ width: auto !important;
+ }
+
+ .ui.table:not(.unstackable) > thead {
+ display: @responsiveHeaderDisplay;
+ }
+ .ui.table:not(.unstackable) > tfoot {
+ display: @responsiveFooterDisplay;
+ }
+ .ui.ui.ui.ui.table:not(.unstackable) > tr,
+ .ui.ui.ui.ui.table:not(.unstackable) > thead > tr,
+ .ui.ui.ui.ui.table:not(.unstackable) > tbody > tr,
+ .ui.ui.ui.ui.table:not(.unstackable) > tfoot > tr {
+ padding-top: @responsiveRowVerticalPadding;
+ padding-bottom: @responsiveRowVerticalPadding;
+ box-shadow: @responsiveRowBoxShadow;
+ }
+
+ .ui.ui.ui.ui.table:not(.unstackable) > tr > th,
+ .ui.ui.ui.ui.table:not(.unstackable) > thead > tr > th,
+ .ui.ui.ui.ui.table:not(.unstackable) > tbody > tr > th,
+ .ui.ui.ui.ui.table:not(.unstackable) > tfoot > tr > th,
+ .ui.ui.ui.ui.table:not(.unstackable) > tr > td,
+ .ui.ui.ui.ui.table:not(.unstackable) > tbody > tr > td,
+ .ui.ui.ui.ui.table:not(.unstackable) > tfoot > tr > td {
+ background: none;
+ border: none;
+ padding: @responsiveCellVerticalPadding @responsiveCellHorizontalPadding;
+ box-shadow: @responsiveCellBoxShadow;
+ }
+ .ui.table:not(.unstackable) > tr > th:first-child,
+ .ui.table:not(.unstackable) > thead > tr > th:first-child,
+ .ui.table:not(.unstackable) > tbody > tr > th:first-child,
+ .ui.table:not(.unstackable) > tfoot > tr > th:first-child,
+ .ui.table:not(.unstackable) > tr > td:first-child,
+ .ui.table:not(.unstackable) > tbody > tr > td:first-child,
+ .ui.table:not(.unstackable) > tfoot > tr > td:first-child {
+ font-weight: @responsiveCellHeaderFontWeight;
+ }
+
+ /* Definition Table */
+ .ui.definition.table:not(.unstackable) > thead > tr > th:first-child {
+ box-shadow: none !important;
}
- .ui.overflowing.table {
- max-height: @overflowingMobileMaxHeight;
+ & when (@variationTableMarked) and not (@variationTableColors = false) {
+ each(@variationTableColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+ @l: @colors[@@color][light];
+ .ui.ui.ui.ui.table:not(.unstackable) tr[class*="@{color} marked"] {
+ &.left {
+ box-shadow: @responsiveRowBoxShadow, @coloredBorderSize 0 0 0 @c inset;
+ }
+ &.right {
+ box-shadow: @responsiveRowBoxShadow, -@coloredBorderSize 0 0 0 @c inset;
+ }
+ }
+ & when (@variationTableInverted) {
+ .ui.ui.ui.ui.inverted.table:not(.unstackable) tr[class*="@{color} marked"] {
+ &.left {
+ box-shadow: @responsiveRowBoxShadow, @coloredBorderSize 0 0 0 @l inset;
+ }
+ &.right {
+ box-shadow: @responsiveRowBoxShadow, -@coloredBorderSize 0 0 0 @l inset;
+ }
+ }
+ }
+ });
}
- & when (@variationTableOverflowingLong) {
- .ui.overflowing.table.long {
- max-height: @overflowingMobileMaxHeight * 2;
- }
+ & when (@variationTableScrolling) {
+ & when (@variationTableScrollingShort) {
+ .ui.scrolling.table.short > tbody {
+ max-height: @scrollingMobileMaxBodyHeight * 0.75;
+ }
+ }
+ & when (@variationTableScrollingVeryShort) {
+ .ui.scrolling.table[class*="very short"] > tbody {
+ max-height: @scrollingMobileMaxBodyHeight * 0.5;
+ }
+ }
+ .ui.scrolling.table > tbody {
+ max-height: @scrollingMobileMaxBodyHeight;
+ }
+ & when (@variationTableScrollingLong) {
+ .ui.scrolling.table.long > tbody {
+ max-height: @scrollingMobileMaxBodyHeight * 2;
+ }
+ }
+ & when (@variationTableScrollingVeryLong) {
+ .ui.scrolling.table[class*="very long"] > tbody {
+ max-height: @scrollingMobileMaxBodyHeight * 3;
+ }
+ }
}
- & when (@variationTableOverflowingVeryLong) {
- .ui.overflowing.table[class*="very long"] {
- max-height: @overflowingMobileMaxHeight * 3;
- }
+ & when (@variationTableOverflowing) {
+ & when (@variationTableOverflowingShort) {
+ .ui.overflowing.table.short {
+ max-height: @overflowingMobileMaxHeight * 0.75;
+ }
+ }
+ & when (@variationTableOverflowingVeryShort) {
+ .ui.overflowing.table[class*="very short"] {
+ max-height: @overflowingMobileMaxHeight * 0.5;
+ }
+ }
+ .ui.overflowing.table {
+ max-height: @overflowingMobileMaxHeight;
+ }
+ & when (@variationTableOverflowingLong) {
+ .ui.overflowing.table.long {
+ max-height: @overflowingMobileMaxHeight * 2;
+ }
+ }
+ & when (@variationTableOverflowingVeryLong) {
+ .ui.overflowing.table[class*="very long"] {
+ max-height: @overflowingMobileMaxHeight * 3;
+ }
+ }
}
- }
}
& when (@variationTableScrolling) {
- /*--------------
- Scrolling
- ---------------*/
- @media only screen and (min-width: @tabletBreakpoint) {
- & when (@variationTableScrollingShort) {
- .ui.scrolling.table.short > tbody {
- max-height: @scrollingTabletMaxBodyHeight * 0.75;
- }
- }
- & when (@variationTableScrollingVeryShort) {
- .ui.scrolling.table[class*="very short"] > tbody {
- max-height: @scrollingTabletMaxBodyHeight * 0.5;
- }
+ /* --------------
+ Scrolling
+ --------------- */
+ @media only screen and (min-width: @tabletBreakpoint) {
+ & when (@variationTableScrollingShort) {
+ .ui.scrolling.table.short > tbody {
+ max-height: @scrollingTabletMaxBodyHeight * 0.75;
+ }
+ }
+ & when (@variationTableScrollingVeryShort) {
+ .ui.scrolling.table[class*="very short"] > tbody {
+ max-height: @scrollingTabletMaxBodyHeight * 0.5;
+ }
+ }
+ .ui.scrolling.table > tbody {
+ max-height: @scrollingTabletMaxBodyHeight;
+ }
+ & when (@variationTableScrollingLong) {
+ .ui.scrolling.table.long > tbody {
+ max-height: @scrollingTabletMaxBodyHeight * 2;
+ }
+ }
+ & when (@variationTableScrollingVeryLong) {
+ .ui.scrolling.table[class*="very long"] > tbody {
+ max-height: @scrollingTabletMaxBodyHeight * 3;
+ }
+ }
}
- .ui.scrolling.table > tbody {
- max-height: @scrollingTabletMaxBodyHeight;
- }
- & when (@variationTableScrollingLong) {
- .ui.scrolling.table.long > tbody {
- max-height: @scrollingTabletMaxBodyHeight * 2;
- }
- }
- & when (@variationTableScrollingVeryLong) {
- .ui.scrolling.table[class*="very long"] > tbody {
- max-height: @scrollingTabletMaxBodyHeight * 3;
- }
- }
- }
- @media only screen and (min-width: @computerBreakpoint) {
- & when (@variationTableScrollingShort) {
- .ui.scrolling.table.short > tbody {
- max-height: @scrollingComputerMaxBodyHeight * 0.75;
- }
- }
- & when (@variationTableScrollingVeryShort) {
- .ui.scrolling.table[class*="very short"] > tbody {
- max-height: @scrollingComputerMaxBodyHeight * 0.5;
- }
+ @media only screen and (min-width: @computerBreakpoint) {
+ & when (@variationTableScrollingShort) {
+ .ui.scrolling.table.short > tbody {
+ max-height: @scrollingComputerMaxBodyHeight * 0.75;
+ }
+ }
+ & when (@variationTableScrollingVeryShort) {
+ .ui.scrolling.table[class*="very short"] > tbody {
+ max-height: @scrollingComputerMaxBodyHeight * 0.5;
+ }
+ }
+ .ui.scrolling.table > tbody {
+ max-height: @scrollingComputerMaxBodyHeight;
+ }
+ & when (@variationTableScrollingLong) {
+ .ui.scrolling.table.long > tbody {
+ max-height: @scrollingComputerMaxBodyHeight * 2;
+ }
+ }
+ & when (@variationTableScrollingVeryLong) {
+ .ui.scrolling.table[class*="very long"] > tbody {
+ max-height: @scrollingComputerMaxBodyHeight * 3;
+ }
+ }
}
- .ui.scrolling.table > tbody {
- max-height: @scrollingComputerMaxBodyHeight;
- }
- & when (@variationTableScrollingLong) {
- .ui.scrolling.table.long > tbody {
- max-height: @scrollingComputerMaxBodyHeight * 2;
- }
- }
- & when (@variationTableScrollingVeryLong) {
- .ui.scrolling.table[class*="very long"] > tbody {
- max-height: @scrollingComputerMaxBodyHeight * 3;
- }
- }
- }
- @media only screen and (min-width: @widescreenMonitorBreakpoint) {
- & when (@variationTableScrollingShort) {
- .ui.scrolling.table.short > tbody {
- max-height: @scrollingWidescreenMaxBodyHeight * 0.75;
- }
- }
- & when (@variationTableScrollingVeryShort) {
- .ui.scrolling.table[class*="very short"] > tbody {
- max-height: @scrollingWidescreenMaxBodyHeight * 0.5;
- }
+ @media only screen and (min-width: @widescreenMonitorBreakpoint) {
+ & when (@variationTableScrollingShort) {
+ .ui.scrolling.table.short > tbody {
+ max-height: @scrollingWidescreenMaxBodyHeight * 0.75;
+ }
+ }
+ & when (@variationTableScrollingVeryShort) {
+ .ui.scrolling.table[class*="very short"] > tbody {
+ max-height: @scrollingWidescreenMaxBodyHeight * 0.5;
+ }
+ }
+ .ui.scrolling.table > tbody {
+ max-height: @scrollingWidescreenMaxBodyHeight;
+ }
+ & when (@variationTableScrollingLong) {
+ .ui.scrolling.table.long > tbody {
+ max-height: @scrollingWidescreenMaxBodyHeight * 2;
+ }
+ }
+ & when (@variationTableScrollingVeryLong) {
+ .ui.scrolling.table[class*="very long"] > tbody {
+ max-height: @scrollingWidescreenMaxBodyHeight * 3;
+ }
+ }
}
+
+ .ui.scrolling.table > thead,
+ .ui.scrolling.table > tfoot,
.ui.scrolling.table > tbody {
- max-height: @scrollingWidescreenMaxBodyHeight;
- }
- & when (@variationTableScrollingLong) {
- .ui.scrolling.table.long > tbody {
- max-height: @scrollingWidescreenMaxBodyHeight * 2;
- }
- }
- & when (@variationTableScrollingVeryLong) {
- .ui.scrolling.table[class*="very long"] > tbody {
- max-height: @scrollingWidescreenMaxBodyHeight * 3;
- }
+ display: block;
+ overflow-y: scroll;
+ overscroll-behavior: @overscrollBehavior;
+ scrollbar-width: thin; /* Firefox */
+ & > tr {
+ display: table;
+ table-layout: fixed;
+ width: 100%;
+ }
}
- }
- .ui.scrolling.table > thead,
- .ui.scrolling.table > tfoot,
- .ui.scrolling.table > tbody {
- display: block;
- overflow-y: scroll;
- scrollbar-width: thin; /* Firefox */
- & > tr {
- display: table;
- table-layout: fixed;
- width: 100%;
+ /* Camouflage scrollbars, we need them only to gain the same width as tbody */
+ .ui.scrolling.table > thead {
+ background: @headerBackground;
+ color: @headerBackground;
+ border-radius: @borderRadius @borderRadius 0 0;
}
- }
-
- /* Camouflage scrollbars, we need them only to gain the same width as tbody */
- .ui.scrolling.table > thead {
- background: @headerBackground;
- color: @headerBackground;
- border-radius: @borderRadius @borderRadius 0 0;
- }
- .ui.scrolling.table > tfoot {
- background: @footerBackground;
- color: @footerBackground;
- border-radius: 0 0 @borderRadius @borderRadius;
- }
- & when (@variationTableInverted) {
- .ui.inverted.scrolling.table > thead {
- background: @invertedHeaderBackground;
- color: @invertedHeaderBackground;
- }
- .ui.inverted.scrolling.table > tfoot {
- background: @invertedFooterBackground;
- color: @invertedFooterBackground;
- }
- }
- .ui.scrolling.table > thead::-webkit-scrollbar-track,
- .ui.scrolling.table > tfoot::-webkit-scrollbar-track {
- background: inherit;
- border-radius: @borderRadius;
- }
-
- /* Firefox & IE */
- .ui.scrolling.table > thead,
- .ui.scrolling.table > tfoot {
- scrollbar-color: currentColor currentColor;
- & when (@supportIE) {
- scrollbar-face-color: currentColor;
- scrollbar-shadow-color: currentColor;
- scrollbar-track-color: currentColor;
- scrollbar-arrow-color: currentColor;
- }
- }
- & when (@supportIE) {
- /* IE scrollbar color needs hex values */
- @media all and (-ms-high-contrast: none) {
- .ui.scrolling.table > thead {
- color: @headerBackgroundHex;
- }
- .ui.scrolling.table > tfoot {
- color: @footerBackgroundHex;
- }
- & when (@variationTableInverted) {
+ .ui.scrolling.table > tfoot {
+ background: @footerBackground;
+ color: @footerBackground;
+ border-radius: 0 0 @borderRadius @borderRadius;
+ }
+ & when (@variationTableInverted) {
.ui.inverted.scrolling.table > thead {
- color: @invertedHeaderBackgroundHex;
+ background: @invertedHeaderBackground;
+ color: @invertedHeaderBackground;
}
.ui.inverted.scrolling.table > tfoot {
- color: @invertedFooterBackgroundHex;
+ background: @invertedFooterBackground;
+ color: @invertedFooterBackground;
}
- }
}
- }
- & when (@variationTableInverted) {
- .ui.inverted.scrolling.table > tbody::-webkit-scrollbar-track {
- background: @trackInvertedBackground;
- }
- .ui.inverted.scrolling.table > tbody::-webkit-scrollbar-thumb {
- background: @thumbInvertedBackground;
- }
- .ui.inverted.scrolling.table > tbody::-webkit-scrollbar-thumb:window-inactive {
- background: @thumbInvertedInactiveBackground;
+ .ui.scrolling.table > thead::-webkit-scrollbar-track,
+ .ui.scrolling.table > tfoot::-webkit-scrollbar-track {
+ background: inherit;
+ border-radius: @borderRadius;
+ }
+
+ /* Firefox & IE */
+ .ui.scrolling.table > thead,
+ .ui.scrolling.table > tfoot {
+ scrollbar-color: currentColor currentColor;
+ & when (@supportIE) {
+ scrollbar-face-color: currentColor;
+ scrollbar-shadow-color: currentColor;
+ scrollbar-track-color: currentColor;
+ scrollbar-arrow-color: currentColor;
+ }
}
- .ui.inverted.scrolling.table > tbody::-webkit-scrollbar-thumb:hover {
- background: @thumbInvertedHoverBackground;
+ & when (@supportIE) {
+ /* IE scrollbar color needs hex values */
+ @media all and (-ms-high-contrast: none) {
+ .ui.scrolling.table > thead {
+ color: @headerBackgroundHex;
+ }
+ .ui.scrolling.table > tfoot {
+ color: @footerBackgroundHex;
+ }
+ & when (@variationTableInverted) {
+ .ui.inverted.scrolling.table > thead {
+ color: @invertedHeaderBackgroundHex;
+ }
+ .ui.inverted.scrolling.table > tfoot {
+ color: @invertedFooterBackgroundHex;
+ }
+ }
+ }
}
- .ui.inverted.scrolling.table > tbody {
- & when (@supportIE) {
- /* IE11 */
- scrollbar-face-color: @thumbInvertedBackgroundHex;
- scrollbar-shadow-color: @thumbInvertedBackgroundHex;
- scrollbar-track-color: @trackInvertedBackgroundHex;
- scrollbar-arrow-color: @trackInvertedBackgroundHex;
- }
- /* firefox : first color thumb, second track */
- scrollbar-color: @thumbInvertedBackground @trackInvertedBackground;
+ & when (@variationTableInverted) {
+ .ui.inverted.scrolling.table > tbody::-webkit-scrollbar-track {
+ background: @trackInvertedBackground;
+ }
+ .ui.inverted.scrolling.table > tbody::-webkit-scrollbar-thumb {
+ background: @thumbInvertedBackground;
+ }
+ .ui.inverted.scrolling.table > tbody::-webkit-scrollbar-thumb:window-inactive {
+ background: @thumbInvertedInactiveBackground;
+ }
+ .ui.inverted.scrolling.table > tbody::-webkit-scrollbar-thumb:hover {
+ background: @thumbInvertedHoverBackground;
+ }
+ .ui.inverted.scrolling.table > tbody {
+ & when (@supportIE) {
+ /* IE11 */
+ scrollbar-face-color: @thumbInvertedBackgroundHex;
+ scrollbar-shadow-color: @thumbInvertedBackgroundHex;
+ scrollbar-track-color: @trackInvertedBackgroundHex;
+ scrollbar-arrow-color: @trackInvertedBackgroundHex;
+ }
+
+ /* firefox: first color thumb, second track */
+ scrollbar-color: @thumbInvertedBackground @trackInvertedBackground;
+ }
}
- }
-
}
& when (@variationTableOverflowing) {
- /*--------------
- Overflowing
- ---------------*/
- .ui.overflowing.table {
- display: block;
- overflow: auto;
- }
- @media only screen and (min-width: @tabletBreakpoint) {
- & when (@variationTableOverflowingShort) {
- .ui.overflowing.table.short {
- max-height: @overflowingTabletMaxHeight * 0.75;
- }
- }
- & when (@variationTableOverflowingVeryShort) {
- .ui.overflowing.table[class*="very short"] {
- max-height: @overflowingTabletMaxHeight * 0.5;
- }
- }
- .ui.overflowing.table {
- max-height: @overflowingTabletMaxHeight;
- }
- & when (@variationTableOverflowingLong) {
- .ui.overflowing.table.long {
- max-height: @overflowingTabletMaxHeight * 2;
- }
- }
- & when (@variationTableOverflowingVeryLong) {
- .ui.overflowing.table[class*="very long"] {
- max-height: @overflowingTabletMaxHeight * 3;
- }
- }
- }
- @media only screen and (min-width: @computerBreakpoint) {
- & when (@variationTableOverflowingShort) {
- .ui.overflowing.table.short {
- max-height: @overflowingComputerMaxHeight * 0.75;
- }
- }
- & when (@variationTableOverflowingVeryShort) {
- .ui.overflowing.table[class*="very short"] {
- max-height: @overflowingComputerMaxHeight * 0.5;
- }
- }
- .ui.overflowing.table {
- max-height: @overflowingComputerMaxHeight;
- }
- & when (@variationTableOverflowingLong) {
- .ui.overflowing.table.long {
- max-height: @overflowingComputerMaxHeight * 2;
- }
- }
- & when (@variationTableOverflowingVeryLong) {
- .ui.overflowing.table[class*="very long"]{
- max-height: @overflowingComputerMaxHeight * 3;
- }
- }
- }
- @media only screen and (min-width: @widescreenMonitorBreakpoint) {
- & when (@variationTableOverflowingShort) {
- .ui.overflowing.table.short {
- max-height: @overflowingWidescreenMaxHeight * 0.75;
- }
- }
- & when (@variationTableOverflowingVeryShort) {
- .ui.overflowing.table[class*="very short"] {
- max-height: @overflowingWidescreenMaxHeight * 0.5;
- }
- }
+ /* --------------
+ Overflowing
+ --------------- */
.ui.overflowing.table {
- max-height: @overflowingWidescreenMaxHeight;
+ display: block;
+ overflow: auto;
+ overscroll-behavior: @overscrollBehavior;
+ }
+ @media only screen and (min-width: @tabletBreakpoint) {
+ & when (@variationTableOverflowingShort) {
+ .ui.overflowing.table.short {
+ max-height: @overflowingTabletMaxHeight * 0.75;
+ }
+ }
+ & when (@variationTableOverflowingVeryShort) {
+ .ui.overflowing.table[class*="very short"] {
+ max-height: @overflowingTabletMaxHeight * 0.5;
+ }
+ }
+ .ui.overflowing.table {
+ max-height: @overflowingTabletMaxHeight;
+ }
+ & when (@variationTableOverflowingLong) {
+ .ui.overflowing.table.long {
+ max-height: @overflowingTabletMaxHeight * 2;
+ }
+ }
+ & when (@variationTableOverflowingVeryLong) {
+ .ui.overflowing.table[class*="very long"] {
+ max-height: @overflowingTabletMaxHeight * 3;
+ }
+ }
}
- & when (@variationTableOverflowingLong) {
- .ui.overflowing.table.long {
- max-height: @overflowingWidescreenMaxHeight * 2;
- }
+ @media only screen and (min-width: @computerBreakpoint) {
+ & when (@variationTableOverflowingShort) {
+ .ui.overflowing.table.short {
+ max-height: @overflowingComputerMaxHeight * 0.75;
+ }
+ }
+ & when (@variationTableOverflowingVeryShort) {
+ .ui.overflowing.table[class*="very short"] {
+ max-height: @overflowingComputerMaxHeight * 0.5;
+ }
+ }
+ .ui.overflowing.table {
+ max-height: @overflowingComputerMaxHeight;
+ }
+ & when (@variationTableOverflowingLong) {
+ .ui.overflowing.table.long {
+ max-height: @overflowingComputerMaxHeight * 2;
+ }
+ }
+ & when (@variationTableOverflowingVeryLong) {
+ .ui.overflowing.table[class*="very long"] {
+ max-height: @overflowingComputerMaxHeight * 3;
+ }
+ }
}
- & when (@variationTableOverflowingVeryLong) {
- .ui.overflowing.table[class*="very long"] {
- max-height: @overflowingWidescreenMaxHeight * 3;
- }
+ @media only screen and (min-width: @widescreenMonitorBreakpoint) {
+ & when (@variationTableOverflowingShort) {
+ .ui.overflowing.table.short {
+ max-height: @overflowingWidescreenMaxHeight * 0.75;
+ }
+ }
+ & when (@variationTableOverflowingVeryShort) {
+ .ui.overflowing.table[class*="very short"] {
+ max-height: @overflowingWidescreenMaxHeight * 0.5;
+ }
+ }
+ .ui.overflowing.table {
+ max-height: @overflowingWidescreenMaxHeight;
+ }
+ & when (@variationTableOverflowingLong) {
+ .ui.overflowing.table.long {
+ max-height: @overflowingWidescreenMaxHeight * 2;
+ }
+ }
+ & when (@variationTableOverflowingVeryLong) {
+ .ui.overflowing.table[class*="very long"] {
+ max-height: @overflowingWidescreenMaxHeight * 3;
+ }
+ }
}
- }
}
-
/*******************************
Coupling
*******************************/
@@ -584,108 +583,112 @@
/* UI Image */
.ui.table .collapsing .image,
.ui.table .collapsing .image img {
- max-width: none;
+ max-width: none;
}
-
/*******************************
Types
*******************************/
-/*--------------
+/* --------------
Complex
----------------*/
+--------------- */
& when (@variationTableStructured) {
- .ui.structured.table {
- border-collapse: collapse;
- }
- .ui.structured.table > thead > tr > th {
- border-left: @headerDivider;
- border-right: @headerDivider;
- }
- & when (@variationTableSortable) {
- .ui.structured.sortable.table > thead > tr > th {
- border-left: @sortableBorder;
- border-right: @sortableBorder;
- }
- }
- & when (@variationTableBasic) {
- .ui.structured.basic.table > tr > th,
- .ui.structured.basic.table > thead > tr > th,
- .ui.structured.basic.table > tbody > tr > th,
- .ui.structured.basic.table > tfoot > tr > th {
- border-left: @basicTableHeaderDivider;
- border-right: @basicTableHeaderDivider;
- }
- }
- & when (@variationTableCelled) {
- .ui.structured.celled.table > tr > th,
- .ui.structured.celled.table > thead > tr > th,
- .ui.structured.celled.table > tbody > tr > th,
- .ui.structured.celled.table > tfoot > tr > th,
- .ui.structured.celled.table > tr > td,
- .ui.structured.celled.table > tbody > tr > td ,
- .ui.structured.celled.table > tfoot > tr > td { border-left: @cellBorder;
- border-right: @cellBorder;
- }
- }
+ .ui.structured.table {
+ border-collapse: collapse;
+ }
+ .ui.structured.table > thead > tr > th {
+ border-left: @headerDivider;
+ border-right: @headerDivider;
+ }
+ & when (@variationTableSortable) {
+ .ui.structured.sortable.table > thead > tr > th {
+ border-left: @sortableBorder;
+ border-right: @sortableBorder;
+ }
+ }
+ & when (@variationTableBasic) {
+ .ui.structured.basic.table > tr > th,
+ .ui.structured.basic.table > thead > tr > th,
+ .ui.structured.basic.table > tbody > tr > th,
+ .ui.structured.basic.table > tfoot > tr > th {
+ border-left: @basicTableHeaderDivider;
+ border-right: @basicTableHeaderDivider;
+ }
+ }
+ & when (@variationTableCelled) {
+ .ui.structured.celled.table > tr > th,
+ .ui.structured.celled.table > thead > tr > th,
+ .ui.structured.celled.table > tbody > tr > th,
+ .ui.structured.celled.table > tfoot > tr > th,
+ .ui.structured.celled.table > tr > td,
+ .ui.structured.celled.table > tbody > tr > td,
+ .ui.structured.celled.table > tfoot > tr > td {
+ border-left: @cellBorder;
+ border-right: @cellBorder;
+ }
+ }
}
& when (@variationTableDefinition) {
- /*--------------
- Definition
- ---------------*/
-
- .ui.definition.table > thead:not(.full-width) > tr > th:first-child {
- pointer-events: none;
- background: @definitionHeaderBackground;
- font-weight: @definitionHeaderFontWeight;
- color: @definitionHeaderColor;
- box-shadow: -@coloredBorderSizeCover -@coloredBorderSize 0 @coloredBorderSizeCover @definitionPageBackground;
- -moz-transform: scale(1);
- }
-
- .ui.definition.table > thead:not(.full-width) > tr > th:first-child:not(:empty) {
- pointer-events: auto;
- }
-
- .ui.definition.table > tfoot:not(.full-width) > tr > th:first-child {
- pointer-events: none;
- background: @definitionFooterBackground;
- font-weight: @definitionFooterFontWeight;
- color: @definitionFooterColor;
- box-shadow: -@coloredBorderSizeCover @coloredBorderSize 0 @coloredBorderSizeCover @definitionPageBackground;
- -moz-transform: scale(1);
- }
-
- /* Highlight Defining Column */
- .ui.definition.table > tr > td:first-child:not(.ignored),
- .ui.definition.table > tbody > tr > td:first-child:not(.ignored),
- .ui.definition.table > tfoot > tr > td:first-child:not(.ignored),
- .ui.definition.table tr td.definition {
- background: @definitionColumnBackground;
- font-weight: @definitionColumnFontWeight;
- color: @definitionColumnColor;
- text-transform: @definitionColumnTextTransform;
- box-shadow: @definitionColumnBoxShadow;
- text-align: @definitionColumnTextAlign;
- font-size: @definitionColumnFontSize;
- padding-left: @definitionColumnHorizontalPadding;
- padding-right: @definitionColumnHorizontalPadding;
- }
-
-
- /* Fix 2nd Column */
- .ui.definition.table > thead:not(.full-width) > tr > th:nth-child(2) {
- border-left: @borderWidth solid @borderColor;
- }
- .ui.definition.table > tfoot:not(.full-width) > tr > th:nth-child(2) ,
- .ui.definition.table > tfoot:not(.full-width) > tr > td:nth-child(2) { border-left: @borderWidth solid @borderColor;
- }
- .ui.definition.table > tr > td:nth-child(2),
- .ui.definition.table > tbody > tr > td:nth-child(2) {
- border-left: @borderWidth solid @borderColor;
- }
+ /* --------------
+ Definition
+ --------------- */
+
+ .ui.definition.table > thead:not(.full-width) > tr > th:first-child {
+ pointer-events: none;
+ background: @definitionHeaderBackground;
+ font-weight: @definitionHeaderFontWeight;
+ color: @definitionHeaderColor;
+ box-shadow: -@coloredBorderSizeCover -@coloredBorderSize 0 @coloredBorderSizeCover @definitionPageBackground;
+ // https://github.com/fomantic/Fomantic-UI/pull/884
+ // stylelint-disable-next-line property-no-vendor-prefix
+ -moz-transform: scale(1);
+ }
+
+ .ui.definition.table > thead:not(.full-width) > tr > th:first-child:not(:empty) {
+ pointer-events: auto;
+ }
+
+ .ui.definition.table > tfoot:not(.full-width) > tr > th:first-child {
+ pointer-events: none;
+ background: @definitionFooterBackground;
+ font-weight: @definitionFooterFontWeight;
+ color: @definitionFooterColor;
+ box-shadow: -@coloredBorderSizeCover @coloredBorderSize 0 @coloredBorderSizeCover @definitionPageBackground;
+ // https://github.com/fomantic/Fomantic-UI/pull/884
+ // stylelint-disable-next-line property-no-vendor-prefix
+ -moz-transform: scale(1);
+ }
+
+ /* Highlight Defining Column */
+ .ui.definition.table > tr > td:first-child:not(.ignored),
+ .ui.definition.table > tbody > tr > td:first-child:not(.ignored),
+ .ui.definition.table > tfoot > tr > td:first-child:not(.ignored),
+ .ui.definition.table tr td.definition {
+ background: @definitionColumnBackground;
+ font-weight: @definitionColumnFontWeight;
+ color: @definitionColumnColor;
+ text-transform: @definitionColumnTextTransform;
+ box-shadow: @definitionColumnBoxShadow;
+ text-align: @definitionColumnTextAlign;
+ font-size: @definitionColumnFontSize;
+ padding-left: @definitionColumnHorizontalPadding;
+ padding-right: @definitionColumnHorizontalPadding;
+ }
+
+ /* Fix 2nd Column */
+ .ui.definition.table > thead:not(.full-width) > tr > th:nth-child(2) {
+ border-left: @borderWidth solid @borderColor;
+ }
+ .ui.definition.table > tfoot:not(.full-width) > tr > th:nth-child(2),
+ .ui.definition.table > tfoot:not(.full-width) > tr > td:nth-child(2) {
+ border-left: @borderWidth solid @borderColor;
+ }
+ .ui.definition.table > tr > td:nth-child(2),
+ .ui.definition.table > tbody > tr > td:nth-child(2) {
+ border-left: @borderWidth solid @borderColor;
+ }
}
/*******************************
@@ -693,1244 +696,1237 @@
*******************************/
& when (@variationTablePositive) {
- /*--------------
- Positive
- ---------------*/
-
- .ui.ui.ui.ui.table tr.positive,
- .ui.ui.table td.positive {
- box-shadow: @positiveBoxShadow;
- background: @positiveBackgroundColor;
- color: @positiveColor;
- }
- & when (@variationTableInverted) {
- .ui.ui.ui.ui.inverted.table tr.positive,
- .ui.ui.inverted.table td.positive {
- background: @invertedPositiveBackgroundColor;
- color: @invertedPositiveColor;
- }
- }
+ /* --------------
+ Positive
+ --------------- */
+
+ .ui.ui.ui.ui.table tr.positive,
+ .ui.ui.table td.positive {
+ box-shadow: @positiveBoxShadow;
+ background: @positiveBackgroundColor;
+ color: @positiveColor;
+ }
+ & when (@variationTableInverted) {
+ .ui.ui.ui.ui.inverted.table tr.positive,
+ .ui.ui.inverted.table td.positive {
+ background: @invertedPositiveBackgroundColor;
+ color: @invertedPositiveColor;
+ }
+ }
}
& when (@variationTableNegative) {
- /*--------------
- Negative
- ---------------*/
-
- .ui.ui.ui.ui.table tr.negative,
- .ui.ui.table td.negative {
- box-shadow: @negativeBoxShadow;
- background: @negativeBackgroundColor;
- color: @negativeColor;
- }
- & when (@variationTableInverted) {
- .ui.ui.ui.ui.inverted.table tr.negative,
- .ui.ui.inverted.table td.negative {
- background: @invertedNegativeBackgroundColor;
- color: @invertedNegativeColor;
- }
- }
+ /* --------------
+ Negative
+ --------------- */
+
+ .ui.ui.ui.ui.table tr.negative,
+ .ui.ui.table td.negative {
+ box-shadow: @negativeBoxShadow;
+ background: @negativeBackgroundColor;
+ color: @negativeColor;
+ }
+ & when (@variationTableInverted) {
+ .ui.ui.ui.ui.inverted.table tr.negative,
+ .ui.ui.inverted.table td.negative {
+ background: @invertedNegativeBackgroundColor;
+ color: @invertedNegativeColor;
+ }
+ }
}
& when (@variationTableError) {
- /*--------------
- Error
- ---------------*/
-
- .ui.ui.ui.ui.table tr.error,
- .ui.ui.table td.error {
- box-shadow: @errorBoxShadow;
- background: @errorBackgroundColor;
- color: @errorColor;
- }
- & when (@variationTableInverted) {
- .ui.ui.ui.ui.inverted.table tr.error,
- .ui.ui.inverted.table td.error {
- background: @invertedErrorBackgroundColor;
- color: @invertedErrorColor;
- }
- }
+ /* --------------
+ Error
+ --------------- */
+
+ .ui.ui.ui.ui.table tr.error,
+ .ui.ui.table td.error {
+ box-shadow: @errorBoxShadow;
+ background: @errorBackgroundColor;
+ color: @errorColor;
+ }
+ & when (@variationTableInverted) {
+ .ui.ui.ui.ui.inverted.table tr.error,
+ .ui.ui.inverted.table td.error {
+ background: @invertedErrorBackgroundColor;
+ color: @invertedErrorColor;
+ }
+ }
}
& when (@variationTableWarning) {
- /*--------------
- Warning
- ---------------*/
-
- .ui.ui.ui.ui.table tr.warning,
- .ui.ui.table td.warning {
- box-shadow: @warningBoxShadow;
- background: @warningBackgroundColor;
- color: @warningColor;
- }
- & when (@variationTableInverted) {
- .ui.ui.ui.ui.inverted.table tr.warning,
- .ui.ui.inverted.table td.warning {
- background: @invertedWarningBackgroundColor;
- color: @invertedWarningColor;
- }
- }
+ /* --------------
+ Warning
+ --------------- */
+
+ .ui.ui.ui.ui.table tr.warning,
+ .ui.ui.table td.warning {
+ box-shadow: @warningBoxShadow;
+ background: @warningBackgroundColor;
+ color: @warningColor;
+ }
+ & when (@variationTableInverted) {
+ .ui.ui.ui.ui.inverted.table tr.warning,
+ .ui.ui.inverted.table td.warning {
+ background: @invertedWarningBackgroundColor;
+ color: @invertedWarningColor;
+ }
+ }
}
& when (@variationTableActive) {
- /*--------------
- Active
- ---------------*/
-
- .ui.ui.ui.ui.table tr.active,
- .ui.ui.table td.active {
- box-shadow: @activeBoxShadow;
- background: @activeBackgroundColor;
- color: @activeColor;
- }
- & when (@variationTableInverted) {
- .ui.ui.ui.ui.inverted.table tr.active,
- .ui.ui.inverted.table td.active {
- background: @invertedActiveBackgroundColor;
- color: @invertedActiveColor;
- }
- }
-}
+ /* --------------
+ Active
+ --------------- */
+ .ui.ui.ui.ui.table tr.active,
+ .ui.ui.table td.active {
+ box-shadow: @activeBoxShadow;
+ background: @activeBackgroundColor;
+ color: @activeColor;
+ }
+ & when (@variationTableInverted) {
+ .ui.ui.ui.ui.inverted.table tr.active,
+ .ui.ui.inverted.table td.active {
+ background: @invertedActiveBackgroundColor;
+ color: @invertedActiveColor;
+ }
+ }
+}
& when (@variationTableDisabled) {
- /*--------------
- Disabled
- ---------------*/
-
- .ui.ui.ui.table tr.disabled td,
- .ui.ui.ui.table tr td.disabled,
- .ui.table tr.disabled:hover,
- .ui.table tr:hover td.disabled {
- pointer-events: none;
- color: @disabledTextColor;
- }
+ /* --------------
+ Disabled
+ --------------- */
+
+ .ui.ui.ui.table tr.disabled td,
+ .ui.ui.ui.table tr td.disabled,
+ .ui.table tr.disabled:hover,
+ .ui.table tr:hover td.disabled {
+ pointer-events: none;
+ color: @disabledTextColor;
+ }
}
/*******************************
Variations
*******************************/
& when (@variationTableStackable) {
- /*--------------
- Stackable
- ---------------*/
-
- @media only screen and (max-width : @largestTabletScreen) {
-
- .ui[class*="tablet stackable"].table,
- .ui[class*="tablet stackable"].table > thead,
- .ui[class*="tablet stackable"].table > thead > tr,
- .ui[class*="tablet stackable"].table > tfoot,
- .ui[class*="tablet stackable"].table > tfoot > tr,
- .ui[class*="tablet stackable"].table > tbody,
- .ui[class*="tablet stackable"].table > tbody > tr,
- .ui[class*="tablet stackable"].table > tr,
- .ui[class*="tablet stackable"].table > thead > tr > th:not(.rowspanned),
- .ui[class*="tablet stackable"].table > tbody > tr > th:not(.rowspanned),
- .ui[class*="tablet stackable"].table > tfoot > tr > th:not(.rowspanned),
- .ui[class*="tablet stackable"].table > tr > th:not(.rowspanned),
- .ui[class*="tablet stackable"].table > tbody > tr > td:not(.rowspanned),
- .ui[class*="tablet stackable"].table > tfoot > tr > td:not(.rowspanned),
- .ui[class*="tablet stackable"].table > tr > td:not(.rowspanned) {
- display: block !important;
- width: 100% !important;
- }
-
- .ui[class*="tablet stackable"].table {
- padding: 0;
- }
- .ui[class*="tablet stackable"].table > thead {
- display: @responsiveHeaderDisplay;
- }
- .ui[class*="tablet stackable"].table > tfoot {
- display: @responsiveFooterDisplay;
- }
- .ui.ui.ui.ui[class*="tablet stackable"].table > thead > tr,
- .ui.ui.ui.ui[class*="tablet stackable"].table > tbody > tr,
- .ui.ui.ui.ui[class*="tablet stackable"].table > tfoot > tr,
- .ui.ui.ui.ui[class*="tablet stackable"].table > tr {
- padding-top: @responsiveRowVerticalPadding;
- padding-bottom: @responsiveRowVerticalPadding;
- box-shadow: @responsiveRowBoxShadow;
- }
- .ui[class*="tablet stackable"].table > thead > tr > th,
- .ui[class*="tablet stackable"].table > tbody > tr > th,
- .ui[class*="tablet stackable"].table > tfoot > tr > th,
- .ui[class*="tablet stackable"].table > tr > th,
- .ui[class*="tablet stackable"].table > tbody > tr > td,
- .ui[class*="tablet stackable"].table > tfoot > tr > td,
- .ui[class*="tablet stackable"].table > tr > td {
- background: none;
- border: none !important;
- padding: @responsiveCellVerticalPadding @responsiveCellHorizontalPadding;
- box-shadow: @responsiveCellBoxShadow;
+ /* --------------
+ Stackable
+ --------------- */
+
+ @media only screen and (max-width: @largestTabletScreen) {
+ .ui[class*="tablet stackable"].table,
+ .ui[class*="tablet stackable"].table > thead,
+ .ui[class*="tablet stackable"].table > thead > tr,
+ .ui[class*="tablet stackable"].table > tfoot,
+ .ui[class*="tablet stackable"].table > tfoot > tr,
+ .ui[class*="tablet stackable"].table > tbody,
+ .ui[class*="tablet stackable"].table > tbody > tr,
+ .ui[class*="tablet stackable"].table > tr,
+ .ui[class*="tablet stackable"].table > thead > tr > th:not(.rowspanned),
+ .ui[class*="tablet stackable"].table > tbody > tr > th:not(.rowspanned),
+ .ui[class*="tablet stackable"].table > tfoot > tr > th:not(.rowspanned),
+ .ui[class*="tablet stackable"].table > tr > th:not(.rowspanned),
+ .ui[class*="tablet stackable"].table > tbody > tr > td:not(.rowspanned),
+ .ui[class*="tablet stackable"].table > tfoot > tr > td:not(.rowspanned),
+ .ui[class*="tablet stackable"].table > tr > td:not(.rowspanned) {
+ display: block !important;
+ width: 100% !important;
+ }
+
+ .ui[class*="tablet stackable"].table {
+ padding: 0;
+ }
+ .ui[class*="tablet stackable"].table > thead {
+ display: @responsiveHeaderDisplay;
+ }
+ .ui[class*="tablet stackable"].table > tfoot {
+ display: @responsiveFooterDisplay;
+ }
+ .ui.ui.ui.ui[class*="tablet stackable"].table > thead > tr,
+ .ui.ui.ui.ui[class*="tablet stackable"].table > tbody > tr,
+ .ui.ui.ui.ui[class*="tablet stackable"].table > tfoot > tr,
+ .ui.ui.ui.ui[class*="tablet stackable"].table > tr {
+ padding-top: @responsiveRowVerticalPadding;
+ padding-bottom: @responsiveRowVerticalPadding;
+ box-shadow: @responsiveRowBoxShadow;
+ }
+ .ui[class*="tablet stackable"].table > thead > tr > th,
+ .ui[class*="tablet stackable"].table > tbody > tr > th,
+ .ui[class*="tablet stackable"].table > tfoot > tr > th,
+ .ui[class*="tablet stackable"].table > tr > th,
+ .ui[class*="tablet stackable"].table > tbody > tr > td,
+ .ui[class*="tablet stackable"].table > tfoot > tr > td,
+ .ui[class*="tablet stackable"].table > tr > td {
+ background: none;
+ border: none !important;
+ padding: @responsiveCellVerticalPadding @responsiveCellHorizontalPadding;
+ box-shadow: @responsiveCellBoxShadow;
+ }
+ & when (@variationTableDefinition) {
+ /* Definition Table */
+ .ui.definition[class*="tablet stackable"].table > thead > tr > th:first-child {
+ box-shadow: none !important;
+ }
+ }
}
- & when (@variationTableDefinition) {
- /* Definition Table */
- .ui.definition[class*="tablet stackable"].table > thead > tr > th:first-child {
- box-shadow: none !important;
- }
+ & when (@variationTableMarked) and not (@variationTableColors = false) {
+ each(@variationTableColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+ @l: @colors[@@color][light];
+ .ui.ui.ui.ui[class*="tablet stackable"].table tr[class*="@{color} marked"] {
+ &.left {
+ box-shadow: @responsiveRowBoxShadow, @coloredBorderSize 0 0 0 @c inset;
+ }
+ &.right {
+ box-shadow: @responsiveRowBoxShadow, -@coloredBorderSize 0 0 0 @c inset;
+ }
+ }
+ & when (@variationTableInverted) {
+ .ui.ui.ui.ui[class*="tablet stackable"].inverted.table tr[class*="@{color} marked"] {
+ &.left {
+ box-shadow: @responsiveRowBoxShadow, @coloredBorderSize 0 0 0 @l inset;
+ }
+ &.right {
+ box-shadow: @responsiveRowBoxShadow, -@coloredBorderSize 0 0 0 @l inset;
+ }
+ }
+ }
+ });
}
- }
- & when (@variationTableMarked) and not (@variationTableColors = false) {
- each(@variationTableColors, {
- @color: @value;
- @c: @colors[@@color][color];
- @l: @colors[@@color][light];
- .ui.ui.ui.ui[class*="tablet stackable"].table tr[class*="@{color} marked"] {
- &.left {
- box-shadow: @responsiveRowBoxShadow, @coloredBorderSize 0 0 0 @c inset;
- }
- &.right {
- box-shadow: @responsiveRowBoxShadow, -@coloredBorderSize 0 0 0 @c inset;
- }
- }
- & when (@variationTableInverted) {
- .ui.ui.ui.ui[class*="tablet stackable"].inverted.table tr[class*="@{color} marked"] {
- &.left {
- box-shadow: @responsiveRowBoxShadow, @coloredBorderSize 0 0 0 @l inset;
- }
- &.right {
- box-shadow: @responsiveRowBoxShadow, -@coloredBorderSize 0 0 0 @l inset;
- }
- }
- }
- })
- }
}
& when (@variationTableAligned) {
- /*--------------
- Text Alignment
- ---------------*/
-
- .ui.table[class*="left aligned"],
- .ui.table [class*="left aligned"] {
- text-align: left;
- }
- .ui.table[class*="center aligned"],
- .ui.table [class*="center aligned"] {
- text-align: center;
- }
- .ui.table[class*="right aligned"],
- .ui.table [class*="right aligned"] {
- text-align: right;
- }
-
- /*------------------
- Vertical Alignment
- ------------------*/
-
- .ui.table[class*="top aligned"],
- .ui.table [class*="top aligned"] {
- vertical-align: top;
- }
- .ui.table[class*="middle aligned"],
- .ui.table [class*="middle aligned"] {
- vertical-align: middle;
- }
- .ui.table[class*="bottom aligned"],
- .ui.table [class*="bottom aligned"] {
- vertical-align: bottom;
- }
+ /* --------------
+ Text Alignment
+ --------------- */
+
+ .ui.table[class*="left aligned"],
+ .ui.table [class*="left aligned"] {
+ text-align: left;
+ }
+ .ui.table[class*="center aligned"],
+ .ui.table [class*="center aligned"] {
+ text-align: center;
+ }
+ .ui.table[class*="right aligned"],
+ .ui.table [class*="right aligned"] {
+ text-align: right;
+ }
+
+ /* ------------------
+ Vertical Alignment
+ ------------------ */
+
+ .ui.table[class*="top aligned"],
+ .ui.table [class*="top aligned"] {
+ vertical-align: top;
+ }
+ .ui.table[class*="middle aligned"],
+ .ui.table [class*="middle aligned"] {
+ vertical-align: middle;
+ }
+ .ui.table[class*="bottom aligned"],
+ .ui.table [class*="bottom aligned"] {
+ vertical-align: bottom;
+ }
}
& when (@variationTableCollapsing) {
- /*--------------
- Collapsing
- ---------------*/
+ /* --------------
+ Collapsing
+ --------------- */
- .ui.table th.collapsing,
- .ui.table td.collapsing {
- width: 1px;
- white-space: nowrap;
- }
+ .ui.table th.collapsing,
+ .ui.table td.collapsing {
+ width: 1px;
+ white-space: nowrap;
+ }
}
& when (@variationTableFixed) {
- /*--------------
- Fixed
- ---------------*/
-
- .ui.fixed.table {
- table-layout: fixed;
- }
-
- .ui.fixed.table th,
- .ui.fixed.table td {
- overflow: hidden;
- text-overflow: ellipsis;
- }
-}
+ /* --------------
+ Fixed
+ --------------- */
+ .ui.fixed.table {
+ table-layout: fixed;
+ }
-& when (@variationTableSelectable) {
- /*--------------
- Selectable
- ---------------*/
-
- .ui.ui.selectable.table > tbody > tr:hover,
- .ui.table tbody tr td.selectable:hover {
- background: @selectableBackground;
- color: @selectableTextColor;
- }
- & when (@variationTableInverted) {
- .ui.ui.selectable.inverted.table > tbody > tr:hover,
- .ui.inverted.table tbody tr td.selectable:hover {
- background: @selectableInvertedBackground;
- color: @selectableInvertedTextColor;
- }
- }
- /* Selectable Cell Link */
- .ui.table tbody tr td.selectable {
- padding: 0;
- }
- .ui.table tbody tr td.selectable > a:not(.ui) {
- display: block;
- color: inherit;
- }
- .ui.table:not(.compact) tbody tr td.selectable > a:not(.ui) {
- padding: @cellVerticalPadding @cellHorizontalPadding;
- }
- .ui.table > tr > td.selectable,
- .ui.table > tbody > tr > td.selectable,
- .ui.selectable.table > tbody > tr,
- .ui.selectable.table > tr {
- cursor:pointer;
- }
- & when (@variationTableError) {
- /* Other States */
- .ui.ui.selectable.table tr.error:hover,
- .ui.table tr td.selectable.error:hover,
- .ui.selectable.table tr:hover td.error {
- background: @errorBackgroundHover;
- color: @errorColorHover;
- }
- }
- & when (@variationTableWarning) {
- .ui.ui.selectable.table tr.warning:hover,
- .ui.table tr td.selectable.warning:hover,
- .ui.selectable.table tr:hover td.warning {
- background: @warningBackgroundHover;
- color: @warningColorHover;
- }
- }
- & when (@variationTableActive) {
- .ui.ui.selectable.table tr.active:hover,
- .ui.table tr td.selectable.active:hover,
- .ui.selectable.table tr:hover td.active {
- background: @activeBackgroundColor;
- color: @activeColor;
- }
- }
- & when (@variationTablePositive) {
- .ui.ui.selectable.table tr.positive:hover,
- .ui.table tr td.selectable.positive:hover,
- .ui.selectable.table tr:hover td.positive {
- background: @positiveBackgroundHover;
- color: @positiveColorHover;
- }
- }
- & when (@variationTableNegative) {
- .ui.ui.selectable.table tr.negative:hover,
- .ui.table tr td.selectable.negative:hover,
- .ui.selectable.table tr:hover td.negative {
- background: @negativeBackgroundHover;
- color: @negativeColorHover;
- }
- }
+ .ui.fixed.table th,
+ .ui.fixed.table td {
+ overflow: hidden;
+ text-overflow: ellipsis;
+ }
}
+& when (@variationTableSelectable) {
+ /* --------------
+ Selectable
+ --------------- */
-& when (@variationTableAttached) {
- /*-------------------
- Attached
- --------------------*/
-
- /* Middle */
- .ui.attached.table {
- top: 0;
- bottom: 0;
- border-radius: 0;
- margin: 0 @attachedHorizontalOffset;
- width: @attachedWidth;
- max-width: @attachedWidth;
- box-shadow: @attachedBoxShadow;
- border: @attachedBorder;
- }
- .ui.attached + .ui.attached.table:not(.top) {
- border-top: none;
- }
+ .ui.ui.selectable.table > tbody > tr:hover,
+ .ui.table tbody tr td.selectable:hover {
+ background: @selectableBackground;
+ color: @selectableTextColor;
+ }
+ & when (@variationTableInverted) {
+ .ui.ui.selectable.inverted.table > tbody > tr:hover,
+ .ui.inverted.table tbody tr td.selectable:hover {
+ background: @selectableInvertedBackground;
+ color: @selectableInvertedTextColor;
+ }
+ }
- /* Top */
- .ui[class*="top attached"].table {
- bottom: 0;
- margin-bottom: 0;
- top: @attachedTopOffset;
- margin-top: @verticalMargin;
- border-radius: @borderRadius @borderRadius 0 0;
- }
- .ui.table[class*="top attached"]:first-child {
- margin-top: 0;
- }
+ /* Selectable Cell Link */
+ .ui.table tbody tr td.selectable {
+ padding: 0;
+ }
+ .ui.table tbody tr td.selectable > a:not(.ui) {
+ display: block;
+ color: inherit;
+ }
+ .ui.table:not(.compact) tbody tr td.selectable > a:not(.ui) {
+ padding: @cellVerticalPadding @cellHorizontalPadding;
+ }
+ .ui.table > tr > td.selectable,
+ .ui.table > tbody > tr > td.selectable,
+ .ui.selectable.table > tbody > tr,
+ .ui.selectable.table > tr {
+ cursor: pointer;
+ }
+ & when (@variationTableError) {
+ /* Other States */
+ .ui.ui.selectable.table tr.error:hover,
+ .ui.table tr td.selectable.error:hover,
+ .ui.selectable.table tr:hover td.error {
+ background: @errorBackgroundHover;
+ color: @errorColorHover;
+ }
+ }
+ & when (@variationTableWarning) {
+ .ui.ui.selectable.table tr.warning:hover,
+ .ui.table tr td.selectable.warning:hover,
+ .ui.selectable.table tr:hover td.warning {
+ background: @warningBackgroundHover;
+ color: @warningColorHover;
+ }
+ }
+ & when (@variationTableActive) {
+ .ui.ui.selectable.table tr.active:hover,
+ .ui.table tr td.selectable.active:hover,
+ .ui.selectable.table tr:hover td.active {
+ background: @activeBackgroundColor;
+ color: @activeColor;
+ }
+ }
+ & when (@variationTablePositive) {
+ .ui.ui.selectable.table tr.positive:hover,
+ .ui.table tr td.selectable.positive:hover,
+ .ui.selectable.table tr:hover td.positive {
+ background: @positiveBackgroundHover;
+ color: @positiveColorHover;
+ }
+ }
+ & when (@variationTableNegative) {
+ .ui.ui.selectable.table tr.negative:hover,
+ .ui.table tr td.selectable.negative:hover,
+ .ui.selectable.table tr:hover td.negative {
+ background: @negativeBackgroundHover;
+ color: @negativeColorHover;
+ }
+ }
+}
- /* Bottom */
- .ui[class*="bottom attached"].table {
- bottom: 0;
- margin-top: 0;
- top: @attachedBottomOffset;
- margin-bottom: @verticalMargin;
- box-shadow: @attachedBottomBoxShadow;
- border-radius: 0 0 @borderRadius @borderRadius;
- }
- .ui[class*="bottom attached"].table:last-child {
- margin-bottom: 0;
- }
+& when (@variationTableAttached) {
+ /* -------------------
+ Attached
+ -------------------- */
+
+ /* Middle */
+ .ui.attached.table {
+ top: 0;
+ bottom: 0;
+ border-radius: 0;
+ margin: 0 @attachedHorizontalOffset;
+ width: @attachedWidth;
+ max-width: @attachedWidth;
+ box-shadow: @attachedBoxShadow;
+ border: @attachedBorder;
+ }
+ .ui.attached + .ui.attached.table:not(.top) {
+ border-top: none;
+ }
+
+ /* Top */
+ .ui[class*="top attached"].table {
+ bottom: 0;
+ margin-bottom: 0;
+ top: @attachedTopOffset;
+ margin-top: @verticalMargin;
+ border-radius: @borderRadius @borderRadius 0 0;
+ }
+ .ui.table[class*="top attached"]:first-child {
+ margin-top: 0;
+ }
+
+ /* Bottom */
+ .ui[class*="bottom attached"].table {
+ bottom: 0;
+ margin-top: 0;
+ top: @attachedBottomOffset;
+ margin-bottom: @verticalMargin;
+ box-shadow: @attachedBottomBoxShadow;
+ border-radius: 0 0 @borderRadius @borderRadius;
+ }
+ .ui[class*="bottom attached"].table:last-child {
+ margin-bottom: 0;
+ }
}
& when (@variationTableStriped) {
- /*--------------
- Striped
- ---------------*/
-
- /* Table Striping */
- .ui.striped.table > tr:nth-child(2n),
- .ui.striped.table > tbody > tr:nth-child(2n) {
- background-color: @stripedBackground;
- }
- & when (@variationTableInverted) {
- /* Stripes */
- .ui.inverted.striped.table > tr:nth-child(2n),
- .ui.inverted.striped.table > tbody > tr:nth-child(2n) {
- background-color: @invertedStripedBackground;
- }
- }
- & when (@variationTableSelectable) {
- /* Allow striped active hover */
- .ui.striped.selectable.selectable.selectable.table tbody tr.active:hover {
- background: @activeBackgroundHover;
- color: @activeColorHover;
- }
- }
+ /* --------------
+ Striped
+ --------------- */
+
+ /* Table Striping */
+ .ui.striped.table > tr:nth-child(2n),
+ .ui.striped.table > tbody > tr:nth-child(2n) {
+ background-color: @stripedBackground;
+ }
+ & when (@variationTableInverted) {
+ /* Stripes */
+ .ui.inverted.striped.table > tr:nth-child(2n),
+ .ui.inverted.striped.table > tbody > tr:nth-child(2n) {
+ background-color: @invertedStripedBackground;
+ }
+ }
+ & when (@variationTableSelectable) {
+ /* Allow striped active hover */
+ .ui.striped.selectable.selectable.selectable.table tbody tr.active:hover {
+ background: @activeBackgroundHover;
+ color: @activeColorHover;
+ }
+ }
}
-/*--------------
+/* --------------
Single Line
----------------*/
+--------------- */
.ui.table[class*="single line"],
.ui.table [class*="single line"] {
- white-space: nowrap;
+ white-space: nowrap;
}
-/*-------------------
+/* -------------------
Colors
---------------------*/
+-------------------- */
& when not (@variationTableColors = false) {
- each(@variationTableColors, {
- @color: @value;
- @c: @colors[@@color][color];
- @t: @colors[@@color][text];
- @ht: @colors[@@color][hoverText];
- @l: @colors[@@color][light];
- @lh: @colors[@@color][lightHover];
- @r: @colors[@@color][ribbon];
- @b: @colors[@@color][bright];
- @bh: @colors[@@color][brightHover];
- @isDark: @colors[@@color][isDark];
- @isVeryDark: @colors[@@color][isVeryDark];
-
- .ui.@{color}.table {
- border-top: @coloredBorderSize solid @c;
- }
- & when (@variationTableInverted) {
- .ui.inverted.@{color}.table {
- background: @c;
- color: @white;
- }
- }
- /* Same color for background and color to camouflage the scrollbar */
- & when (@variationTableScrolling) {
- .ui.scrolling.table > thead.@{color},
- .ui.scrolling.table > tfoot.@{color} {
- & when (@isDark) {
- background: @l;
- color: @l;
- }
- & when not (@isDark) {
- background: @b;
- color: @b;
- }
- & > tr > th,
- > tr > td {
- background: inherit;
- & when (@isVeryDark) {
- color: @white;
- }
- & when not (@isVeryDark) {
- color: @t;
- }
- }
- }
- & when (@variationTableInverted) {
- .ui.inverted.scrolling.table > thead.@{color},
- .ui.inverted.scrolling.table > tfoot.@{color} {
- background: @c;
- color: @c;
- & > tr > th,
- > tr > td {
+ each(@variationTableColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+ @t: @colors[@@color][text];
+ @ht: @colors[@@color][hoverText];
+ @l: @colors[@@color][light];
+ @lh: @colors[@@color][lightHover];
+ @r: @colors[@@color][ribbon];
+ @b: @colors[@@color][bright];
+ @bh: @colors[@@color][brightHover];
+ @isDark: @colors[@@color][isDark];
+ @isVeryDark: @colors[@@color][isVeryDark];
+
+ .ui.@{color}.table {
+ border-top: @coloredBorderSize solid @c;
+ }
+ & when (@variationTableInverted) {
+ .ui.inverted.@{color}.table {
+ background: @c;
+ color: @white;
+ }
+ }
+ /* Same color for background and color to camouflage the scrollbar */
+ & when (@variationTableScrolling) {
+ .ui.scrolling.table > thead.@{color},
+ .ui.scrolling.table > tfoot.@{color} {
+ & when (@isDark) {
+ background: @l;
+ color: @l;
+ }
+ & when not (@isDark) {
+ background: @b;
+ color: @b;
+ }
+ & > tr > th,
+ > tr > td {
+ background: inherit;
+ & when (@isVeryDark) {
+ color: @white;
+ }
+ & when not (@isVeryDark) {
+ color: @t;
+ }
+ }
+ }
+ & when (@variationTableInverted) {
+ .ui.inverted.scrolling.table > thead.@{color},
+ .ui.inverted.scrolling.table > tfoot.@{color} {
+ background: @c;
+ color: @c;
+ & > tr > th,
+ > tr > td {
+ background: inherit;
+ color: @white;
+ }
+ }
+ }
+ }
+ .ui.ui.ui.ui.table tr[class*="@{color} colored"],
+ .ui.ui.table th[class*="@{color} colored"],
+ .ui.ui.table td[class*="@{color} colored"],
+ .ui.ui.ui.ui.table tr.@{color}:not(.marked),
+ .ui.ui.table th.@{color}:not(.marked),
+ .ui.ui.table td.@{color}:not(.marked) {
+ & when (@stateMarkerWidth > 0) {
+ box-shadow: @stateMarkerWidth 0 0 @r inset;
+ }
+ & when (@isDark) {
+ background: @l;
+ }
+ & when not (@isDark) {
+ background: @b;
+ }
+ & when (@isVeryDark) {
+ color: @white;
+ }
+ & when not (@isVeryDark) {
+ color: @t;
+ }
+ }
+ .ui.table > thead > tr[class*="@{color} colored"] > th,
+ .ui.table > tfoot > tr[class*="@{color} colored"] > th,
+ .ui.table > tfoot > tr[class*="@{color} colored"] > td,
+ .ui.table > thead > tr.@{color}:not(.marked) > th,
+ .ui.table > tfoot > tr.@{color}:not(.marked) > th,
+ .ui.table > tfoot > tr.@{color}:not(.marked) > td {
background: inherit;
- color: @white;
- }
- }
- }
- }
- .ui.ui.ui.ui.table tr[class*="@{color} colored"],
- .ui.ui.table th[class*="@{color} colored"],
- .ui.ui.table td[class*="@{color} colored"],
- .ui.ui.ui.ui.table tr.@{color}:not(.marked),
- .ui.ui.table th.@{color}:not(.marked),
- .ui.ui.table td.@{color}:not(.marked) {
- & when (@stateMarkerWidth > 0) {
- box-shadow: @stateMarkerWidth 0 0 @r inset;
- }
- & when (@isDark) {
- background: @l;
- }
- & when not (@isDark) {
- background: @b;
- }
- & when (@isVeryDark) {
- color: @white;
- }
- & when not (@isVeryDark) {
- color: @t;
- }
- }
- .ui.table > thead > tr[class*="@{color} colored"] > th,
- .ui.table > tfoot > tr[class*="@{color} colored"] > th,
- .ui.table > tfoot > tr[class*="@{color} colored"] > td,
- .ui.table > thead > tr.@{color}:not(.marked) > th,
- .ui.table > tfoot > tr.@{color}:not(.marked) > th,
- .ui.table > tfoot > tr.@{color}:not(.marked) > td {
- background: inherit;
- & when (@isVeryDark) {
- color: @white;
- }
- & when not (@isVeryDark) {
- color: @t;
- }
- }
+ & when (@isVeryDark) {
+ color: @white;
+ }
+ & when not (@isVeryDark) {
+ color: @t;
+ }
+ }
- & when (@variationTableInverted) {
- .ui.ui.ui.ui.inverted.table tr[class*="@{color} colored"],
- .ui.ui.inverted.table th[class*="@{color} colored"],
- .ui.ui.inverted.table td[class*="@{color} colored"],
- .ui.ui.ui.ui.inverted.table tr.@{color}:not(.marked),
- .ui.ui.inverted.table th.@{color}:not(.marked),
- .ui.ui.inverted.table td.@{color}:not(.marked) {
- background: @c;
- color: @white;
- }
- .ui.inverted.table > thead > tr[class*="@{color} colored"] > th,
- .ui.inverted.table > tfoot > tr[class*="@{color} colored"] > th,
- .ui.inverted.table > tfoot > tr[class*="@{color} colored"] > td,
- .ui.inverted.table > thead > tr.@{color}:not(.marked) > th,
- .ui.inverted.table > tfoot > tr.@{color}:not(.marked) > th,
- .ui.inverted.table > tfoot > tr.@{color}:not(.marked) > td {
- background: inherit;
- color: @white;
- }
- }
- & when (@variationTableSelectable) {
- .ui.ui.selectable.table tr[class*="@{color} colored"]:hover,
- .ui.table tr td.selectable[class*="@{color} colored"]:hover,
- .ui.selectable.table tr:hover td[class*="@{color} colored"],
- .ui.ui.selectable.table tr.@{color}:not(.marked):hover,
- .ui.table tr td.selectable.@{color}:not(.marked):hover,
- .ui.selectable.table tr:hover td.@{color}:not(.marked) {
- & when (@isDark) {
- background: @lh;
- }
- & when not (@isDark) {
- background: @bh;
- }
- & when (@isVeryDark) {
- color: @white;
- }
- & when not (@isVeryDark) {
- color: @ht;
- }
- }
- & when (@variationTableInverted) {
- .ui.ui.inverted.selectable.table tr[class*="@{color} colored"]:hover,
- .ui.inverted.table tr td.selectable[class*="@{color} colored"]:hover,
- .ui.inverted.selectable.table tr:hover td[class*="@{color} colored"],
- .ui.ui.inverted.selectable.table tr.@{color}:not(.marked):hover,
- .ui.inverted.table tr td.selectable.@{color}:not(.marked):hover,
- .ui.inverted.selectable.table tr:hover td.@{color}:not(.marked) {
- & when (@isDark) {
- background: @bh;
- }
- & when not (@isDark) {
- background: @lh;
- }
- & when (@isVeryDark) {
- color: @ht;
- }
- & when not (@isVeryDark) {
- color: @white;
- }
- }
- }
- }
- & when (@variationTableMarked) {
- .ui.table td[class*="@{color} marked"],
- .ui.table tr[class*="@{color} marked"] {
- &.left {
- box-shadow: @coloredBorderSize 0 0 0 @c inset;
- }
- &.right {
- box-shadow: -@coloredBorderSize 0 0 0 @c inset;
- }
- }
- & when (@variationTableInverted) {
- .ui.inverted.table td[class*="@{color} marked"],
- .ui.inverted.table tr[class*="@{color} marked"] {
- &.left {
- box-shadow: @coloredBorderSize 0 0 0 @l inset;
- }
- &.right {
- box-shadow: -@coloredBorderSize 0 0 0 @l inset;
- }
- }
- }
- }
-
- })
+ & when (@variationTableInverted) {
+ .ui.ui.ui.ui.inverted.table tr[class*="@{color} colored"],
+ .ui.ui.inverted.table th[class*="@{color} colored"],
+ .ui.ui.inverted.table td[class*="@{color} colored"],
+ .ui.ui.ui.ui.inverted.table tr.@{color}:not(.marked),
+ .ui.ui.inverted.table th.@{color}:not(.marked),
+ .ui.ui.inverted.table td.@{color}:not(.marked) {
+ background: @c;
+ color: @white;
+ }
+ .ui.inverted.table > thead > tr[class*="@{color} colored"] > th,
+ .ui.inverted.table > tfoot > tr[class*="@{color} colored"] > th,
+ .ui.inverted.table > tfoot > tr[class*="@{color} colored"] > td,
+ .ui.inverted.table > thead > tr.@{color}:not(.marked) > th,
+ .ui.inverted.table > tfoot > tr.@{color}:not(.marked) > th,
+ .ui.inverted.table > tfoot > tr.@{color}:not(.marked) > td {
+ background: inherit;
+ color: @white;
+ }
+ }
+ & when (@variationTableSelectable) {
+ .ui.ui.selectable.table tr[class*="@{color} colored"]:hover,
+ .ui.table tr td.selectable[class*="@{color} colored"]:hover,
+ .ui.selectable.table tr:hover td[class*="@{color} colored"],
+ .ui.ui.selectable.table tr.@{color}:not(.marked):hover,
+ .ui.table tr td.selectable.@{color}:not(.marked):hover,
+ .ui.selectable.table tr:hover td.@{color}:not(.marked) {
+ & when (@isDark) {
+ background: @lh;
+ }
+ & when not (@isDark) {
+ background: @bh;
+ }
+ & when (@isVeryDark) {
+ color: @white;
+ }
+ & when not (@isVeryDark) {
+ color: @ht;
+ }
+ }
+ & when (@variationTableInverted) {
+ .ui.ui.inverted.selectable.table tr[class*="@{color} colored"]:hover,
+ .ui.inverted.table tr td.selectable[class*="@{color} colored"]:hover,
+ .ui.inverted.selectable.table tr:hover td[class*="@{color} colored"],
+ .ui.ui.inverted.selectable.table tr.@{color}:not(.marked):hover,
+ .ui.inverted.table tr td.selectable.@{color}:not(.marked):hover,
+ .ui.inverted.selectable.table tr:hover td.@{color}:not(.marked) {
+ & when (@isDark) {
+ background: @bh;
+ }
+ & when not (@isDark) {
+ background: @lh;
+ }
+ & when (@isVeryDark) {
+ color: @ht;
+ }
+ & when not (@isVeryDark) {
+ color: @white;
+ }
+ }
+ }
+ }
+ & when (@variationTableMarked) {
+ .ui.table td[class*="@{color} marked"],
+ .ui.table tr[class*="@{color} marked"] {
+ &.left {
+ box-shadow: @coloredBorderSize 0 0 0 @c inset;
+ }
+ &.right {
+ box-shadow: -@coloredBorderSize 0 0 0 @c inset;
+ }
+ }
+ & when (@variationTableInverted) {
+ .ui.inverted.table td[class*="@{color} marked"],
+ .ui.inverted.table tr[class*="@{color} marked"] {
+ &.left {
+ box-shadow: @coloredBorderSize 0 0 0 @l inset;
+ }
+ &.right {
+ box-shadow: -@coloredBorderSize 0 0 0 @l inset;
+ }
+ }
+ }
+ }
+
+ });
}
& when (@variationTableEqualWidth) {
- /*--------------
- Column Count
- ---------------*/
-
- /* Grid Based */
- .ui.one.column.table td {
- width: @oneColumn;
- }
- .ui.two.column.table td {
- width: @twoColumn;
- }
- .ui.three.column.table td {
- width: @threeColumn;
- }
- .ui.four.column.table td {
- width: @fourColumn;
- }
- .ui.five.column.table td {
- width: @fiveColumn;
- }
- .ui.six.column.table td {
- width: @sixColumn;
- }
- .ui.seven.column.table td {
- width: @sevenColumn;
- }
- .ui.eight.column.table td {
- width: @eightColumn;
- }
- .ui.nine.column.table td {
- width: @nineColumn;
- }
- .ui.ten.column.table td {
- width: @tenColumn;
- }
- .ui.eleven.column.table td {
- width: @elevenColumn;
- }
- .ui.twelve.column.table td {
- width: @twelveColumn;
- }
- .ui.thirteen.column.table td {
- width: @thirteenColumn;
- }
- .ui.fourteen.column.table td {
- width: @fourteenColumn;
- }
- .ui.fifteen.column.table td {
- width: @fifteenColumn;
- }
- .ui.sixteen.column.table td {
- width: @sixteenColumn;
- }
+ /* --------------
+ Column Count
+ --------------- */
+
+ /* Grid Based */
+ .ui.one.column.table td {
+ width: @oneColumn;
+ }
+ .ui.two.column.table td {
+ width: @twoColumn;
+ }
+ .ui.three.column.table td {
+ width: @threeColumn;
+ }
+ .ui.four.column.table td {
+ width: @fourColumn;
+ }
+ .ui.five.column.table td {
+ width: @fiveColumn;
+ }
+ .ui.six.column.table td {
+ width: @sixColumn;
+ }
+ .ui.seven.column.table td {
+ width: @sevenColumn;
+ }
+ .ui.eight.column.table td {
+ width: @eightColumn;
+ }
+ .ui.nine.column.table td {
+ width: @nineColumn;
+ }
+ .ui.ten.column.table td {
+ width: @tenColumn;
+ }
+ .ui.eleven.column.table td {
+ width: @elevenColumn;
+ }
+ .ui.twelve.column.table td {
+ width: @twelveColumn;
+ }
+ .ui.thirteen.column.table td {
+ width: @thirteenColumn;
+ }
+ .ui.fourteen.column.table td {
+ width: @fourteenColumn;
+ }
+ .ui.fifteen.column.table td {
+ width: @fifteenColumn;
+ }
+ .ui.sixteen.column.table td {
+ width: @sixteenColumn;
+ }
}
& when (@variationTableWide) {
- /* Column Width */
- .ui.table th.one.wide,
- .ui.table td.one.wide {
- width: @oneWide;
- }
- .ui.table th.two.wide,
- .ui.table td.two.wide {
- width: @twoWide;
- }
- .ui.table th.three.wide,
- .ui.table td.three.wide {
- width: @threeWide;
- }
- .ui.table th.four.wide,
- .ui.table td.four.wide {
- width: @fourWide;
- }
- .ui.table th.five.wide,
- .ui.table td.five.wide {
- width: @fiveWide;
- }
- .ui.table th.six.wide,
- .ui.table td.six.wide {
- width: @sixWide;
- }
- .ui.table th.seven.wide,
- .ui.table td.seven.wide {
- width: @sevenWide;
- }
- .ui.table th.eight.wide,
- .ui.table td.eight.wide {
- width: @eightWide;
- }
- .ui.table th.nine.wide,
- .ui.table td.nine.wide {
- width: @nineWide;
- }
- .ui.table th.ten.wide,
- .ui.table td.ten.wide {
- width: @tenWide;
- }
- .ui.table th.eleven.wide,
- .ui.table td.eleven.wide {
- width: @elevenWide;
- }
- .ui.table th.twelve.wide,
- .ui.table td.twelve.wide {
- width: @twelveWide;
- }
- .ui.table th.thirteen.wide,
- .ui.table td.thirteen.wide {
- width: @thirteenWide;
- }
- .ui.table th.fourteen.wide,
- .ui.table td.fourteen.wide {
- width: @fourteenWide;
- }
- .ui.table th.fifteen.wide,
- .ui.table td.fifteen.wide {
- width: @fifteenWide;
- }
- .ui.table th.sixteen.wide,
- .ui.table td.sixteen.wide {
- width: @sixteenWide;
- }
+ /* Column Width */
+ .ui.table th.one.wide,
+ .ui.table td.one.wide {
+ width: @oneWide;
+ }
+ .ui.table th.two.wide,
+ .ui.table td.two.wide {
+ width: @twoWide;
+ }
+ .ui.table th.three.wide,
+ .ui.table td.three.wide {
+ width: @threeWide;
+ }
+ .ui.table th.four.wide,
+ .ui.table td.four.wide {
+ width: @fourWide;
+ }
+ .ui.table th.five.wide,
+ .ui.table td.five.wide {
+ width: @fiveWide;
+ }
+ .ui.table th.six.wide,
+ .ui.table td.six.wide {
+ width: @sixWide;
+ }
+ .ui.table th.seven.wide,
+ .ui.table td.seven.wide {
+ width: @sevenWide;
+ }
+ .ui.table th.eight.wide,
+ .ui.table td.eight.wide {
+ width: @eightWide;
+ }
+ .ui.table th.nine.wide,
+ .ui.table td.nine.wide {
+ width: @nineWide;
+ }
+ .ui.table th.ten.wide,
+ .ui.table td.ten.wide {
+ width: @tenWide;
+ }
+ .ui.table th.eleven.wide,
+ .ui.table td.eleven.wide {
+ width: @elevenWide;
+ }
+ .ui.table th.twelve.wide,
+ .ui.table td.twelve.wide {
+ width: @twelveWide;
+ }
+ .ui.table th.thirteen.wide,
+ .ui.table td.thirteen.wide {
+ width: @thirteenWide;
+ }
+ .ui.table th.fourteen.wide,
+ .ui.table td.fourteen.wide {
+ width: @fourteenWide;
+ }
+ .ui.table th.fifteen.wide,
+ .ui.table td.fifteen.wide {
+ width: @fifteenWide;
+ }
+ .ui.table th.sixteen.wide,
+ .ui.table td.sixteen.wide {
+ width: @sixteenWide;
+ }
}
& when (@variationTableSortable) {
- /*--------------
- Sortable
- ---------------*/
+ /* --------------
+ Sortable
+ --------------- */
+
+ .ui.sortable.table > thead > tr > th {
+ cursor: pointer;
+ white-space: nowrap;
+ color: @sortableColor;
+ }
+ & when (@variationTableCelled) {
+ .ui.celled.sortable.table > thead > tr > th:not(:first-child) {
+ border-left: @sortableBorder;
+ }
+ }
+ .ui.sortable.table thead th.sorted,
+ .ui.sortable.table thead th.sorted:hover {
+ user-select: none;
+ }
- .ui.sortable.table > thead > tr > th {
- cursor: pointer;
- white-space: nowrap;
- color: @sortableColor;
- }
- & when (@variationTableCelled) {
- .ui.celled.sortable.table > thead > tr > th:not(:first-child) {
- border-left: @sortableBorder;
- }
- }
- .ui.sortable.table thead th.sorted,
- .ui.sortable.table thead th.sorted:hover {
- user-select: none;
- }
-
- .ui.sortable.table > thead > tr > th::after {
- display: none;
- font-style: normal;
- font-weight: @normal;
- text-decoration: inherit;
- content: '';
- height: 1em;
- width: @sortableIconWidth;
- opacity: @sortableIconOpacity;
- margin: 0 0 0 @sortableIconDistance;
- font-family: @sortableIconFont;
- }
- .ui.sortable.table thead th.ascending::after {
- content: @sortableIconAscending;
- }
- .ui.sortable.table thead th.descending::after {
- content: @sortableIconDescending;
- }
-
- & when (@variationTableDisabled) {
- /* Hover */
- .ui.sortable.table th.disabled:hover {
- cursor: auto;
- color: @sortableDisabledColor;
- }
- }
- .ui.sortable.table > thead > tr > th:hover {
- color: @sortableHoverColor;
- }
- .ui.sortable.table:not(.basic) > thead > tr > th:hover {
- background: @sortableHoverBackground;
- }
-
- /* Sorted */
- .ui.sortable.table thead th.sorted {
- color: @sortableActiveColor;
- }
- .ui.sortable.table:not(.basic) thead th.sorted {
- background: @sortableActiveBackground;
- }
- .ui.sortable.table thead th.sorted::after {
- display: inline-block;
- }
-
- /* Sorted Hover */
- .ui.sortable.table thead th.sorted:hover {
- color: @sortableActiveHoverColor;
- }
- .ui.sortable.table:not(.basic) thead th.sorted:hover {
- background: @sortableActiveHoverBackground;
- }
- & when (@variationTableInverted) {
- /* Inverted */
- .ui.inverted.sortable.table thead th.sorted {
- color: @sortableInvertedActiveColor;
- }
- .ui.inverted.sortable.table:not(.basic) thead th.sorted {
- background: @sortableInvertedActiveBackground;
- }
- .ui.inverted.sortable.table > thead > tr > th:hover {
- color: @sortableInvertedHoverColor;
- }
- .ui.inverted.sortable.table:not(.basic) > thead > tr > th:hover {
- background: @sortableInvertedHoverBackground;
- }
- .ui.inverted.sortable.table:not(.basic) > thead > tr > th {
- border-left-color: @sortableInvertedBorderColor;
- border-right-color: @sortableInvertedBorderColor;
- }
- }
+ .ui.sortable.table > thead > tr > th::after {
+ display: none;
+ font-style: normal;
+ font-weight: @normal;
+ text-decoration: inherit;
+ content: "";
+ height: 1em;
+ width: @sortableIconWidth;
+ opacity: @sortableIconOpacity;
+ margin: 0 0 0 @sortableIconDistance;
+ font-family: @sortableIconFont;
+ }
+ .ui.sortable.table thead th.ascending::after {
+ content: @sortableIconAscending;
+ }
+ .ui.sortable.table thead th.descending::after {
+ content: @sortableIconDescending;
+ }
+
+ & when (@variationTableDisabled) {
+ /* Hover */
+ .ui.sortable.table th.disabled:hover {
+ cursor: auto;
+ color: @sortableDisabledColor;
+ }
+ }
+ .ui.sortable.table > thead > tr > th:hover {
+ color: @sortableHoverColor;
+ }
+ .ui.sortable.table:not(.basic) > thead > tr > th:hover {
+ background: @sortableHoverBackground;
+ }
+
+ /* Sorted */
+ .ui.sortable.table thead th.sorted {
+ color: @sortableActiveColor;
+ }
+ .ui.sortable.table:not(.basic) thead th.sorted {
+ background: @sortableActiveBackground;
+ }
+ .ui.sortable.table thead th.sorted::after {
+ display: inline-block;
+ }
+
+ /* Sorted Hover */
+ .ui.sortable.table thead th.sorted:hover {
+ color: @sortableActiveHoverColor;
+ }
+ .ui.sortable.table:not(.basic) thead th.sorted:hover {
+ background: @sortableActiveHoverBackground;
+ }
+ & when (@variationTableInverted) {
+ /* Inverted */
+ .ui.inverted.sortable.table thead th.sorted {
+ color: @sortableInvertedActiveColor;
+ }
+ .ui.inverted.sortable.table:not(.basic) thead th.sorted {
+ background: @sortableInvertedActiveBackground;
+ }
+ .ui.inverted.sortable.table > thead > tr > th:hover {
+ color: @sortableInvertedHoverColor;
+ }
+ .ui.inverted.sortable.table:not(.basic) > thead > tr > th:hover {
+ background: @sortableInvertedHoverBackground;
+ }
+ .ui.inverted.sortable.table:not(.basic) > thead > tr > th {
+ border-left-color: @sortableInvertedBorderColor;
+ border-right-color: @sortableInvertedBorderColor;
+ }
+ }
}
& when (@variationTableInverted) {
- /*--------------
- Inverted
- ---------------*/
-
- /* Text Color */
- .ui.inverted.table {
- background: @invertedBackground;
- color: @invertedCellColor;
- border: @invertedBorder;
- }
- .ui.ui.inverted.table > thead > tr > th,
- .ui.ui.inverted.table > tbody > tr > th,
- .ui.ui.inverted.table > tr > th {
- background-color: @invertedHeaderBackground;
- border-color: @invertedHeaderBorderColor;
- color: @invertedHeaderColor;
- }
- .ui.ui.inverted.table > tfoot > tr > th,
- .ui.ui.inverted.table > tfoot > tr > td {
- background-color: @invertedFooterBackground;
- border-color: @invertedFooterBorderColor;
- color: @invertedFooterColor;
- }
- .ui.inverted.table > tbody > tr > td,
- .ui.inverted.table > tfoot > tr > td,
- .ui.inverted.table > tr > td {
- border-color: @invertedCellBorderColor;
- }
- & when (@variationTableDisabled) {
- .ui.inverted.table tr.disabled td,
- .ui.inverted.table tr td.disabled,
- .ui.inverted.table tr.disabled:hover td,
- .ui.inverted.table tr:hover td.disabled {
- pointer-events: none;
- color: @invertedDisabledTextColor;
- }
- .ui.ui.ui.inverted.table tr td.disabled:not([class="disabled"]),
- .ui.inverted.table tr.disabled:not([class="disabled"]) td,
- .ui.inverted.table tr.disabled td[class]:not(.disabled),
- .ui.inverted.table tr:hover td.disabled:not([class="disabled"]) {
- color: @disabledTextColor;
- }
- }
- & when (@variationTableDefinition) {
- /* Definition */
- .ui.inverted.definition.table > tfoot:not(.full-width) > tr > th:first-child,
- .ui.inverted.definition.table > thead:not(.full-width) > tr > th:first-child {
- background: @definitionPageBackground;
- }
- .ui.inverted.definition.table > tbody > tr > td:first-child,
- .ui.inverted.definition.table > tfoot > tr > td:first-child,
- .ui.inverted.definition.table > tr > td:first-child {
- background: @invertedDefinitionColumnBackground;
- color: @invertedDefinitionColumnColor;
- }
- }
+ /* --------------
+ Inverted
+ --------------- */
+
+ /* Text Color */
+ .ui.inverted.table {
+ background: @invertedBackground;
+ color: @invertedCellColor;
+ border: @invertedBorder;
+ }
+ .ui.ui.inverted.table > thead > tr > th,
+ .ui.ui.inverted.table > tbody > tr > th,
+ .ui.ui.inverted.table > tr > th {
+ background-color: @invertedHeaderBackground;
+ border-color: @invertedHeaderBorderColor;
+ color: @invertedHeaderColor;
+ }
+ .ui.ui.inverted.table > tfoot > tr > th,
+ .ui.ui.inverted.table > tfoot > tr > td {
+ background-color: @invertedFooterBackground;
+ border-color: @invertedFooterBorderColor;
+ color: @invertedFooterColor;
+ }
+ .ui.inverted.table > tbody > tr > td,
+ .ui.inverted.table > tfoot > tr > td,
+ .ui.inverted.table > tr > td {
+ border-color: @invertedCellBorderColor;
+ }
+ & when (@variationTableDisabled) {
+ .ui.ui.ui.inverted.table tr.disabled td,
+ .ui.ui.ui.inverted.table tr td.disabled,
+ .ui.inverted.table tr.disabled:hover td,
+ .ui.inverted.table tr:hover td.disabled {
+ pointer-events: none;
+ color: @invertedDisabledTextColor;
+ }
+ .ui.ui.ui.inverted.table tr td.disabled:not([class="disabled"]),
+ .ui.inverted.table tr.disabled:not([class="disabled"]) td,
+ .ui.inverted.table tr.disabled td[class]:not(.disabled),
+ .ui.inverted.table tr:hover td.disabled:not([class="disabled"]) {
+ color: @disabledTextColor;
+ }
+ }
+ & when (@variationTableDefinition) {
+ /* Definition */
+ .ui.inverted.definition.table > tfoot:not(.full-width) > tr > th:first-child,
+ .ui.inverted.definition.table > thead:not(.full-width) > tr > th:first-child {
+ background: @definitionPageBackground;
+ }
+ .ui.inverted.definition.table > tbody > tr > td:first-child,
+ .ui.inverted.definition.table > tfoot > tr > td:first-child,
+ .ui.inverted.definition.table > tr > td:first-child {
+ background: @invertedDefinitionColumnBackground;
+ color: @invertedDefinitionColumnColor;
+ }
+ }
}
& when (@variationTableCollapsing) {
- /*--------------
- Collapsing
- ---------------*/
+ /* --------------
+ Collapsing
+ --------------- */
- .ui.collapsing.table {
- width: auto;
- }
+ .ui.collapsing.table {
+ width: auto;
+ }
}
-& when (@variationTableBasic) or (@variationTableVeryBasic){
- /*--------------
- Basic
- ---------------*/
-
- .ui.basic.table {
- background: @basicTableBackground;
- border: @basicTableBorder;
- box-shadow: @basicBoxShadow;
- }
- .ui.basic.table > thead,
- .ui.basic.table > tfoot {
- box-shadow: none;
- }
- .ui.basic.table > thead > tr > th,
- .ui.basic.table > tbody > tr > th,
- .ui.basic.table > tfoot > tr > th,
- .ui.basic.table > tr > th {
- background: @basicTableHeaderBackground;
- border-left: @basicTableHeaderDivider;
- }
- .ui.basic.table > tbody > tr {
- border-bottom: @basicTableCellBorder;
- }
- .ui.basic.table > tbody > tr > td,
- .ui.basic.table > tfoot > tr > td,
- .ui.basic.table >tr > td {
- background: @basicTableCellBackground;
- }
- & when (@variationTableStriped) {
- .ui.basic.striped.table > tbody > tr:nth-child(2n) {
- background-color: @basicTableStripedBackground;
- }
- }
- & when (@variationTableVeryBasic) {
- /* Very Basic */
- .ui[class*="very basic"].table {
- border: none;
- }
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tr > th,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > thead > tr > th,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tbody > tr > th,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tfoot > tr > th,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tr > td,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tbody > tr > td {
- padding: @basicTableCellPadding;
- }
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tr > th:first-child,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > thead > tr > th:first-child,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tbody > tr > th:first-child,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tfoot > tr > th:first-child,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tr > td:first-child,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tbody > tr > td:first-child,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tfoot > tr > td:first-child {
- padding-left: 0;
- }
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tr > th:last-child,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > thead > tr > th:last-child,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tbody > tr > th:last-child,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tfoot > tr > th:last-child,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tr > td:last-child,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tbody > tr > td:last-child,
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > tfoot > tr > td:last-child {
- padding-right: 0;
- }
- .ui[class*="very basic"].table:not(.sortable):not(.striped) > thead > tr:first-child > th {
- padding-top: 0;
- }
- }
+& when (@variationTableBasic) or (@variationTableVeryBasic) {
+ /* --------------
+ Basic
+ --------------- */
+
+ .ui.basic.table {
+ background: @basicTableBackground;
+ border: @basicTableBorder;
+ box-shadow: @basicBoxShadow;
+ }
+ .ui.basic.table > thead,
+ .ui.basic.table > tfoot {
+ box-shadow: none;
+ }
+ .ui.basic.table > thead > tr > th,
+ .ui.basic.table > tbody > tr > th,
+ .ui.basic.table > tfoot > tr > th,
+ .ui.basic.table > tr > th {
+ background: @basicTableHeaderBackground;
+ border-left: @basicTableHeaderDivider;
+ }
+ .ui.basic.table > tbody > tr {
+ border-bottom: @basicTableCellBorder;
+ }
+ .ui.basic.table > tbody > tr > td,
+ .ui.basic.table > tfoot > tr > td,
+ .ui.basic.table > tr > td {
+ background: @basicTableCellBackground;
+ }
+ & when (@variationTableStriped) {
+ .ui.basic.striped.table > tbody > tr:nth-child(2n) {
+ background-color: @basicTableStripedBackground;
+ }
+ }
+ & when (@variationTableVeryBasic) {
+ /* Very Basic */
+ .ui[class*="very basic"].table {
+ border: none;
+ }
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tr > th,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > thead > tr > th,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tbody > tr > th,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tfoot > tr > th,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tr > td,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tbody > tr > td {
+ padding: @basicTableCellPadding;
+ }
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tr > th:first-child,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > thead > tr > th:first-child,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tbody > tr > th:first-child,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tfoot > tr > th:first-child,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tr > td:first-child,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tbody > tr > td:first-child,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tfoot > tr > td:first-child {
+ padding-left: 0;
+ }
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tr > th:last-child,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > thead > tr > th:last-child,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tbody > tr > th:last-child,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tfoot > tr > th:last-child,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tr > td:last-child,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tbody > tr > td:last-child,
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > tfoot > tr > td:last-child {
+ padding-right: 0;
+ }
+ .ui[class*="very basic"].table:not(.sortable):not(.striped) > thead > tr:first-child > th {
+ padding-top: 0;
+ }
+ }
}
& when (@variationTableCelled) {
- /*--------------
- Celled
- ---------------*/
-
- .ui.celled.table > tr > th,
- .ui.celled.table > thead > tr > th,
- .ui.celled.table > tbody > tr > th,
- .ui.celled.table > tfoot > tr > th,
- .ui.celled.table > tr > td,
- .ui.celled.table > tbody > tr > td ,
- .ui.celled.table > tfoot > tr > td {
- border-left: @cellBorder;
- }
- & when (@variationTableInverted) {
- .ui.inverted.celled.table > tbody > tr > td,
- .ui.inverted.celled.table > tr > td {
- border-left: @invertedCellBorder;
- }
- }
- .ui.celled.table > tr > th:first-child,
- .ui.celled.table > thead > tr > th:first-child,
- .ui.celled.table > tbody > tr > th:first-child,
- .ui.celled.table > tfoot > tr > th:first-child,
- .ui.celled.table > tr > td:first-child,
- .ui.celled.table > tbody > tr > td:first-child,
- .ui.celled.table > tfoot >tr > td:first-child {
- border-left: none;
- }
+ /* --------------
+ Celled
+ --------------- */
+
+ .ui.celled.table > tr > th,
+ .ui.celled.table > thead > tr > th,
+ .ui.celled.table > tbody > tr > th,
+ .ui.celled.table > tfoot > tr > th,
+ .ui.celled.table > tr > td,
+ .ui.celled.table > tbody > tr > td,
+ .ui.celled.table > tfoot > tr > td {
+ border-left: @cellBorder;
+ }
+ & when (@variationTableInverted) {
+ .ui.inverted.celled.table > tbody > tr > td,
+ .ui.inverted.celled.table > tr > td {
+ border-left: @invertedCellBorder;
+ }
+ }
+ .ui.celled.table > tr > th:first-child,
+ .ui.celled.table > thead > tr > th:first-child,
+ .ui.celled.table > tbody > tr > th:first-child,
+ .ui.celled.table > tfoot > tr > th:first-child,
+ .ui.celled.table > tr > td:first-child,
+ .ui.celled.table > tbody > tr > td:first-child,
+ .ui.celled.table > tfoot > tr > td:first-child {
+ border-left: none;
+ }
}
& when (@variationTablePadded) or (@variationTableVeryPadded) {
- /*--------------
- Padded
- ---------------*/
-
- .ui.padded.table > tr > th,
- .ui.padded.table > thead > tr > th,
- .ui.padded.table > tbody > tr > th,
- .ui.padded.table > tfoot > tr > th {
- padding-left: @paddedHorizontalPadding;
- padding-right: @paddedHorizontalPadding;
- }
- .ui.padded.table > tr > th,
- .ui.padded.table > thead > tr > th,
- .ui.padded.table > tbody > tr > th,
- .ui.padded.table > tfoot > tr > th,
- .ui.padded.table > tr > td,
- .ui.padded.table > tbody > tr > td ,
- .ui.padded.table > tfoot > tr > td {
- padding: @paddedVerticalPadding @paddedHorizontalPadding;
- }
-
- & when (@variationTableVeryPadded) {
- /* Very */
- .ui[class*="very padded"].table > tr > th,
- .ui[class*="very padded"].table > thead > tr > th,
- .ui[class*="very padded"].table > tbody > tr > th,
- .ui[class*="very padded"].table > tfoot > tr > th {
- padding-left: @veryPaddedHorizontalPadding;
- padding-right: @veryPaddedHorizontalPadding;
- }
- .ui[class*="very padded"].table > tr > td,
- .ui[class*="very padded"].table > tbody > tr > td,
- .ui[class*="very padded"].table > tfoot > tr > td {
- padding: @veryPaddedVerticalPadding @veryPaddedHorizontalPadding;
- }
- }
+ /* --------------
+ Padded
+ --------------- */
+
+ .ui.padded.table > tr > th,
+ .ui.padded.table > thead > tr > th,
+ .ui.padded.table > tbody > tr > th,
+ .ui.padded.table > tfoot > tr > th {
+ padding-left: @paddedHorizontalPadding;
+ padding-right: @paddedHorizontalPadding;
+ }
+ .ui.padded.table > tr > th,
+ .ui.padded.table > thead > tr > th,
+ .ui.padded.table > tbody > tr > th,
+ .ui.padded.table > tfoot > tr > th,
+ .ui.padded.table > tr > td,
+ .ui.padded.table > tbody > tr > td,
+ .ui.padded.table > tfoot > tr > td {
+ padding: @paddedVerticalPadding @paddedHorizontalPadding;
+ }
+
+ & when (@variationTableVeryPadded) {
+ /* Very */
+ .ui[class*="very padded"].table > tr > th,
+ .ui[class*="very padded"].table > thead > tr > th,
+ .ui[class*="very padded"].table > tbody > tr > th,
+ .ui[class*="very padded"].table > tfoot > tr > th {
+ padding-left: @veryPaddedHorizontalPadding;
+ padding-right: @veryPaddedHorizontalPadding;
+ }
+ .ui[class*="very padded"].table > tr > td,
+ .ui[class*="very padded"].table > tbody > tr > td,
+ .ui[class*="very padded"].table > tfoot > tr > td {
+ padding: @veryPaddedVerticalPadding @veryPaddedHorizontalPadding;
+ }
+ }
}
& when (@variationTableCompact) or (@variationTableVeryCompact) {
- /*--------------
- Compact
- ---------------*/
-
- .ui.compact.table > tr > th,
- .ui.compact.table > thead > tr > th,
- .ui.compact.table > tbody > tr > th,
- .ui.compact.table > tfoot > tr > th {
- padding-left: @compactHorizontalPadding;
- padding-right: @compactHorizontalPadding;
- }
- .ui.compact.table > tr > td,
- .ui.compact.table > tbody > tr > td ,
- .ui.compact.table > tfoot > tr > td {
- padding: @compactVerticalPadding @compactHorizontalPadding;
- }
-
- & when (@variationTableVeryCompact) {
- /* Very */
- .ui[class*="very compact"].table > tr > th,
- .ui[class*="very compact"].table > thead > tr > th,
- .ui[class*="very compact"].table > tbody > tr > th,
- .ui[class*="very compact"].table > tfoot > tr > th {
- padding-left: @veryCompactHorizontalPadding;
- padding-right: @veryCompactHorizontalPadding;
- }
- .ui[class*="very compact"].table > tr > td,
- .ui[class*="very compact"].table > tbody > tr > td,
- .ui[class*="very compact"].table > tfoot > tr > td {
- padding: @veryCompactVerticalPadding @veryCompactHorizontalPadding;
- }
- }
+ /* --------------
+ Compact
+ --------------- */
+
+ .ui.compact.table > tr > th,
+ .ui.compact.table > thead > tr > th,
+ .ui.compact.table > tbody > tr > th,
+ .ui.compact.table > tfoot > tr > th {
+ padding-left: @compactHorizontalPadding;
+ padding-right: @compactHorizontalPadding;
+ }
+ .ui.compact.table > tr > td,
+ .ui.compact.table > tbody > tr > td,
+ .ui.compact.table > tfoot > tr > td {
+ padding: @compactVerticalPadding @compactHorizontalPadding;
+ }
+
+ & when (@variationTableVeryCompact) {
+ /* Very */
+ .ui[class*="very compact"].table > tr > th,
+ .ui[class*="very compact"].table > thead > tr > th,
+ .ui[class*="very compact"].table > tbody > tr > th,
+ .ui[class*="very compact"].table > tfoot > tr > th {
+ padding-left: @veryCompactHorizontalPadding;
+ padding-right: @veryCompactHorizontalPadding;
+ }
+ .ui[class*="very compact"].table > tr > td,
+ .ui[class*="very compact"].table > tbody > tr > td,
+ .ui[class*="very compact"].table > tfoot > tr > td {
+ padding: @veryCompactVerticalPadding @veryCompactHorizontalPadding;
+ }
+ }
}
& when (@variationTableStuck) {
- /*--------------
- Stuck
- ---------------*/
+ /* --------------
+ Stuck
+ --------------- */
- .ui.stuck.table:not(.inverted) {
- background: @stuckBackground;
- & > thead > tr {
- background: @stuckHeaderBackground;
+ .ui.stuck.table:not(.inverted) {
+ background: @stuckBackground;
+ & > thead > tr {
+ background: @stuckHeaderBackground;
+ }
+ & > tbody > tr {
+ background: @stuckBackground;
+ }
+ & > tfoot > tr {
+ background: @stuckFooterBackground;
+ }
+ &.basic when (@variationTableBasic) {
+ & > thead > tr,
+ > tfoot > tr {
+ background: @stuckBackground;
+ }
+ }
}
- & > tbody > tr {
- background: @stuckBackground;
+ .ui.inverted.stuck.table when (@variationTableInverted) {
+ & > thead > tr {
+ background: @invertedStuckHeaderBackground;
+ }
+ & > tbody > tr {
+ background: @invertedStuckBackground;
+ }
+ & > tfoot > tr {
+ background: @invertedStuckFooterBackground;
+ }
+ &.basic when (@variationTableBasic) {
+ & > thead > tr,
+ > tfoot > tr {
+ background: @invertedStuckBackground;
+ }
+ }
}
- & > tfoot > tr {
- background: @stuckFooterBackground;
+ & when (@variationTableStuckHead) or (@variationTableStuckFoot) {
+ .ui.head.stuck.table > thead,
+ .ui.foot.stuck.table > tfoot {
+ position: sticky;
+ z-index: @stuckZIndex;
+ }
}
- &.basic when (@variationTableBasic) {
- & > thead > tr,
- > tfoot > tr {
- background: @stuckBackground;
- }
- }
- }
- .ui.inverted.stuck.table when (@variationTableInverted) {
- & > thead > tr {
- background: @invertedStuckHeaderBackground;
- }
- & > tbody > tr {
- background: @invertedStuckBackground;
- }
- & > tfoot > tr {
- background: @invertedStuckFooterBackground;
- }
- &.basic when (@variationTableBasic){
- & > thead > tr,
- > tfoot > tr {
- background: @invertedStuckBackground;
- }
- }
- }
- & when (@variationTableStuckHead) or (@variationTableStuckFoot) {
- .ui.head.stuck.table > thead,
- .ui.foot.stuck.table > tfoot {
- position: -webkit-sticky;
- position: sticky;
- z-index: @stuckZIndex;
- }
- }
- .ui.head.stuck.table when (@variationTableStuckHead) {
- border-top: 0;
- & > thead {
- top: 0;
- bottom: auto;
- & > tr:first-child > th {
- border-top: @cellBorder;
- }
- }
- &.inverted > thead > tr:first-child > th when (@variationTableInverted) {
- border-top: @invertedCellBorder;
- }
- }
- .ui.foot.stuck.table when (@variationTableStuckFoot) {
- border-bottom: 0;
- & > tfoot {
- top: auto;
- bottom: 0;
- & > tr:last-child > td,
- > tr:last-child > th {
- border-bottom: @cellBorder;
- }
+ .ui.head.stuck.table when (@variationTableStuckHead) {
+ border-top: 0;
+ & > thead {
+ top: 0;
+ bottom: auto;
+ & > tr:first-child > th {
+ border-top: @cellBorder;
+ }
+ }
+ &.inverted > thead > tr:first-child > th when (@variationTableInverted) {
+ border-top: @invertedCellBorder;
+ }
}
- & when (@variationTableInverted) {
- &.inverted > tfoot > tr:first-child > td,
- &.inverted > tfoot > tr:first-child > th {
- border-top: @invertedCellBorder;
- }
- }
- }
-
- .ui.first.stuck.table when (@variationTableStuckFirst) {
- border-left: 0;
- & th:first-child,
- td:first-child {
- position: -webkit-sticky;
- position: sticky;
- left: 0;
- border-left: @cellBorder;
- background: inherit;
+ .ui.foot.stuck.table when (@variationTableStuckFoot) {
+ border-bottom: 0;
+ & > tfoot {
+ top: auto;
+ bottom: 0;
+ & > tr:last-child > td,
+ > tr:last-child > th {
+ border-bottom: @cellBorder;
+ }
+ }
+ & when (@variationTableInverted) {
+ &.inverted > tfoot > tr:first-child > td,
+ &.inverted > tfoot > tr:first-child > th {
+ border-top: @invertedCellBorder;
+ }
+ }
}
- & when (@variationTableInverted) {
- &.inverted th:first-child,
- &.inverted td:first-child {
- border-left: @invertedCellBorder;
- }
- }
- }
-
- .ui.last.stuck.table when (@variationTableStuckLast) {
- border-right: 0;
- & th:last-child,
- td:last-child {
- position: -webkit-sticky;
- position: sticky;
- right: 0;
- border-right: @cellBorder;
- background: inherit;
+
+ .ui.first.stuck.table when (@variationTableStuckFirst) {
+ border-left: 0;
+ & th:first-child,
+ td:first-child {
+ position: sticky;
+ left: 0;
+ border-left: @cellBorder;
+ background: inherit;
+ }
+ & when (@variationTableInverted) {
+ &.inverted th:first-child,
+ &.inverted td:first-child {
+ border-left: @invertedCellBorder;
+ }
+ }
}
- & when (@variationTableInverted) {
- &.inverted th:last-child,
- &.inverted td:last-child {
- border-right: @invertedCellBorder;
- }
- }
- }
- & when (@variationTableCelled) {
- & when (@variationTableStuckFirst) {
- .ui.celled.first.stuck.table th:first-child,
- .ui.celled.first.stuck.table td:first-child {
- border-right: @cellBorder;
- }
- }
- & when (@variationTableStuckLast) {
- .ui.celled.last.stuck.table th:last-child,
- .ui.celled.last.stuck.table td:last-child {
- border-left: @cellBorder;
- }
+
+ .ui.last.stuck.table when (@variationTableStuckLast) {
+ border-right: 0;
+ & th:last-child,
+ td:last-child {
+ position: sticky;
+ right: 0;
+ border-right: @cellBorder;
+ background: inherit;
+ }
+ & when (@variationTableInverted) {
+ &.inverted th:last-child,
+ &.inverted td:last-child {
+ border-right: @invertedCellBorder;
+ }
+ }
}
- & when (@variationTableInverted) {
- & when (@variationTableStuckFirst) {
- .ui.inverted.celled.first.stuck.table th:first-child,
- .ui.inverted.celled.first.stuck.table td:first-child {
- border-right: @invertedCellBorder;
+ & when (@variationTableCelled) {
+ & when (@variationTableStuckFirst) {
+ .ui.celled.first.stuck.table th:first-child,
+ .ui.celled.first.stuck.table td:first-child {
+ border-right: @cellBorder;
+ }
+ }
+ & when (@variationTableStuckLast) {
+ .ui.celled.last.stuck.table th:last-child,
+ .ui.celled.last.stuck.table td:last-child {
+ border-left: @cellBorder;
+ }
}
- }
- & when (@variationTableStuckLast) {
- .ui.inverted.celled.last.stuck.table th:last-child,
- .ui.inverted.celled.last.stuck.table td:last-child {
- border-left: @invertedCellBorder;
+ & when (@variationTableInverted) {
+ & when (@variationTableStuckFirst) {
+ .ui.inverted.celled.first.stuck.table th:first-child,
+ .ui.inverted.celled.first.stuck.table td:first-child {
+ border-right: @invertedCellBorder;
+ }
+ }
+ & when (@variationTableStuckLast) {
+ .ui.inverted.celled.last.stuck.table th:last-child,
+ .ui.inverted.celled.last.stuck.table td:last-child {
+ border-left: @invertedCellBorder;
+ }
+ }
}
- }
}
- }
}
-/*--------------
+/* --------------
Sizes
----------------*/
+--------------- */
/* Standard */
.ui.table {
- font-size: @medium;
+ font-size: @medium;
}
& when not (@variationTableSizes = false) {
- each(@variationTableSizes, {
- @s: @@value;
- .ui.@{value}.table {
- font-size: @s;
- }
- })
+ each(@variationTableSizes, {
+ @s: @@value;
+ .ui.@{value}.table {
+ font-size: @s;
+ }
+ });
}
-
.loadUIOverrides();
diff --git a/definitions/elements/button.less b/definitions/elements/button.less
index 69761ae..40bfa6c 100644
--- a/definitions/elements/button.less
+++ b/definitions/elements/button.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Button
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,635 +12,625 @@
Theme
*******************************/
-@type : 'element';
-@element : 'button';
+@type: "element";
+@element: "button";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Button
*******************************/
.ui.button {
- cursor: pointer;
- display: inline-block;
-
- min-height: 1em;
-
- outline: none;
- border: none;
- vertical-align: @verticalAlign;
- background: @background;
- color: @textColor;
-
- font-family: @fontFamily;
-
- margin: 0 @horizontalMargin @verticalMargin 0;
- padding: @verticalPadding @horizontalPadding (@verticalPadding + @shadowOffset);
-
- text-transform: @textTransform;
- text-shadow: @textShadow;
- font-weight: @fontWeight;
- line-height: @lineHeight;
- font-style: normal;
- text-align: center;
- text-decoration: none;
-
- border-radius: @borderRadius;
- box-shadow: @boxShadow;
-
- user-select: none;
- transition: @transition;
- will-change: @willChange;
-
- -webkit-tap-highlight-color: @tapColor;
+ cursor: pointer;
+ display: inline-block;
+ min-height: 1em;
+ outline: none;
+ border: none;
+ vertical-align: @verticalAlign;
+ background: @background;
+ color: @textColor;
+ font-family: @fontFamily;
+ margin: 0 @horizontalMargin @verticalMargin 0;
+ padding: @verticalPadding @horizontalPadding (@verticalPadding + @shadowOffset);
+ text-transform: @textTransform;
+ text-shadow: @textShadow;
+ font-weight: @fontWeight;
+ line-height: @lineHeight;
+ font-style: normal;
+ text-align: center;
+ text-decoration: none;
+ border-radius: @borderRadius;
+ box-shadow: @boxShadow;
+ user-select: none;
+ transition: @transition;
+ will-change: @willChange;
+ -webkit-tap-highlight-color: @tapColor;
}
-
/*******************************
States
*******************************/
-/*--------------
+/* --------------
Hover
----------------*/
+--------------- */
.ui.button:hover {
- background-color: @hoverBackgroundColor;
- background-image: @hoverBackgroundImage;
- box-shadow: @hoverBoxShadow;
- color: @hoverColor;
+ background-color: @hoverBackgroundColor;
+ background-image: @hoverBackgroundImage;
+ box-shadow: @hoverBoxShadow;
+ color: @hoverColor;
}
.ui.button:hover .icon {
- opacity: @iconHoverOpacity;
+ opacity: @iconHoverOpacity;
}
-/*--------------
+/* --------------
Focus
----------------*/
+--------------- */
.ui.button:focus {
- background-color: @focusBackgroundColor;
- color: @focusColor;
- background-image: @focusBackgroundImage;
- box-shadow: @focusBoxShadow;
+ background-color: @focusBackgroundColor;
+ color: @focusColor;
+ background-image: @focusBackgroundImage;
+ box-shadow: @focusBoxShadow;
}
.ui.button:focus .icon {
- opacity: @iconFocusOpacity;
+ opacity: @iconFocusOpacity;
}
-/*--------------
+/* --------------
Down
----------------*/
+--------------- */
.ui.button:active,
.ui.active.button:active {
- background-color: @downBackgroundColor;
- background-image: @downBackgroundImage;
- color: @downColor;
- box-shadow: @downBoxShadow;
+ background-color: @downBackgroundColor;
+ background-image: @downBackgroundImage;
+ color: @downColor;
+ box-shadow: @downBoxShadow;
}
-/*--------------
+/* --------------
Active
----------------*/
+--------------- */
.ui.active.button {
- background-color: @activeBackgroundColor;
- background-image: @activeBackgroundImage;
- box-shadow: @activeBoxShadow;
- color: @activeColor;
+ background-color: @activeBackgroundColor;
+ background-image: @activeBackgroundImage;
+ box-shadow: @activeBoxShadow;
+ color: @activeColor;
}
.ui.active.button:hover {
- background-color: @activeHoverBackgroundColor;
- background-image: @activeHoverBackgroundImage;
- color: @activeHoverColor;
+ background-color: @activeHoverBackgroundColor;
+ background-image: @activeHoverBackgroundImage;
+ color: @activeHoverColor;
}
.ui.active.button:active {
- background-color: @activeBackgroundColor;
- background-image: @activeBackgroundImage;
+ background-color: @activeBackgroundColor;
+ background-image: @activeBackgroundImage;
}
& when (@variationButtonLoading) {
- /*--------------
- Loading
- ---------------*/
-
- /* Specificity hack */
- .ui.loading.loading.loading.loading.loading.loading.button {
- position: relative;
- cursor: default;
- text-shadow: none !important;
- color: transparent;
- opacity: @loadingOpacity;
- pointer-events: @loadingPointerEvents;
- transition: @loadingTransition;
- }
- .ui.loading.button::before {
- position: absolute;
- content: '';
- top: 50%;
- left: 50%;
-
- margin: @loaderMargin;
- width: @loaderSize;
- height: @loaderSize;
-
- border-radius: @circularRadius;
- border: @loaderLineWidth solid @invertedLoaderFillColor;
- }
- .ui.loading.button::after {
- position: absolute;
- content: '';
- top: 50%;
- left: 50%;
-
- margin: @loaderMargin;
- width: @loaderSize;
- height: @loaderSize;
-
- border-radius: @circularRadius;
-
- animation: loader @loaderSpeed infinite linear;
- border: @loaderLineWidth solid currentColor;
- color: @invertedLoaderLineColor;
-
- box-shadow: 0 0 0 1px transparent;
- }
- .ui.ui.ui.loading.button .label {
- background-color: transparent;
- border-color: transparent;
- color: transparent;
- }
- & when (@variationButtonLabeledIcon){
- .ui.labeled.icon.loading.button .icon {
- background-color: transparent;
- box-shadow: none;
- }
- }
- & when (@variationButtonBasic){
- .ui.basic.loading.button:not(.inverted)::before {
- border-color: @loaderFillColor;
- }
- .ui.basic.loading.button:not(.inverted)::after {
- border-color: @loaderLineColor;
- }
- }
+ /* --------------
+ Loading
+ --------------- */
+
+ /* Specificity hack */
+ .ui.loading.loading.loading.loading.loading.loading.button {
+ position: relative;
+ cursor: default;
+ text-shadow: none !important;
+ color: transparent;
+ opacity: @loadingOpacity;
+ pointer-events: @loadingPointerEvents;
+ transition: @loadingTransition;
+ }
+ .ui.loading.button::before {
+ position: absolute;
+ content: "";
+ top: 50%;
+ left: 50%;
+ margin: @loaderMargin;
+ width: @loaderSize;
+ height: @loaderSize;
+ border-radius: @circularRadius;
+ border: @loaderLineWidth solid @invertedLoaderFillColor;
+ }
+ .ui.loading.button::after {
+ position: absolute;
+ content: "";
+ top: 50%;
+ left: 50%;
+ margin: @loaderMargin;
+ width: @loaderSize;
+ height: @loaderSize;
+ border-radius: @circularRadius;
+ animation: loader @loaderSpeed infinite linear;
+ border: @loaderLineWidth solid currentColor;
+ color: @invertedLoaderLineColor;
+ box-shadow: 0 0 0 1px transparent;
+ }
+ .ui.ui.ui.loading.button .label {
+ background-color: transparent;
+ border-color: transparent;
+ color: transparent;
+ }
+ & when (@variationButtonLabeledIcon) {
+ .ui.labeled.icon.loading.button .icon {
+ background-color: transparent;
+ box-shadow: none;
+ }
+ }
+ & when (@variationButtonBasic) {
+ .ui.basic.loading.button:not(.inverted)::before {
+ border-color: @loaderFillColor;
+ }
+ .ui.basic.loading.button:not(.inverted)::after {
+ border-color: @loaderLineColor;
+ }
+ }
}
-& when (@variationButtonDisabled){
- /*-------------------
- Disabled
- --------------------*/
-
- .ui.buttons .disabled.button:not(.basic),
- .ui.disabled.button,
- .ui.button:disabled,
- .ui.disabled.button:hover,
- .ui.disabled.active.button {
- cursor: default;
- opacity: @disabledOpacity !important;
- background-image: none;
- box-shadow: none;
- pointer-events: none !important;
- }
- & when (@variationButtonBasic){
- /* Basic Group With Disabled */
- .ui.basic.buttons .ui.disabled.button {
- border-color: @disabledBorderColor;
- }
- }
+& when (@variationButtonDisabled) {
+ /* -------------------
+ Disabled
+ -------------------- */
+
+ .ui.buttons .disabled.button:not(.basic),
+ .ui.disabled.button,
+ .ui.button:disabled,
+ .ui.disabled.button:hover,
+ .ui.disabled.active.button {
+ cursor: default;
+ opacity: @disabledOpacity !important;
+ background-image: none;
+ box-shadow: none;
+ pointer-events: none !important;
+ }
+ & when (@variationButtonBasic) {
+ /* Basic Group With Disabled */
+ .ui.basic.buttons .ui.disabled.button {
+ border-color: @disabledBorderColor;
+ }
+ }
}
/*******************************
Types
*******************************/
-& when (@variationButtonAnimated){
- /*-------------------
- Animated
- --------------------*/
-
- .ui.animated.button {
- position: relative;
- overflow: hidden;
- padding-right: 0 !important;
- vertical-align: @animatedVerticalAlign;
- z-index: @animatedZIndex;
- }
-
- .ui.animated.button .content {
- will-change: transform, opacity;
- }
- .ui.animated.button .visible.content {
- position: relative;
- margin-right: @horizontalPadding;
- }
- .ui.animated.button .hidden.content {
- position: absolute;
- width: 100%;
- }
-
- /* Horizontal */
- .ui.animated.button .visible.content,
- .ui.animated.button .hidden.content {
- transition: right @animationDuration @animationEasing 0s;
- }
- .ui.animated.button .visible.content {
- left: auto;
- right: 0;
- }
- .ui.animated.button .hidden.content {
- top: 50%;
- left: auto;
- right: -100%;
- margin-top: -(@lineHeight / 2);
- }
- .ui.animated.button:focus .visible.content,
- .ui.animated.button:hover .visible.content {
- left: auto;
- right: 200%;
- }
- .ui.animated.button:focus .hidden.content,
- .ui.animated.button:hover .hidden.content {
- left: auto;
- right: 0;
- }
-
- & when (@variationButtonVertical) {
- /* Vertical */
- .ui.vertical.animated.button .visible.content,
- .ui.vertical.animated.button .hidden.content {
- transition: top @animationDuration @animationEasing, transform @animationDuration @animationEasing;
- }
- .ui.vertical.animated.button .visible.content {
- transform: translateY(0%);
- right: auto;
- }
- .ui.vertical.animated.button .hidden.content {
- top: -50%;
- left: 0;
- right: auto;
- }
- .ui.vertical.animated.button:focus .visible.content,
- .ui.vertical.animated.button:hover .visible.content {
- transform: translateY(200%);
- right: auto;
- }
- .ui.vertical.animated.button:focus .hidden.content,
- .ui.vertical.animated.button:hover .hidden.content {
- top: 50%;
- right: auto;
- }
- }
- & when (@variationButtonAnimatedFade) {
- /* Fade */
- .ui.fade.animated.button .visible.content,
- .ui.fade.animated.button .hidden.content {
- transition: opacity @animationDuration @animationEasing, transform @animationDuration @animationEasing;
- }
- .ui.fade.animated.button .visible.content {
- left: auto;
- right: auto;
- opacity: 1;
- transform: scale(1);
- }
- .ui.fade.animated.button .hidden.content {
- opacity: 0;
- left: 0;
- right: auto;
- transform: scale(@fadeScaleHigh);
- }
- .ui.fade.animated.button:focus .visible.content,
- .ui.fade.animated.button:hover .visible.content {
- left: auto;
- right: auto;
- opacity: 0;
- transform: scale(@fadeScaleLow);
- }
- .ui.fade.animated.button:focus .hidden.content,
- .ui.fade.animated.button:hover .hidden.content {
- left: 0;
- right: auto;
- opacity: 1;
- transform: scale(1);
- }
- }
+& when (@variationButtonAnimated) {
+ /* -------------------
+ Animated
+ -------------------- */
+
+ .ui.animated.button {
+ position: relative;
+ overflow: hidden;
+ padding-right: 0 !important;
+ vertical-align: @animatedVerticalAlign;
+ z-index: @animatedZIndex;
+ }
+
+ .ui.animated.button .content {
+ will-change: transform, opacity;
+ }
+ .ui.animated.button .visible.content {
+ position: relative;
+ margin-right: @horizontalPadding;
+ }
+ .ui.animated.button .hidden.content {
+ position: absolute;
+ width: 100%;
+ }
+
+ /* Horizontal */
+ .ui.animated.button .visible.content,
+ .ui.animated.button .hidden.content {
+ transition: right @animationDuration @animationEasing 0s;
+ }
+ .ui.animated.button .visible.content {
+ left: auto;
+ right: 0;
+ }
+ .ui.animated.button .hidden.content {
+ top: 50%;
+ left: auto;
+ right: -100%;
+ margin-top: -(@lineHeight / 2);
+ }
+ .ui.animated.button:focus .visible.content,
+ .ui.animated.button:hover .visible.content {
+ left: auto;
+ right: 200%;
+ }
+ .ui.animated.button:focus .hidden.content,
+ .ui.animated.button:hover .hidden.content {
+ left: auto;
+ right: 0;
+ }
+
+ & when (@variationButtonVertical) {
+ /* Vertical */
+ .ui.vertical.animated.button .visible.content,
+ .ui.vertical.animated.button .hidden.content {
+ transition:
+ top @animationDuration @animationEasing,
+ transform @animationDuration @animationEasing;
+ }
+ .ui.vertical.animated.button .visible.content {
+ transform: translateY(0);
+ right: auto;
+ }
+ .ui.vertical.animated.button .hidden.content {
+ top: -50%;
+ left: 0;
+ right: auto;
+ }
+ .ui.vertical.animated.button:focus .visible.content,
+ .ui.vertical.animated.button:hover .visible.content {
+ transform: translateY(200%);
+ right: auto;
+ }
+ .ui.vertical.animated.button:focus .hidden.content,
+ .ui.vertical.animated.button:hover .hidden.content {
+ top: 50%;
+ right: auto;
+ }
+ }
+ & when (@variationButtonAnimatedFade) {
+ /* Fade */
+ .ui.fade.animated.button .visible.content,
+ .ui.fade.animated.button .hidden.content {
+ transition:
+ opacity @animationDuration @animationEasing,
+ transform @animationDuration @animationEasing;
+ }
+ .ui.fade.animated.button .visible.content {
+ left: auto;
+ right: auto;
+ opacity: 1;
+ transform: scale(1);
+ }
+ .ui.fade.animated.button .hidden.content {
+ opacity: 0;
+ left: 0;
+ right: auto;
+ transform: scale(@fadeScaleHigh);
+ }
+ .ui.fade.animated.button:focus .visible.content,
+ .ui.fade.animated.button:hover .visible.content {
+ left: auto;
+ right: auto;
+ opacity: 0;
+ transform: scale(@fadeScaleLow);
+ }
+ .ui.fade.animated.button:focus .hidden.content,
+ .ui.fade.animated.button:hover .hidden.content {
+ left: 0;
+ right: auto;
+ opacity: 1;
+ transform: scale(1);
+ }
+ }
}
& when (@variationButtonInverted) {
- /*-------------------
- Inverted
- --------------------*/
+ /* -------------------
+ Inverted
+ -------------------- */
- .ui.inverted.button {
- box-shadow: 0 0 0 @invertedBorderSize @white inset;
- background: transparent none;
- color: @white;
- text-shadow: none !important;
- }
+ .ui.inverted.button {
+ box-shadow: 0 0 0 @invertedBorderSize @white inset;
+ background: transparent none;
+ color: @white;
+ text-shadow: none !important;
+ }
- & when (@variationButtonGroups) {
- /* Group */
- .ui.inverted.buttons .button {
- margin: @invertedGroupButtonOffset;
+ & when (@variationButtonGroups) {
+ /* Group */
+ .ui.inverted.buttons .button {
+ margin: @invertedGroupButtonOffset;
+ }
+ .ui.inverted.buttons .button:first-child {
+ margin-left: 0;
+ }
+ & when (@variationButtonVertical) {
+ .ui.inverted.vertical.buttons .button {
+ margin: @invertedVerticalGroupButtonOffset;
+ }
+ .ui.inverted.vertical.buttons .button:first-child {
+ margin-top: 0;
+ }
+ }
}
- .ui.inverted.buttons .button:first-child {
- margin-left: 0;
+
+ /* States */
+
+ /* Hover */
+ .ui.inverted.button:hover {
+ background: @white;
+ box-shadow: 0 0 0 @invertedBorderSize @white inset;
+ color: @hoverColor;
}
- & when (@variationButtonVertical) {
- .ui.inverted.vertical.buttons .button {
- margin: @invertedVerticalGroupButtonOffset;
- }
- .ui.inverted.vertical.buttons .button:first-child {
- margin-top: 0;
- }
- }
- }
- /* States */
-
- /* Hover */
- .ui.inverted.button:hover {
- background: @white;
- box-shadow: 0 0 0 @invertedBorderSize @white inset;
- color: @hoverColor;
- }
- /* Active / Focus */
- .ui.inverted.button:focus,
- .ui.inverted.button.active {
- background: @white;
- box-shadow: 0 0 0 @invertedBorderSize @white inset;
- color: @focusColor;
- }
+ /* Active / Focus */
+ .ui.inverted.button:focus,
+ .ui.inverted.button.active {
+ background: @white;
+ box-shadow: 0 0 0 @invertedBorderSize @white inset;
+ color: @focusColor;
+ }
- /* Active Focus */
- .ui.inverted.button.active:focus {
- background: @midWhite;
- box-shadow: 0 0 0 @invertedBorderSize @midWhite inset;
- color: @focusColor;
- }
+ /* Active Focus */
+ .ui.inverted.button.active:focus {
+ background: @midWhite;
+ box-shadow: 0 0 0 @invertedBorderSize @midWhite inset;
+ color: @focusColor;
+ }
}
-& when (@variationButtonLabeled) or (@variationButtonLabeledIcon){
- /*-------------------
- Labeled Button
- --------------------*/
+& when (@variationButtonLabeled) or (@variationButtonLabeledIcon) {
+ /* -------------------
+ Labeled Button
+ -------------------- */
- .ui.labeled.button:not(.icon) {
- display: inline-flex;
- flex-direction: row;
- background: none;
- padding: 0 !important;
- border: none;
- box-shadow: none;
- }
-
- .ui.labeled.button > .button {
- margin: 0;
- }
- .ui.labeled.button > .label {
- display: flex;
- align-items: @labeledLabelAlign;
- margin: 0 0 0 @labeledLabelBorderOffset !important;
- font-size: @labeledLabelFontSize;
- padding: @labeledLabelPadding;
- border-color: @labeledLabelBorderColor;
- }
-
- /* Tag */
- .ui.labeled.button > .tag.label::before {
- width: @labeledTagLabelSize;
- height: @labeledTagLabelSize;
- }
-
- /* Right */
- .ui.labeled.button:not([class*="left labeled"]) > .button {
- border-top-right-radius: 0;
- border-bottom-right-radius: 0;
- }
- .ui.labeled.button:not([class*="left labeled"]) > .label {
- border-top-left-radius: 0;
- border-bottom-left-radius: 0;
- }
-
- /* Left Side */
- .ui[class*="left labeled"].button > .button {
- border-top-left-radius: 0;
- border-bottom-left-radius: 0;
- }
- .ui[class*="left labeled"].button > .label {
- border-top-right-radius: 0;
- border-bottom-right-radius: 0;
- }
+ .ui.labeled.button:not(.icon) {
+ display: inline-flex;
+ flex-direction: row;
+ background: none;
+ padding: 0 !important;
+ border: none;
+ box-shadow: none;
+ }
+
+ .ui.labeled.button > .button {
+ margin: 0;
+ }
+ .ui.labeled.button > .label {
+ display: flex;
+ align-items: @labeledLabelAlign;
+ margin: 0 0 0 @labeledLabelBorderOffset !important;
+ font-size: @labeledLabelFontSize;
+ padding: @labeledLabelPadding;
+ border-color: @labeledLabelBorderColor;
+ }
+
+ /* Tag */
+ .ui.labeled.button > .tag.label::before {
+ width: @labeledTagLabelSize;
+ height: @labeledTagLabelSize;
+ }
+
+ /* Right */
+ .ui.labeled.button:not([class*="left labeled"]) > .button {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+ }
+ .ui.labeled.button:not([class*="left labeled"]) > .label {
+ border-top-left-radius: 0;
+ border-bottom-left-radius: 0;
+ }
+
+ /* Left Side */
+ .ui[class*="left labeled"].button > .button {
+ border-top-left-radius: 0;
+ border-bottom-left-radius: 0;
+ }
+ .ui[class*="left labeled"].button > .label {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+ }
}
& when (@variationButtonSocial) {
- /*-------------------
- Social
- --------------------*/
-
- /* Facebook */
- .ui.facebook.button {
- background-color: @facebookColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- background-image: @coloredBackgroundImage;
- box-shadow: @coloredBoxShadow;
- }
- .ui.facebook.button:hover {
- background-color: @facebookHoverColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
- .ui.facebook.button:active {
- background-color: @facebookDownColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
-
- /* Twitter */
- .ui.twitter.button {
- background-color: @twitterColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- background-image: @coloredBackgroundImage;
- box-shadow: @coloredBoxShadow;
- }
- .ui.twitter.button:hover {
- background-color: @twitterHoverColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
- .ui.twitter.button:active {
- background-color: @twitterDownColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
-
- /* Google Plus */
- .ui.google.plus.button {
- background-color: @googlePlusColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- background-image: @coloredBackgroundImage;
- box-shadow: @coloredBoxShadow;
- }
- .ui.google.plus.button:hover {
- background-color: @googlePlusHoverColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
- .ui.google.plus.button:active {
- background-color: @googlePlusDownColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
-
- /* Linked In */
- .ui.linkedin.button {
- background-color: @linkedInColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
- .ui.linkedin.button:hover {
- background-color: @linkedInHoverColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
- .ui.linkedin.button:active {
- background-color: @linkedInDownColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
-
- /* YouTube */
- .ui.youtube.button {
- background-color: @youtubeColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- background-image: @coloredBackgroundImage;
- box-shadow: @coloredBoxShadow;
- }
- .ui.youtube.button:hover {
- background-color: @youtubeHoverColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
- .ui.youtube.button:active {
- background-color: @youtubeDownColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
-
- /* Instagram */
- .ui.instagram.button {
- background-color: @instagramColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- background-image: @coloredBackgroundImage;
- box-shadow: @coloredBoxShadow;
- }
- .ui.instagram.button:hover {
- background-color: @instagramHoverColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
- .ui.instagram.button:active {
- background-color: @instagramDownColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
-
- /* Pinterest */
- .ui.pinterest.button {
- background-color: @pinterestColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- background-image: @coloredBackgroundImage;
- box-shadow: @coloredBoxShadow;
- }
- .ui.pinterest.button:hover {
- background-color: @pinterestHoverColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
- .ui.pinterest.button:active {
- background-color: @pinterestDownColor;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- }
-
- /* VK */
- .ui.vk.button {
- background-color: @vkColor;
- color: @white;
- background-image: @coloredBackgroundImage;
- box-shadow: @coloredBoxShadow;
- }
- .ui.vk.button:hover {
- background-color: @vkHoverColor;
- color: @white;
- }
- .ui.vk.button:active {
- background-color: @vkDownColor;
- color: @white;
- }
-
- /* WhatsApp */
- .ui.whatsapp.button {
- background-color: @whatsAppColor;
- color: @white;
- background-image: @coloredBackgroundImage;
- box-shadow: @coloredBoxShadow;
- }
- .ui.whatsapp.button:hover {
- background-color: @whatsAppHoverColor;
- color: @white;
- }
- .ui.whatsapp.button:active {
- background-color: @whatsAppDownColor;
- color: @white;
- }
-
- /* Telegram */
- .ui.telegram.button {
- background-color: @telegramColor;
- color: @white;
- background-image: @coloredBackgroundImage;
- box-shadow: @coloredBoxShadow;
- }
- .ui.telegram.button:hover {
- background-color: @telegramHoverColor;
- color: @white;
- }
- .ui.telegram.button:active {
- background-color: @telegramDownColor;
- color: @white;
- }
+ /* -------------------
+ Social
+ -------------------- */
+
+ /* Facebook */
+ .ui.facebook.button {
+ background-color: @facebookColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ background-image: @coloredBackgroundImage;
+ box-shadow: @coloredBoxShadow;
+ }
+ .ui.facebook.button:hover {
+ background-color: @facebookHoverColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+ .ui.facebook.button:active {
+ background-color: @facebookDownColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+
+ /* Twitter */
+ .ui.twitter.button {
+ background-color: @twitterColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ background-image: @coloredBackgroundImage;
+ box-shadow: @coloredBoxShadow;
+ }
+ .ui.twitter.button:hover {
+ background-color: @twitterHoverColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+ .ui.twitter.button:active {
+ background-color: @twitterDownColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+
+ /* Google Plus */
+ .ui.google.plus.button {
+ background-color: @googlePlusColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ background-image: @coloredBackgroundImage;
+ box-shadow: @coloredBoxShadow;
+ }
+ .ui.google.plus.button:hover {
+ background-color: @googlePlusHoverColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+ .ui.google.plus.button:active {
+ background-color: @googlePlusDownColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+
+ /* Linked In */
+ .ui.linkedin.button {
+ background-color: @linkedInColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+ .ui.linkedin.button:hover {
+ background-color: @linkedInHoverColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+ .ui.linkedin.button:active {
+ background-color: @linkedInDownColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+
+ /* YouTube */
+ .ui.youtube.button {
+ background-color: @youtubeColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ background-image: @coloredBackgroundImage;
+ box-shadow: @coloredBoxShadow;
+ }
+ .ui.youtube.button:hover {
+ background-color: @youtubeHoverColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+ .ui.youtube.button:active {
+ background-color: @youtubeDownColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+
+ /* Instagram */
+ .ui.instagram.button {
+ background-color: @instagramColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ background-image: @coloredBackgroundImage;
+ box-shadow: @coloredBoxShadow;
+ }
+ .ui.instagram.button:hover {
+ background-color: @instagramHoverColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+ .ui.instagram.button:active {
+ background-color: @instagramDownColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+
+ /* Pinterest */
+ .ui.pinterest.button {
+ background-color: @pinterestColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ background-image: @coloredBackgroundImage;
+ box-shadow: @coloredBoxShadow;
+ }
+ .ui.pinterest.button:hover {
+ background-color: @pinterestHoverColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+ .ui.pinterest.button:active {
+ background-color: @pinterestDownColor;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ }
+
+ /* VK */
+ .ui.vk.button {
+ background-color: @vkColor;
+ color: @white;
+ background-image: @coloredBackgroundImage;
+ box-shadow: @coloredBoxShadow;
+ }
+ .ui.vk.button:hover {
+ background-color: @vkHoverColor;
+ color: @white;
+ }
+ .ui.vk.button:active {
+ background-color: @vkDownColor;
+ color: @white;
+ }
+
+ /* WhatsApp */
+ .ui.whatsapp.button {
+ background-color: @whatsAppColor;
+ color: @white;
+ background-image: @coloredBackgroundImage;
+ box-shadow: @coloredBoxShadow;
+ }
+ .ui.whatsapp.button:hover {
+ background-color: @whatsAppHoverColor;
+ color: @white;
+ }
+ .ui.whatsapp.button:active {
+ background-color: @whatsAppDownColor;
+ color: @white;
+ }
+
+ /* Telegram */
+ .ui.telegram.button {
+ background-color: @telegramColor;
+ color: @white;
+ background-image: @coloredBackgroundImage;
+ box-shadow: @coloredBoxShadow;
+ }
+ .ui.telegram.button:hover {
+ background-color: @telegramHoverColor;
+ color: @white;
+ }
+ .ui.telegram.button:active {
+ background-color: @telegramDownColor;
+ color: @white;
+ }
}
-/*--------------
+/* --------------
Icon
----------------*/
+--------------- */
.ui.button > .icon:not(.button) {
- height: @iconHeight;
- opacity: @iconOpacity;
- transition: @iconTransition;
- color: @iconColor;
+ height: @iconHeight;
+ opacity: @iconOpacity;
+ transition: @iconTransition;
+ color: @iconColor;
}
.ui.button:not(.icon) > .icon:not(.button):not(.dropdown),
.ui.button:not(.icon) > .icons:not(.button):not(.dropdown) {
- margin: @iconMargin;
- vertical-align: @iconVerticalAlign;
+ margin: @iconMargin;
+ vertical-align: @iconVerticalAlign;
}
.ui.button:not(.icon) > .icons:not(.button):not(.dropdown) > .icon {
- vertical-align: @iconVerticalAlign;
+ vertical-align: @iconVerticalAlign;
}
.ui.button:not(.icon) > .right.icon:not(.button):not(.dropdown) {
- margin: @rightIconMargin;
+ margin: @rightIconMargin;
}
/*******************************
@@ -648,1403 +638,1371 @@
*******************************/
& when (@variationButtonStackable) {
- /*--------------
- Stackable
- ---------------*/
-
- /* Tablet Or Below */
- @media only screen and (max-width: @largestMobileScreen) {
-
- .ui.stackable.buttons {
- flex-direction: column;
- width: 100%;
- & .button:first-child {
- border-bottom-left-radius: 0;
- border-top-right-radius: @borderRadius;
- }
- & .button:last-child {
- border-bottom-left-radius: @borderRadius;
- border-top-right-radius: 0;
- }
- & .button:only-child {
- border-radius: @borderRadius;
- }
+ /* --------------
+ Stackable
+ --------------- */
+
+ /* Tablet Or Below */
+ @media only screen and (max-width: @largestMobileScreen) {
+ .ui.stackable.buttons {
+ flex-direction: column;
+ width: 100%;
+ & .button:first-child {
+ border-bottom-left-radius: 0;
+ border-top-right-radius: @borderRadius;
+ }
+ & .button:last-child {
+ border-bottom-left-radius: @borderRadius;
+ border-top-right-radius: 0;
+ }
+ & .button:only-child {
+ border-radius: @borderRadius;
+ }
+ }
}
-
- }
}
& when (@variationButtonFloated) {
- /*-------------------
- Floated
- --------------------*/
-
- .ui[class*="left floated"].buttons,
- .ui[class*="left floated"].button {
- float: left;
- margin-left: 0;
- margin-right: @floatedMargin;
- }
-
- .ui[class*="right floated"].buttons,
- .ui[class*="right floated"].button {
- float: right;
- margin-right: 0;
- margin-left: @floatedMargin;
- }
+ /* -------------------
+ Floated
+ -------------------- */
+
+ .ui[class*="left floated"].buttons,
+ .ui[class*="left floated"].button {
+ float: left;
+ margin-left: 0;
+ margin-right: @floatedMargin;
+ }
+
+ .ui[class*="right floated"].buttons,
+ .ui[class*="right floated"].button {
+ float: right;
+ margin-right: 0;
+ margin-left: @floatedMargin;
+ }
}
& when (@variationButtonCompact) {
- /*-------------------
- Compact
- --------------------*/
-
- .ui.compact.buttons .button,
- .ui.compact.button {
- padding: @compactVerticalPadding @compactHorizontalPadding ( @compactVerticalPadding + @shadowOffset );
- }
-
- .ui.compact.icon.buttons .button,
- .ui.compact.icon.button {
- padding: @compactVerticalPadding @compactVerticalPadding ( @compactVerticalPadding + @shadowOffset );
- }
-
- .ui.compact.labeled.icon.buttons .button,
- .ui.compact.labeled.icon.button {
- padding: @compactVerticalPadding (@compactHorizontalPadding + @labeledIconWidth) ( @compactVerticalPadding + @shadowOffset );
- }
-
- .ui.compact.labeled.icon.buttons .button > .icon,
- .ui.compact.labeled.icon.button > .icon {
- padding: @compactVerticalPadding 0 @compactVerticalPadding 0;
- }
+ /* -------------------
+ Compact
+ -------------------- */
+
+ .ui.compact.buttons .button,
+ .ui.compact.button {
+ padding: @compactVerticalPadding @compactHorizontalPadding (@compactVerticalPadding + @shadowOffset);
+ }
+
+ .ui.compact.icon.buttons .button,
+ .ui.compact.icon.button {
+ padding: @compactVerticalPadding @compactVerticalPadding (@compactVerticalPadding + @shadowOffset);
+ }
+
+ .ui.compact.labeled.icon.buttons .button,
+ .ui.compact.labeled.icon.button {
+ padding: @compactVerticalPadding (@compactHorizontalPadding + @labeledIconWidth) (@compactVerticalPadding + @shadowOffset);
+ }
+
+ .ui.compact.labeled.icon.buttons .button > .icon,
+ .ui.compact.labeled.icon.button > .icon {
+ padding: @compactVerticalPadding 0;
+ }
}
-/*-------------------
+
+/* -------------------
Sizes
---------------------*/
+-------------------- */
.ui.buttons .button,
.ui.buttons .or,
.ui.button {
- font-size: @medium;
+ font-size: @medium;
}
& when not (@variationButtonSizes = false) {
- each(@variationButtonSizes, {
- @s: @@value;
- .ui.@{value}.buttons .dropdown,
- .ui.@{value}.buttons .dropdown .menu > .item,
- .ui.@{value}.buttons .button,
- .ui.@{value}.buttons .or,
- .ui.ui.ui.ui.@{value}.button {
- font-size: @s;
- }
- })
+ each(@variationButtonSizes, {
+ @s: @@value;
+ .ui.@{value}.buttons .dropdown,
+ .ui.@{value}.buttons .dropdown .menu > .item,
+ .ui.@{value}.buttons .button,
+ .ui.@{value}.buttons .or,
+ .ui.ui.ui.ui.@{value}.button {
+ font-size: @s;
+ }
+ });
}
& when (@variationButtonIcon) {
- /*--------------
- Icon Only
- ---------------*/
-
- .ui.icon.buttons .button,
- .ui.icon.button:not(.animated):not(.compact):not(.labeled) {
- padding: @verticalPadding @verticalPadding ( @verticalPadding + @shadowOffset );
- }
- .ui.animated.icon.button > .content > .icon,
- .ui.icon.buttons .button > .icon,
- .ui.icon.button > .icon {
- opacity: @iconButtonOpacity;
- margin: 0 !important;
- vertical-align: top;
- }
+ /* --------------
+ Icon Only
+ --------------- */
+
+ .ui.icon.buttons .button,
+ .ui.icon.button:not(.animated):not(.compact):not(.labeled) {
+ padding: @verticalPadding @verticalPadding (@verticalPadding + @shadowOffset);
+ }
+ .ui.animated.icon.button > .content > .icon,
+ .ui.icon.buttons .button > .icon,
+ .ui.icon.button > .icon {
+ opacity: @iconButtonOpacity;
+ margin: 0 !important;
+ vertical-align: top;
+ }
}
& when (@variationButtonAnimated) {
- .ui.animated.button > .content > .icon {
- vertical-align: top;
- }
+ .ui.animated.button > .content > .icon {
+ vertical-align: top;
+ }
}
& when (@variationButtonBasic) {
- /*-------------------
- Basic
- --------------------*/
-
- .ui.basic.buttons .button,
- .ui.basic.button {
- background: @basicBackground;
- color: @basicTextColor;
- font-weight: @basicFontWeight;
- border-radius: @basicBorderRadius;
- text-transform: @basicTextTransform;
- text-shadow: none !important;
- box-shadow: @basicBoxShadow;
- }
- & when (@variationButtonGroups) {
- .ui.basic.buttons {
- box-shadow: @basicGroupBoxShadow;
- border: @basicGroupBorder;
- border-radius: @borderRadius;
- border-right: none;
- }
-
- .ui.basic.buttons .button {
- border-radius: 0;
- }
- }
-
- .ui.basic.buttons .button:hover,
- .ui.basic.button:hover {
- background: @basicHoverBackground;
- color: @basicHoverTextColor;
- box-shadow: @basicHoverBoxShadow;
- }
-
- .ui.basic.buttons .button:focus,
- .ui.basic.button:focus {
- background: @basicFocusBackground;
- color: @basicFocusTextColor;
- box-shadow: @basicFocusBoxShadow;
- }
-
- .ui.basic.buttons .button:active,
- .ui.basic.button:active {
- background: @basicDownBackground;
- color: @basicDownTextColor;
- box-shadow: @basicDownBoxShadow;
- }
-
- .ui.basic.buttons .active.button,
- .ui.basic.active.button {
- background: @basicActiveBackground;
- box-shadow: @basicActiveBoxShadow;
- color: @basicActiveTextColor;
- }
-
- .ui.basic.buttons .active.button:hover,
- .ui.basic.active.button:hover {
- background-color: @transparentBlack;
- }
- & when (@variationButtonGroups) {
-
- .ui.basic.buttons .button:hover {
- box-shadow: @basicHoverBoxShadow inset;
- }
-
- .ui.basic.buttons .button:active {
- box-shadow: @basicDownBoxShadow inset;
- }
-
- .ui.basic.buttons .active.button {
- box-shadow: @basicActiveBoxShadow;
- }
- }
- & when (@variationButtonInverted) {
- /* Standard Basic Inverted */
-
- .ui.basic.inverted.buttons .button,
- .ui.basic.inverted.button {
- background-color: transparent;
- color: @offWhite;
- box-shadow: @basicInvertedBoxShadow;
- }
-
- .ui.basic.inverted.buttons .button:hover,
- .ui.basic.inverted.button:hover {
- color: @white;
- box-shadow: @basicInvertedHoverBoxShadow;
- }
-
- .ui.basic.inverted.buttons .button:focus,
- .ui.basic.inverted.button:focus {
- color: @white;
- box-shadow: @basicInvertedFocusBoxShadow;
- }
-
- .ui.basic.inverted.buttons .button:active,
- .ui.basic.inverted.button:active {
- background-color: @transparentWhite;
- color: @white;
- box-shadow: @basicInvertedDownBoxShadow;
- }
+ /* -------------------
+ Basic
+ -------------------- */
+
+ .ui.basic.buttons .button,
+ .ui.basic.button {
+ background: @basicBackground;
+ color: @basicTextColor;
+ font-weight: @basicFontWeight;
+ border-radius: @basicBorderRadius;
+ text-transform: @basicTextTransform;
+ text-shadow: none !important;
+ box-shadow: @basicBoxShadow;
+ }
+ & when (@variationButtonGroups) {
+ .ui.basic.buttons {
+ box-shadow: @basicGroupBoxShadow;
+ border: @basicGroupBorder;
+ border-radius: @borderRadius;
+ border-right: none;
+ }
- .ui.basic.inverted.buttons .active.button,
- .ui.basic.inverted.active.button {
- background-color: @transparentWhite;
- color: @invertedTextColor;
- text-shadow: @invertedTextShadow;
- box-shadow: @basicInvertedActiveBoxShadow;
+ .ui.basic.buttons .button {
+ border-radius: 0;
+ }
}
- .ui.basic.inverted.buttons .active.button:hover,
- .ui.basic.inverted.active.button:hover {
- background-color: @strongTransparentWhite;
- box-shadow: @basicInvertedHoverBoxShadow;
+ .ui.basic.buttons .button:hover,
+ .ui.basic.button:hover {
+ background: @basicHoverBackground;
+ color: @basicHoverTextColor;
+ box-shadow: @basicHoverBoxShadow;
}
- }
- & when (@variationButtonGroups) {
- /* Basic Group */
- .ui.basic.buttons:not(.inverted) .button:not(.basic) {
- border-right: @basicGroupBorder;
- box-shadow: none;
+ .ui.basic.buttons .button:focus,
+ .ui.basic.button:focus {
+ background: @basicFocusBackground;
+ color: @basicFocusTextColor;
+ box-shadow: @basicFocusBoxShadow;
}
- & when (@variationButtonVertical) {
- .ui.basic.vertical.buttons .button {
- border-left: none;
- border-left-width: 0;
- border-top: @basicGroupBorder;
- }
+ .ui.basic.buttons .button:active,
+ .ui.basic.button:active {
+ background: @basicDownBackground;
+ color: @basicDownTextColor;
+ box-shadow: @basicDownBoxShadow;
+ }
- .ui.basic.vertical.buttons:not(.spaced) .button:first-child {
- border-top: none;
- }
+ .ui.basic.buttons .active.button,
+ .ui.basic.active.button {
+ background: @basicActiveBackground;
+ box-shadow: @basicActiveBoxShadow;
+ color: @basicActiveTextColor;
}
- }
-}
-& when (@variationButtonTertiary) {
- /*-------------------
- Tertiary
- --------------------*/
+ .ui.basic.buttons .active.button:hover,
+ .ui.basic.active.button:hover {
+ background-color: @transparentBlack;
+ }
+ & when (@variationButtonGroups) {
+ .ui.basic.buttons .button:hover {
+ box-shadow: @basicHoverBoxShadow;
+ }
- /* Overline Mixin */
- .ui.tertiary.button {
- transition: color @defaultDuration @defaultEasing !important;
- border-radius: 0;
- margin: (@verticalPadding - @tertiaryVerticalPadding)
- (@horizontalMargin)
- (@verticalPadding + @shadowOffset + @verticalMargin - @tertiaryVerticalPadding)
- 0 !important;
- padding: @tertiaryVerticalPadding @tertiaryHorizontalPadding !important;
+ .ui.basic.buttons .button:active {
+ box-shadow: @basicDownBoxShadow;
+ }
- & when (@tertiaryWithUnderline = true) {
- box-shadow: inset 0 -@tertiaryLineHeight 0 @tertiaryLineColor;
+ .ui.basic.buttons .active.button {
+ box-shadow: @basicActiveBoxShadow;
+ }
}
+ & when (@variationButtonInverted) {
+ /* Standard Basic Inverted */
- & when (@tertiaryWithOverline = true) {
- box-shadow: inset 0 @tertiaryLineHeight 0 @tertiaryLineColor;
- }
+ .ui.basic.inverted.buttons .button,
+ .ui.basic.inverted.button {
+ background-color: transparent;
+ color: @offWhite;
+ box-shadow: @basicInvertedBoxShadow;
+ }
- & when (@tertiaryWithUnderline = false) and (@tertiaryWithOverline = false){
- box-shadow: none;
- }
+ .ui.basic.inverted.buttons .button:hover,
+ .ui.basic.inverted.button:hover {
+ color: @white;
+ box-shadow: @basicInvertedHoverBoxShadow;
+ }
- color: @tertiaryTextColor;
- background: @tertiaryBackgroundColor;
- }
+ .ui.basic.inverted.buttons .button:focus,
+ .ui.basic.inverted.button:focus {
+ color: @white;
+ box-shadow: @basicInvertedFocusBoxShadow;
+ }
- .ui.tertiary.button:hover {
+ .ui.basic.inverted.buttons .button:active,
+ .ui.basic.inverted.button:active {
+ background-color: @transparentWhite;
+ color: @white;
+ box-shadow: @basicInvertedDownBoxShadow;
+ }
- & when (@tertiaryHoverWithUnderline = true) {
- box-shadow: inset 0 -@tertiaryLineHeight 0 @tertiaryHoverLineColor;
- }
+ .ui.basic.inverted.buttons .active.button,
+ .ui.basic.inverted.active.button {
+ background-color: @transparentWhite;
+ color: @invertedTextColor;
+ text-shadow: @invertedTextShadow;
+ box-shadow: @basicInvertedActiveBoxShadow;
+ }
- & when (@tertiaryHoverWithOverline = true) {
- box-shadow: inset 0 @tertiaryLineHeight 0 @tertiaryHoverLineColor;
+ .ui.basic.inverted.buttons .active.button:hover,
+ .ui.basic.inverted.active.button:hover {
+ background-color: @strongTransparentWhite;
+ box-shadow: @basicInvertedHoverBoxShadow;
+ }
}
- & when (@tertiaryHoverWithUnderline = false) and (@tertiaryHoverWithOverline = false) {
- box-shadow: none;
+ & when (@variationButtonGroups) {
+ /* Basic Group */
+ .ui.basic.buttons:not(.inverted) .button:not(.basic) {
+ border-right: @basicGroupBorder;
+ box-shadow: none;
+ }
+
+ & when (@variationButtonVertical) {
+ .ui.basic.vertical.buttons .button {
+ border-left: none;
+ border-left-width: 0;
+ border-top: @basicGroupBorder;
+ }
+
+ .ui.basic.vertical.buttons:not(.spaced) .button:first-child {
+ border-top: none;
+ }
+ }
}
+}
+
+& when (@variationButtonTertiary) {
+ /* -------------------
+ Tertiary
+ -------------------- */
+
+ /* Overline Mixin */
+ .ui.tertiary.button {
+ transition: color @defaultDuration @defaultEasing !important;
+ border-radius: 0;
+ // prettier-ignore
+ margin:
+ (@verticalPadding - @tertiaryVerticalPadding)
+ (@horizontalMargin)
+ (@verticalPadding + @shadowOffset + @verticalMargin - @tertiaryVerticalPadding)
+ 0 !important;
+ padding: @tertiaryVerticalPadding @tertiaryHorizontalPadding !important;
- color: @tertiaryHoverColor;
- background: @tertiaryHoverBackgroundColor;
- }
+ & when (@tertiaryWithUnderline = true) {
+ box-shadow: inset 0 -@tertiaryLineHeight 0 @tertiaryLineColor;
+ }
+
+ & when (@tertiaryWithOverline = true) {
+ box-shadow: inset 0 @tertiaryLineHeight 0 @tertiaryLineColor;
+ }
+
+ & when (@tertiaryWithUnderline = false) and (@tertiaryWithOverline = false) {
+ box-shadow: none;
+ }
- .ui.tertiary.button:focus {
- & when (@tertiaryFocusWithUnderline = true) {
- box-shadow: inset 0 -@tertiaryLineHeight 0 @tertiaryFocusLineColor;
+ color: @tertiaryTextColor;
+ background: @tertiaryBackgroundColor;
}
- & when (@tertiaryFocusWithOverline = true) {
- box-shadow: inset 0 @tertiaryLineHeight 0 @tertiaryFocusLineColor;
+ .ui.tertiary.button:hover {
+ & when (@tertiaryHoverWithUnderline = true) {
+ box-shadow: inset 0 -@tertiaryLineHeight 0 @tertiaryHoverLineColor;
+ }
+
+ & when (@tertiaryHoverWithOverline = true) {
+ box-shadow: inset 0 @tertiaryLineHeight 0 @tertiaryHoverLineColor;
+ }
+
+ & when (@tertiaryHoverWithUnderline = false) and (@tertiaryHoverWithOverline = false) {
+ box-shadow: none;
+ }
+
+ color: @tertiaryHoverColor;
+ background: @tertiaryHoverBackgroundColor;
}
- & when (@tertiaryFocusWithUnderline = false) and (@tertiaryFocusWithOverline = false){
- box-shadow: none;
+ .ui.tertiary.button:focus {
+ & when (@tertiaryFocusWithUnderline = true) {
+ box-shadow: inset 0 -@tertiaryLineHeight 0 @tertiaryFocusLineColor;
+ }
+
+ & when (@tertiaryFocusWithOverline = true) {
+ box-shadow: inset 0 @tertiaryLineHeight 0 @tertiaryFocusLineColor;
+ }
+
+ & when (@tertiaryFocusWithUnderline = false) and (@tertiaryFocusWithOverline = false) {
+ box-shadow: none;
+ }
+
+ color: @tertiaryFocusColor;
+ background: @tertiaryFocusBackgroundColor;
}
- color: @tertiaryFocusColor;
- background: @tertiaryFocusBackgroundColor;
- }
+ .ui.tertiary.button:active {
+ & when (@tertiaryActiveWithUnderline = true) {
+ box-shadow: inset 0 -@tertiaryLineHeight 0 @tertiaryActiveLineColor;
+ border-radius: @borderRadius @borderRadius 0 0;
+ }
+
+ & when (@tertiaryActiveWithOverline = true) {
+ box-shadow: inset 0 @tertiaryLineHeight 0 @tertiaryActiveLineColor;
+ border-radius: 0 0 @borderRadius @borderRadius;
+ }
+
+ & when (@tertiaryActiveWithUnderline = false) and (@tertiaryActiveWithOverline = false) {
+ box-shadow: none;
+ border-radius: 0;
+ }
+
+ color: @tertiaryActiveColor;
+ background: @tertiaryActiveBackgroundColor;
+ }
+}
- .ui.tertiary.button:active {
- & when (@tertiaryActiveWithUnderline = true) {
- box-shadow: inset 0 -@tertiaryLineHeight 0 @tertiaryActiveLineColor;
- border-radius: @borderRadius @borderRadius 0 0;
+& when (@variationButtonLabeledIcon) {
+ /* --------------
+ Labeled Icon
+ --------------- */
+
+ .ui.labeled.icon.buttons .button,
+ .ui.labeled.icon.button {
+ position: relative;
+ padding-left: @labeledIconPadding !important;
+ padding-right: @horizontalPadding !important;
+ }
+
+ /* Left Labeled */
+ .ui.labeled.icon.buttons > .button > .icon,
+ .ui.labeled.icon.button > .icon {
+ position: absolute;
+ top: 0;
+ left: 0;
+ height: 100%;
+ line-height: 1;
+ border-radius: 0;
+ border-top-left-radius: inherit;
+ border-bottom-left-radius: inherit;
+ text-align: center;
+ animation: none;
+ padding: @verticalPadding 0;
+ margin: @labeledIconMargin;
+ width: @labeledIconWidth;
+ background-color: @labeledIconBackgroundColor;
+ color: @labeledIconColor;
+ box-shadow: @labeledIconLeftShadow;
+ }
+
+ /* Right Labeled */
+ .ui[class*="right labeled"].icon.button {
+ padding-right: @labeledIconPadding !important;
+ padding-left: @horizontalPadding !important;
+ }
+
+ .ui[class*="right labeled"].icon.button > .icon {
+ left: auto;
+ right: 0;
+ border-radius: 0;
+ border-top-right-radius: inherit;
+ border-bottom-right-radius: inherit;
+ box-shadow: @labeledIconRightShadow;
+ }
+
+ .ui.labeled.icon.buttons > .button > .icon::before,
+ .ui.labeled.icon.button > .icon::before,
+ .ui.labeled.icon.buttons > .button > .icon::after,
+ .ui.labeled.icon.button > .icon::after {
+ display: block;
+ position: relative;
+ width: 100%;
+ top: 0;
+ text-align: center;
+ }
+
+ .ui.labeled.icon.buttons .button > .icon {
+ border-radius: 0;
+ }
+
+ .ui.labeled.icon.buttons .button:first-child > .icon {
+ border-top-left-radius: @borderRadius;
+ border-bottom-left-radius: @borderRadius;
}
- & when (@tertiaryActiveWithOverline = true) {
- box-shadow: inset 0 @tertiaryLineHeight 0 @tertiaryActiveLineColor;
- border-radius: 0 0 @borderRadius @borderRadius;
+ .ui.labeled.icon.buttons .button:last-child > .icon {
+ border-top-right-radius: @borderRadius;
+ border-bottom-right-radius: @borderRadius;
}
- & when (@tertiaryActiveWithUnderline = false) and (@tertiaryActiveWithOverline = false){
- box-shadow: none;
- border-radius: 0;
+ .ui.vertical.labeled.icon.buttons .button:first-child > .icon {
+ border-radius: 0;
+ border-top-left-radius: @borderRadius;
}
- color: @tertiaryActiveColor;
- background: @tertiaryActiveBackgroundColor;
- }
-}
+ .ui.vertical.labeled.icon.buttons .button:last-child > .icon {
+ border-radius: 0;
+ border-bottom-left-radius: @borderRadius;
+ }
-& when (@variationButtonLabeledIcon) {
- /*--------------
- Labeled Icon
- ---------------*/
-
- .ui.labeled.icon.buttons .button,
- .ui.labeled.icon.button {
- position: relative;
- padding-left: @labeledIconPadding !important;
- padding-right: @horizontalPadding !important;
- }
-
- /* Left Labeled */
- .ui.labeled.icon.buttons > .button > .icon,
- .ui.labeled.icon.button > .icon {
- position: absolute;
- top: 0;
- left: 0;
- height: 100%;
- line-height: 1;
- border-radius: 0;
- border-top-left-radius: inherit;
- border-bottom-left-radius: inherit;
- text-align: center;
- animation: none;
- padding: @verticalPadding 0 @verticalPadding 0;
-
- margin: @labeledIconMargin;
- width: @labeledIconWidth;
- background-color: @labeledIconBackgroundColor;
- color: @labeledIconColor;
- box-shadow: @labeledIconLeftShadow;
- }
-
- /* Right Labeled */
- .ui[class*="right labeled"].icon.button {
- padding-right: @labeledIconPadding !important;
- padding-left: @horizontalPadding !important;
- }
-
- .ui[class*="right labeled"].icon.button > .icon {
- left: auto;
- right: 0;
- border-radius: 0;
- border-top-right-radius: inherit;
- border-bottom-right-radius: inherit;
- box-shadow: @labeledIconRightShadow;
- }
-
-
- .ui.labeled.icon.buttons > .button > .icon::before,
- .ui.labeled.icon.button > .icon::before,
- .ui.labeled.icon.buttons > .button > .icon::after,
- .ui.labeled.icon.button > .icon::after {
- display: block;
- position: relative;
- width: 100%;
- top: 0;
- text-align: center;
- }
-
- .ui.labeled.icon.buttons .button > .icon {
- border-radius: 0;
- }
-
- .ui.labeled.icon.buttons .button:first-child > .icon {
- border-top-left-radius: @borderRadius;
- border-bottom-left-radius: @borderRadius;
- }
-
- .ui.labeled.icon.buttons .button:last-child > .icon {
- border-top-right-radius: @borderRadius;
- border-bottom-right-radius: @borderRadius;
- }
-
- .ui.vertical.labeled.icon.buttons .button:first-child > .icon {
- border-radius: 0;
- border-top-left-radius: @borderRadius;
- }
-
- .ui.vertical.labeled.icon.buttons .button:last-child > .icon {
- border-radius: 0;
- border-bottom-left-radius: @borderRadius;
- }
-
- /* Loading Icon in Labeled Button */
- .ui.labeled.icon.button > .loading.icon::before {
- animation: loader 2s linear infinite;
- }
+ /* Loading Icon in Labeled Button */
+ .ui.labeled.icon.button > .loading.icon::before {
+ animation: loader 2s linear infinite;
+ }
}
& when (@variationButtonToggle) {
- /*--------------
- Toggle
- ---------------*/
-
- /* Toggle (Modifies active state to give affordances) */
- .ui.toggle.buttons .active.button,
- .ui.buttons .button.toggle.active,
- .ui.button.toggle.active {
- background-color: @toggleBackgroundColor;
- box-shadow: none;
- text-shadow: @toggleTextShadow;
- color: @toggleColor;
- }
-
- .ui.button.toggle.active:hover {
- background-color: @toggleHoverBackgroundColor;
- text-shadow: @toggleHoverTextShadow;
- color: @toggleHoverColor;
- }
+ /* --------------
+ Toggle
+ --------------- */
+
+ /* Toggle (Modifies active state to give affordances) */
+ .ui.toggle.buttons .active.button,
+ .ui.buttons .button.toggle.active,
+ .ui.button.toggle.active {
+ background-color: @toggleBackgroundColor;
+ box-shadow: none;
+ text-shadow: @toggleTextShadow;
+ color: @toggleColor;
+ }
+
+ .ui.button.toggle.active:hover {
+ background-color: @toggleHoverBackgroundColor;
+ text-shadow: @toggleHoverTextShadow;
+ color: @toggleHoverColor;
+ }
}
& when (@variationButtonCircular) {
- /*--------------
- Circular
- ---------------*/
-
- .ui.circular.button {
- border-radius: @circularBorderRadius;
- }
-
- .ui.circular.button > .icon {
- width: @circularIconWidth;
- vertical-align: baseline;
- }
+ /* --------------
+ Circular
+ --------------- */
+
+ .ui.circular.button {
+ border-radius: @circularBorderRadius;
+ }
+
+ .ui.circular.button > .icon {
+ width: @circularIconWidth;
+ vertical-align: baseline;
+ }
}
& when (@variationButtonOr) {
- /*-------------------
- Or Buttons
- --------------------*/
-
- .ui.buttons .or {
- position: relative;
- width: @orGap;
- height: @orHeight;
- z-index: @orZIndex;
- }
-
- .ui.buttons .or::before {
- position: absolute;
- text-align: center;
- border-radius: @circularRadius;
+ /* -------------------
+ Or Buttons
+ -------------------- */
- content: @orText;
- top: 50%;
- left: 50%;
- background-color: @orBackgroundColor;
- text-shadow: @orTextShadow;
+ .ui.buttons .or {
+ position: relative;
+ width: @orGap;
+ height: @orHeight;
+ z-index: @orZIndex;
+ }
- margin-top: @orVerticalOffset;
- margin-left: @orHorizontalOffset;
+ .ui.buttons .or::before {
+ position: absolute;
+ text-align: center;
+ border-radius: @circularRadius;
+ content: @orText;
+ top: 50%;
+ left: 50%;
+ background-color: @orBackgroundColor;
+ text-shadow: @orTextShadow;
+ margin-top: @orVerticalOffset;
+ margin-left: @orHorizontalOffset;
+ width: @orCircleSize;
+ height: @orCircleSize;
+ line-height: @orLineHeight;
+ color: @orTextColor;
+ font-style: @orTextStyle;
+ font-weight: @orTextWeight;
+ box-shadow: @orBoxShadow;
+ }
- width: @orCircleSize;
- height: @orCircleSize;
+ .ui.buttons .or[data-text]::before {
+ content: attr(data-text);
+ }
- line-height: @orLineHeight;
- color: @orTextColor;
+ /* Fluid Or */
+ .ui.fluid.buttons .or {
+ width: 0 !important;
+ }
- font-style: @orTextStyle;
- font-weight: @orTextWeight;
+ .ui.fluid.buttons .or::after {
+ display: none;
+ }
+}
- box-shadow: @orBoxShadow;
- }
+& when (@variationButtonAttached) {
+ /* -------------------
+ Attached
+ -------------------- */
- .ui.buttons .or[data-text]::before {
- content: attr(data-text);
- }
+ /* Singular */
+ .ui.attached.button {
+ position: relative;
+ display: block;
+ margin: 0;
+ border-radius: 0;
+ box-shadow: @attachedBoxShadow;
+ }
- /* Fluid Or */
- .ui.fluid.buttons .or {
- width: 0 !important;
- }
+ /* Top / Bottom */
+ .ui.attached.top.button {
+ border-radius: @borderRadius @borderRadius 0 0;
+ }
- .ui.fluid.buttons .or::after {
- display: none;
- }
+ .ui.attached.bottom.button {
+ border-radius: 0 0 @borderRadius @borderRadius;
+ }
-}
+ /* Left / Right */
+ .ui.left.attached.button {
+ display: inline-block;
+ border-left: none;
+ text-align: right;
+ padding-right: @attachedHorizontalPadding;
+ border-radius: @borderRadius 0 0 @borderRadius;
+ }
-& when (@variationButtonAttached) {
- /*-------------------
- Attached
- --------------------*/
-
-
- /* Singular */
- .ui.attached.button {
- position: relative;
- display: block;
- margin: 0;
- border-radius: 0;
- box-shadow: @attachedBoxShadow;
- }
-
- /* Top / Bottom */
- .ui.attached.top.button {
- border-radius: @borderRadius @borderRadius 0 0;
- }
-
- .ui.attached.bottom.button {
- border-radius: 0 0 @borderRadius @borderRadius;
- }
-
- /* Left / Right */
- .ui.left.attached.button {
- display: inline-block;
- border-left: none;
- text-align: right;
+ .ui.right.attached.button {
+ display: inline-block;
+ text-align: left;
+ padding-left: @attachedHorizontalPadding;
+ border-radius: 0 @borderRadius @borderRadius 0;
+ }
- padding-right: @attachedHorizontalPadding;
- border-radius: @borderRadius 0 0 @borderRadius;
- }
+ /* Plural */
+ .ui.attached.buttons {
+ position: relative;
+ display: flex;
+ border-radius: 0;
+ width: auto !important;
+ z-index: @attachedZIndex;
+ margin-left: @attachedOffset;
+ margin-right: @attachedOffset;
+ }
- .ui.right.attached.button {
- display: inline-block;
- text-align: left;
- padding-left: @attachedHorizontalPadding;
- border-radius: 0 @borderRadius @borderRadius 0;
- }
-
- /* Plural */
- .ui.attached.buttons {
- position: relative;
- display: flex;
- border-radius: 0;
- width: auto !important;
- z-index: @attachedZIndex;
- margin-left: @attachedOffset;
- margin-right: @attachedOffset;
- }
-
- .ui.attached.buttons .button {
- margin: 0;
- }
-
- .ui.attached.buttons .button:first-child {
- border-radius: 0;
- }
-
- .ui.attached.buttons .button:last-child {
- border-radius: 0;
- }
-
- /* Top / Bottom */
- .ui[class*="top attached"].buttons {
- margin-bottom: @topAttachedOffset;
- border-radius: @borderRadius @borderRadius 0 0;
- }
-
- .ui[class*="top attached"].buttons .button:first-child {
- border-radius: @borderRadius 0 0 0;
- }
-
- .ui[class*="top attached"].buttons .button:last-child {
- border-radius: 0 @borderRadius 0 0;
- }
-
- .ui[class*="bottom attached"].buttons {
- margin-top: @bottomAttachedOffset;
- border-radius: 0 0 @borderRadius @borderRadius;
- }
-
- .ui[class*="bottom attached"].buttons .button:first-child {
- border-radius: 0 0 0 @borderRadius;
- }
-
- .ui[class*="bottom attached"].buttons .button:last-child {
- border-radius: 0 0 @borderRadius 0;
- }
-
- /* Left / Right */
- .ui[class*="left attached"].buttons {
- display: inline-flex;
- margin-right: 0;
- margin-left: @attachedOffset;
- border-radius: 0 @borderRadius @borderRadius 0;
- }
-
- .ui[class*="left attached"].buttons .button:first-child {
- margin-left: @attachedOffset;
- border-radius: 0 @borderRadius 0 0;
- }
-
- .ui[class*="left attached"].buttons .button:last-child {
- margin-left: @attachedOffset;
- border-radius: 0 0 @borderRadius 0;
- }
-
- .ui[class*="right attached"].buttons {
- display: inline-flex;
- margin-left: 0;
- margin-right: @attachedOffset;
- border-radius: @borderRadius 0 0 @borderRadius;
- }
-
- .ui[class*="right attached"].buttons .button:first-child {
- margin-left: @attachedOffset;
- border-radius: @borderRadius 0 0 0;
- }
-
- .ui[class*="right attached"].buttons .button:last-child {
- margin-left: @attachedOffset;
- border-radius: 0 0 0 @borderRadius;
- }
-}
+ .ui.attached.buttons .button {
+ margin: 0;
+ }
-& when (@variationButtonFluid) {
- /*-------------------
- Fluid
- --------------------*/
-
- .ui.fluid.buttons,
- .ui.fluid.button {
- width: 100%;
- }
-
- .ui.fluid.button {
- display: block;
- }
-}
-& when (@variationButtonEqualWidth) {
- .ui.two.buttons {
- width: 100%;
- }
+ .ui.attached.buttons .button:first-child {
+ border-radius: 0;
+ }
- .ui.two.buttons > .button {
- width: 50%;
- }
+ .ui.attached.buttons .button:last-child {
+ border-radius: 0;
+ }
- .ui.three.buttons {
- width: 100%;
- }
+ /* Top / Bottom */
+ .ui[class*="top attached"].buttons {
+ margin-bottom: @topAttachedOffset;
+ border-radius: @borderRadius @borderRadius 0 0;
+ }
- .ui.three.buttons > .button {
- width: 33.333%;
- }
+ .ui[class*="top attached"].buttons .button:first-child {
+ border-radius: @borderRadius 0 0 0;
+ }
- .ui.four.buttons {
- width: 100%;
- }
+ .ui[class*="top attached"].buttons .button:last-child {
+ border-radius: 0 @borderRadius 0 0;
+ }
- .ui.four.buttons > .button {
- width: 25%;
- }
+ .ui[class*="bottom attached"].buttons {
+ margin-top: @bottomAttachedOffset;
+ border-radius: 0 0 @borderRadius @borderRadius;
+ }
- .ui.five.buttons {
- width: 100%;
- }
+ .ui[class*="bottom attached"].buttons .button:first-child {
+ border-radius: 0 0 0 @borderRadius;
+ }
- .ui.five.buttons > .button {
- width: 20%;
- }
+ .ui[class*="bottom attached"].buttons .button:last-child {
+ border-radius: 0 0 @borderRadius 0;
+ }
- .ui.six.buttons {
- width: 100%;
- }
+ /* Left / Right */
+ .ui[class*="left attached"].buttons {
+ display: inline-flex;
+ margin-right: 0;
+ margin-left: @attachedOffset;
+ border-radius: 0 @borderRadius @borderRadius 0;
+ }
- .ui.six.buttons > .button {
- width: 16.666%;
- }
+ .ui[class*="left attached"].buttons .button:first-child {
+ margin-left: @attachedOffset;
+ border-radius: 0 @borderRadius 0 0;
+ }
- .ui.seven.buttons {
- width: 100%;
- }
+ .ui[class*="left attached"].buttons .button:last-child {
+ margin-left: @attachedOffset;
+ border-radius: 0 0 @borderRadius 0;
+ }
- .ui.seven.buttons > .button {
- width: 14.285%;
- }
+ .ui[class*="right attached"].buttons {
+ display: inline-flex;
+ margin-left: 0;
+ margin-right: @attachedOffset;
+ border-radius: @borderRadius 0 0 @borderRadius;
+ }
- .ui.eight.buttons {
- width: 100%;
- }
+ .ui[class*="right attached"].buttons .button:first-child {
+ margin-left: @attachedOffset;
+ border-radius: @borderRadius 0 0 0;
+ }
- .ui.eight.buttons > .button {
- width: 12.500%;
- }
+ .ui[class*="right attached"].buttons .button:last-child {
+ margin-left: @attachedOffset;
+ border-radius: 0 0 0 @borderRadius;
+ }
+}
- .ui.nine.buttons {
- width: 100%;
- }
+& when (@variationButtonFluid) {
+ /* -------------------
+ Fluid
+ -------------------- */
- .ui.nine.buttons > .button {
- width: 11.11%;
- }
+ .ui.fluid.buttons,
+ .ui.fluid.button {
+ width: 100%;
+ }
- .ui.ten.buttons {
- width: 100%;
- }
+ .ui.fluid.button {
+ display: block;
+ }
+}
+& when (@variationButtonEqualWidth) {
+ .ui.two.buttons {
+ width: 100%;
+ }
- .ui.ten.buttons > .button {
- width: 10%;
- }
+ .ui.two.buttons > .button {
+ width: 50%;
+ }
- .ui.eleven.buttons {
- width: 100%;
- }
+ .ui.three.buttons {
+ width: 100%;
+ }
- .ui.eleven.buttons > .button {
- width: 9.09%;
- }
+ .ui.three.buttons > .button {
+ width: 33.333%;
+ }
- .ui.twelve.buttons {
- width: 100%;
- }
+ .ui.four.buttons {
+ width: 100%;
+ }
- .ui.twelve.buttons > .button {
- width: 8.3333%;
- }
-}
+ .ui.four.buttons > .button {
+ width: 25%;
+ }
-& when (@variationButtonVertical) {
- & when (@variationButtonFluid) {
- /* Fluid Vertical Buttons */
- .ui.fluid.vertical.buttons,
- .ui.fluid.vertical.buttons > .button {
- display: flex;
- width: auto;
- justify-content: center;
+ .ui.five.buttons {
+ width: 100%;
}
- }
- & when (@variationButtonEqualWidth) {
- .ui.two.vertical.buttons > .button {
- height: 50%;
+ .ui.five.buttons > .button {
+ width: 20%;
}
- .ui.three.vertical.buttons > .button {
- height: 33.333%;
+ .ui.six.buttons {
+ width: 100%;
}
- .ui.four.vertical.buttons > .button {
- height: 25%;
+ .ui.six.buttons > .button {
+ width: 16.666%;
}
- .ui.five.vertical.buttons > .button {
- height: 20%;
+ .ui.seven.buttons {
+ width: 100%;
}
- .ui.six.vertical.buttons > .button {
- height: 16.666%;
+ .ui.seven.buttons > .button {
+ width: 14.285%;
}
- .ui.seven.vertical.buttons > .button {
- height: 14.285%;
+ .ui.eight.buttons {
+ width: 100%;
}
- .ui.eight.vertical.buttons > .button {
- height: 12.500%;
+ .ui.eight.buttons > .button {
+ width: 12.5%;
}
- .ui.nine.vertical.buttons > .button {
- height: 11.11%;
+ .ui.nine.buttons {
+ width: 100%;
}
- .ui.ten.vertical.buttons > .button {
- height: 10%;
+ .ui.nine.buttons > .button {
+ width: 11.11%;
}
- .ui.eleven.vertical.buttons > .button {
- height: 9.09%;
+ .ui.ten.buttons {
+ width: 100%;
}
- .ui.twelve.vertical.buttons > .button {
- height: 8.3333%;
+ .ui.ten.buttons > .button {
+ width: 10%;
}
- }
-}
-/*-------------------
- Colors
---------------------*/
+ .ui.eleven.buttons {
+ width: 100%;
+ }
-& when not (@variationButtonColors = false) {
- each(@variationButtonColors, {
- @color: @value;
- @c: @colors[@@color][color];
- @h: @colors[@@color][hover];
- @f: @colors[@@color][focus];
- @d: @colors[@@color][down];
- @a: @colors[@@color][active];
- @t: @colors[@@color][text];
- @s: @colors[@@color][shadow];
- @l: @colors[@@color][light];
- @lh: @colors[@@color][lightHover];
- @lf: @colors[@@color][lightFocus];
- @ld: @colors[@@color][lightDown];
- @la: @colors[@@color][lightActive];
- @lt: @colors[@@color][lightText];
- @ls: @colors[@@color][lightShadow];
- @ty: @colors[@@color][tertiary];
- @tyh: @colors[@@color][tertiaryHover];
- @tyf: @colors[@@color][tertiaryFocus];
- @tya: @colors[@@color][tertiaryActive];
- @isDark: @colors[@@color][isDark];
- @isVeryDark: @colors[@@color][isVeryDark];
-
- .ui.@{color}.buttons .button,
- .ui.@{color}.button {
- background-color: @c;
- color: @t;
- text-shadow: @s;
- background-image: @coloredBackgroundImage;
- }
- .ui.@{color}.button {
- box-shadow: @coloredBoxShadow;
- }
- .ui.@{color}.buttons .button:hover,
- .ui.@{color}.button:hover {
- background-color: @h;
- color: @t;
- text-shadow: @s;
- }
- .ui.@{color}.buttons .button:focus,
- .ui.@{color}.button:focus {
- background-color: @f;
- color: @t;
- text-shadow: @s;
- }
- .ui.@{color}.buttons .button:active,
- .ui.@{color}.button:active {
- background-color: @d;
- color: @t;
- text-shadow: @s;
- }
- .ui.@{color}.buttons .active.button,
- .ui.@{color}.buttons .active.button:active,
- .ui.@{color}.active.button,
- .ui.@{color}.button .active.button:active {
- background-color: @a;
- color: @t;
- text-shadow: @s;
+ .ui.eleven.buttons > .button {
+ width: 9.09%;
}
- & when (@variationButtonBasic) {
- /* Basic */
- .ui.basic.@{color}.buttons .button,
- .ui.basic.@{color}.button {
- background: transparent;
- box-shadow: 0 0 0 @basicBorderSize @c inset;
- color: @c;
- }
- .ui.basic.@{color}.buttons .button:hover,
- .ui.basic.@{color}.button:hover {
- background: transparent;
- box-shadow: 0 0 0 @basicColoredBorderSize @h inset;
- color: @h;
- }
- .ui.basic.@{color}.buttons .button:focus,
- .ui.basic.@{color}.button:focus {
- background: transparent;
- box-shadow: 0 0 0 @basicColoredBorderSize @f inset;
- color: @h;
- }
- .ui.basic.@{color}.buttons .active.button,
- .ui.basic.@{color}.active.button {
- background: transparent;
- box-shadow: 0 0 0 @basicColoredBorderSize @a inset;
- color: @d;
- }
- .ui.basic.@{color}.buttons .button:active,
- .ui.basic.@{color}.button:active {
- box-shadow: 0 0 0 @basicColoredBorderSize @d inset;
- color: @d;
- }
+ .ui.twelve.buttons {
+ width: 100%;
}
- & when (@variationButtonInverted) {
- /* Inverted */
- .ui.inverted.@{color}.buttons .button,
- .ui.inverted.@{color}.button {
- background-color: transparent;
- & when (@isDark) {
- box-shadow: 0 0 0 @invertedBorderSize @solidBorderColor inset;
- color: @invertedTextColor;
- }
+ .ui.twelve.buttons > .button {
+ width: 8.3333%;
+ }
+}
- & when not (@isDark) {
- box-shadow: 0 0 0 @invertedBorderSize @l inset;
- color: @l;
+& when (@variationButtonVertical) {
+ & when (@variationButtonFluid) {
+ /* Fluid Vertical Buttons */
+ .ui.fluid.vertical.buttons,
+ .ui.fluid.vertical.buttons > .button {
+ display: flex;
+ width: auto;
+ justify-content: center;
}
- }
- .ui.inverted.@{color}.buttons .button:hover,
- .ui.inverted.@{color}.button:hover,
- .ui.inverted.@{color}.buttons .button:focus,
- .ui.inverted.@{color}.button:focus,
- .ui.inverted.@{color}.buttons .button.active,
- .ui.inverted.@{color}.button.active,
- .ui.inverted.@{color}.buttons .button:active,
- .ui.inverted.@{color}.button:active {
- box-shadow: none;
- color: @lt;
- }
- .ui.inverted.@{color}.buttons .button:hover,
- .ui.inverted.@{color}.button:hover {
- background-color: @lh;
- }
- .ui.inverted.@{color}.buttons .button:focus,
- .ui.inverted.@{color}.button:focus {
- background-color: @lf;
- }
- .ui.inverted.@{color}.buttons .active.button,
- .ui.inverted.@{color}.active.button {
- background-color: @la;
- }
- .ui.inverted.@{color}.buttons .button:active,
- .ui.inverted.@{color}.button:active {
- background-color: @ld;
- }
-
- /* Inverted Basic */
- .ui.inverted.@{color}.basic.buttons .button,
- .ui.inverted.@{color}.buttons .basic.button,
- .ui.inverted.@{color}.basic.button {
- background-color: transparent;
- box-shadow: @basicInvertedBoxShadow;
- color: @white;
- }
- .ui.inverted.@{color}.basic.buttons .button:hover,
- .ui.inverted.@{color}.buttons .basic.button:hover,
- .ui.inverted.@{color}.basic.button:hover {
- box-shadow: 0 0 0 @invertedBorderSize @lh inset;
-
- & when (@isDark) {
- color: @white;
- }
-
- & when not (@isDark) {
- color: @l;
- }
- }
- .ui.inverted.@{color}.basic.buttons .button:focus,
- .ui.inverted.@{color}.basic.buttons .button:focus,
- .ui.inverted.@{color}.basic.button:focus {
- box-shadow: 0 0 0 @invertedBorderSize @lf inset;
- color: @l;
- }
- .ui.inverted.@{color}.basic.buttons .active.button,
- .ui.inverted.@{color}.buttons .basic.active.button,
- .ui.inverted.@{color}.basic.active.button {
- box-shadow: 0 0 0 @invertedBorderSize @la inset;
-
- & when (@isDark) {
- color: @white;
- }
-
- & when not (@isDark) {
- color: @l;
- }
- }
- & when (@variationButtonBasic) {
- .ui.inverted.@{color}.basic.buttons .button:active,
- .ui.inverted.@{color}.buttons .basic.button:active,
- .ui.inverted.@{color}.basic.button:active {
- box-shadow: 0 0 0 @invertedBorderSize @ld inset;
-
- & when (@isDark) {
- color: @white;
- }
+ }
- & when not (@isDark) {
- color: @l;
- }
+ & when (@variationButtonEqualWidth) {
+ .ui.two.vertical.buttons > .button {
+ height: 50%;
}
- }
- }
- & when (@variationButtonTertiary) {
- /* Tertiary */
+ .ui.three.vertical.buttons > .button {
+ height: 33.333%;
+ }
- .ui.tertiary.@{color}.buttons .button,
- .ui.tertiary.@{color}.buttons .tertiary.button,
- .ui.tertiary.@{color}.button {
- background: transparent;
+ .ui.four.vertical.buttons > .button {
+ height: 25%;
+ }
+ .ui.five.vertical.buttons > .button {
+ height: 20%;
+ }
+ .ui.six.vertical.buttons > .button {
+ height: 16.666%;
+ }
- & when (@tertiaryWithUnderline = true) {
- box-shadow: inset 0 -@tertiaryLineHeight 0 @ty;
+ .ui.seven.vertical.buttons > .button {
+ height: 14.285%;
}
- & when (@tertiaryWithOverline = true) {
- box-shadow: inset 0 @tertiaryLineHeight 0 @ty;
+ .ui.eight.vertical.buttons > .button {
+ height: 12.5%;
}
- & when (@tertiaryWithUnderline = false) and (@tertiaryWithOverline = false){
- box-shadow: none;
+ .ui.nine.vertical.buttons > .button {
+ height: 11.11%;
}
- color: @c;
- }
+ .ui.ten.vertical.buttons > .button {
+ height: 10%;
+ }
- .ui.tertiary.@{color}.buttons .button:hover,
- .ui.tertiary.@{color}.buttons button:hover,
- .ui.tertiary.@{color}.button:hover {
+ .ui.eleven.vertical.buttons > .button {
+ height: 9.09%;
+ }
+ .ui.twelve.vertical.buttons > .button {
+ height: 8.3333%;
+ }
+ }
+}
+/* -------------------
+ Colors
+-------------------- */
- & when (@tertiaryHoverWithUnderline = true) {
- box-shadow: inset 0 -@tertiaryLineHeight 0 @tyh;
+& when not (@variationButtonColors = false) {
+ each(@variationButtonColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+ @h: @colors[@@color][hover];
+ @f: @colors[@@color][focus];
+ @d: @colors[@@color][down];
+ @a: @colors[@@color][active];
+ @t: @colors[@@color][text];
+ @s: @colors[@@color][shadow];
+ @l: @colors[@@color][light];
+ @lh: @colors[@@color][lightHover];
+ @lf: @colors[@@color][lightFocus];
+ @ld: @colors[@@color][lightDown];
+ @la: @colors[@@color][lightActive];
+ @lt: @colors[@@color][lightText];
+ @ls: @colors[@@color][lightShadow];
+ @ty: @colors[@@color][tertiary];
+ @tyh: @colors[@@color][tertiaryHover];
+ @tyf: @colors[@@color][tertiaryFocus];
+ @tya: @colors[@@color][tertiaryActive];
+ @isDark: @colors[@@color][isDark];
+ @isVeryDark: @colors[@@color][isVeryDark];
+
+ .ui.@{color}.buttons .button,
+ .ui.@{color}.button {
+ background-color: @c;
+ color: @t;
+ text-shadow: @s;
+ background-image: @coloredBackgroundImage;
}
-
- & when (@tertiaryHoverWithOverline = true) {
- box-shadow: inset 0 @tertiaryLineHeight 0 @tyh;
+ .ui.@{color}.button {
+ box-shadow: @coloredBoxShadow;
+ }
+ .ui.@{color}.buttons .button:hover,
+ .ui.@{color}.button:hover {
+ background-color: @h;
+ color: @t;
+ text-shadow: @s;
+ }
+ .ui.@{color}.buttons .button:focus,
+ .ui.@{color}.button:focus {
+ background-color: @f;
+ color: @t;
+ text-shadow: @s;
+ }
+ .ui.@{color}.buttons .button:active,
+ .ui.@{color}.button:active {
+ background-color: @d;
+ color: @t;
+ text-shadow: @s;
+ }
+ .ui.@{color}.buttons .active.button,
+ .ui.@{color}.buttons .active.button:active,
+ .ui.@{color}.active.button,
+ .ui.@{color}.button .active.button:active {
+ background-color: @a;
+ color: @t;
+ text-shadow: @s;
}
- & when (@tertiaryHoverWithUnderline = false) and (@tertiaryHoverWithOverline = false) {
- box-shadow: none;
+ & when (@variationButtonBasic) {
+ /* Basic */
+ .ui.basic.@{color}.buttons .button,
+ .ui.basic.@{color}.button {
+ background: transparent;
+ box-shadow: 0 0 0 @basicBorderSize @c inset;
+ color: @c;
+ }
+ .ui.basic.@{color}.buttons .button:hover,
+ .ui.basic.@{color}.button:hover {
+ background: transparent;
+ box-shadow: 0 0 0 @basicColoredBorderSize @h inset;
+ color: @h;
+ }
+ .ui.basic.@{color}.buttons .button:focus,
+ .ui.basic.@{color}.button:focus {
+ background: transparent;
+ box-shadow: 0 0 0 @basicColoredBorderSize @f inset;
+ color: @h;
+ }
+ .ui.basic.@{color}.buttons .active.button,
+ .ui.basic.@{color}.active.button {
+ background: transparent;
+ box-shadow: 0 0 0 @basicColoredBorderSize @a inset;
+ color: @d;
+ }
+ .ui.basic.@{color}.buttons .button:active,
+ .ui.basic.@{color}.button:active {
+ box-shadow: 0 0 0 @basicColoredBorderSize @d inset;
+ color: @d;
+ }
+ }
+ & when (@variationButtonInverted) {
+ /* Inverted */
+ .ui.inverted.@{color}.buttons .button,
+ .ui.inverted.@{color}.button {
+ background-color: transparent;
+
+ & when (@isDark) {
+ box-shadow: 0 0 0 @invertedBorderSize @solidBorderColor inset;
+ color: @invertedTextColor;
+ }
+
+ & when not (@isDark) {
+ box-shadow: 0 0 0 @invertedBorderSize @l inset;
+ color: @l;
+ }
+ }
+ .ui.inverted.@{color}.buttons .button:hover,
+ .ui.inverted.@{color}.button:hover,
+ .ui.inverted.@{color}.buttons .button:focus,
+ .ui.inverted.@{color}.button:focus,
+ .ui.inverted.@{color}.buttons .button.active,
+ .ui.inverted.@{color}.button.active,
+ .ui.inverted.@{color}.buttons .button:active,
+ .ui.inverted.@{color}.button:active {
+ box-shadow: none;
+ color: @lt;
+ }
+ .ui.inverted.@{color}.buttons .button:hover,
+ .ui.inverted.@{color}.button:hover {
+ background-color: @lh;
+ }
+ .ui.inverted.@{color}.buttons .button:focus,
+ .ui.inverted.@{color}.button:focus {
+ background-color: @lf;
+ }
+ .ui.inverted.@{color}.buttons .active.button,
+ .ui.inverted.@{color}.active.button {
+ background-color: @la;
+ }
+ .ui.inverted.@{color}.buttons .button:active,
+ .ui.inverted.@{color}.button:active {
+ background-color: @ld;
+ }
+
+ /* Inverted Basic */
+ .ui.inverted.@{color}.basic.buttons .button,
+ .ui.inverted.@{color}.buttons .basic.button,
+ .ui.inverted.@{color}.basic.button {
+ background-color: transparent;
+ box-shadow: @basicInvertedBoxShadow;
+ color: @white;
+ }
+ .ui.inverted.@{color}.basic.buttons .button:hover,
+ .ui.inverted.@{color}.buttons .basic.button:hover,
+ .ui.inverted.@{color}.basic.button:hover {
+ box-shadow: 0 0 0 @invertedBorderSize @lh inset;
+
+ & when (@isDark) {
+ color: @white;
+ }
+
+ & when not (@isDark) {
+ color: @l;
+ }
+ }
+ .ui.inverted.@{color}.basic.buttons .button:focus,
+ .ui.inverted.@{color}.basic.buttons .button:focus,
+ .ui.inverted.@{color}.basic.button:focus {
+ box-shadow: 0 0 0 @invertedBorderSize @lf inset;
+ color: @l;
+ }
+ .ui.inverted.@{color}.basic.buttons .active.button,
+ .ui.inverted.@{color}.buttons .basic.active.button,
+ .ui.inverted.@{color}.basic.active.button {
+ box-shadow: 0 0 0 @invertedBorderSize @la inset;
+
+ & when (@isDark) {
+ color: @white;
+ }
+
+ & when not (@isDark) {
+ color: @l;
+ }
+ }
+ & when (@variationButtonBasic) {
+ .ui.inverted.@{color}.basic.buttons .button:active,
+ .ui.inverted.@{color}.buttons .basic.button:active,
+ .ui.inverted.@{color}.basic.button:active {
+ box-shadow: 0 0 0 @invertedBorderSize @ld inset;
+
+ & when (@isDark) {
+ color: @white;
+ }
+
+ & when not (@isDark) {
+ color: @l;
+ }
+ }
+ }
}
+ & when (@variationButtonTertiary) {
+ /* Tertiary */
- color: @tyh;
- }
+ .ui.tertiary.@{color}.buttons .button,
+ .ui.tertiary.@{color}.buttons .tertiary.button,
+ .ui.tertiary.@{color}.button {
+ background: transparent;
- .ui.tertiary.@{color}.buttons .button:focus,
- .ui.tertiary.@{color}.buttons .tertiary.button:focus,
- .ui.tertiary.@{color}.button:focus {
+ & when (@tertiaryWithUnderline = true) {
+ box-shadow: inset 0 -@tertiaryLineHeight 0 @ty;
+ }
+ & when (@tertiaryWithOverline = true) {
+ box-shadow: inset 0 @tertiaryLineHeight 0 @ty;
+ }
+ & when (@tertiaryWithUnderline = false) and (@tertiaryWithOverline = false){
+ box-shadow: none;
+ }
+ color: @c;
+ }
- & when (@tertiaryFocusWithUnderline = true) {
- box-shadow: inset 0 -@tertiaryLineHeight 0 @tyf;
- }
+ .ui.tertiary.@{color}.buttons .button:hover,
+ .ui.tertiary.@{color}.buttons button:hover,
+ .ui.tertiary.@{color}.button:hover {
- & when (@tertiaryFocusWithOverline = true) {
- box-shadow: inset 0 @tertiaryLineHeight 0 @tyf;
- }
+ & when (@tertiaryHoverWithUnderline = true) {
+ box-shadow: inset 0 -@tertiaryLineHeight 0 @tyh;
+ }
- & when (@tertiaryFocusWithUnderline = false) and (@tertiaryFocusWithOverline = false) {
- box-shadow: none;
- }
+ & when (@tertiaryHoverWithOverline = true) {
+ box-shadow: inset 0 @tertiaryLineHeight 0 @tyh;
+ }
+ & when (@tertiaryHoverWithUnderline = false) and (@tertiaryHoverWithOverline = false) {
+ box-shadow: none;
+ }
- color: @tyf;
- }
+ color: @tyh;
+ }
- .ui.tertiary.@{color}.buttons .active.button,
- .ui.tertiary.@{color}.buttons .tertiary.active.button,
- .ui.tertiary.@{color}.active.button,
- .ui.tertiary.@{color}.buttons .button:active,
- .ui.tertiary.@{color}.buttons .tertiary.button:active,
- .ui.tertiary.@{color}.button:active {
+ .ui.tertiary.@{color}.buttons .button:focus,
+ .ui.tertiary.@{color}.buttons .tertiary.button:focus,
+ .ui.tertiary.@{color}.button:focus {
+ & when (@tertiaryFocusWithUnderline = true) {
+ box-shadow: inset 0 -@tertiaryLineHeight 0 @tyf;
+ }
+ & when (@tertiaryFocusWithOverline = true) {
+ box-shadow: inset 0 @tertiaryLineHeight 0 @tyf;
+ }
- & when (@tertiaryActiveWithUnderline = true) {
- box-shadow: inset 0 -@tertiaryLineHeight 0 @tya;
- }
+ & when (@tertiaryFocusWithUnderline = false) and (@tertiaryFocusWithOverline = false) {
+ box-shadow: none;
+ }
- & when (@tertiaryActiveWithOverline = true) {
- box-shadow: inset 0 @tertiaryLineHeight 0 @tya;
+ color: @tyf;
+ }
+
+ .ui.tertiary.@{color}.buttons .active.button,
+ .ui.tertiary.@{color}.buttons .tertiary.active.button,
+ .ui.tertiary.@{color}.active.button,
+ .ui.tertiary.@{color}.buttons .button:active,
+ .ui.tertiary.@{color}.buttons .tertiary.button:active,
+ .ui.tertiary.@{color}.button:active {
+
+ & when (@tertiaryActiveWithUnderline = true) {
+ box-shadow: inset 0 -@tertiaryLineHeight 0 @tya;
+ }
+
+ & when (@tertiaryActiveWithOverline = true) {
+ box-shadow: inset 0 @tertiaryLineHeight 0 @tya;
+ }
+
+ & when (@tertiaryActiveWithUnderline = false) and (@tertiaryActiveWithOverline = false) {
+ box-shadow: none;
+ }
+
+ color: @a;
+ }
}
+ });
+}
- & when (@tertiaryActiveWithUnderline = false) and (@tertiaryActiveWithOverline = false) {
- box-shadow: none;
+& when not (@variationButtonConsequences = false) {
+ each(@variationButtonConsequences, {
+ @consequence: @value;
+
+ @_backgroundColor: "@{consequence}Color";
+ @_backgroundColorHover: "@{consequence}ColorHover";
+ @_backgroundColorFocus: "@{consequence}ColorFocus";
+ @_backgroundColorDown: "@{consequence}ColorDown";
+ @_backgroundColorActive: "@{consequence}ColorActive";
+ @_textColor: "@{consequence}TextColor";
+ @_textShadow: "@{consequence}TextShadow";
+
+ /* Standard */
+ .ui.@{consequence}.buttons .button,
+ .ui.@{consequence}.button {
+ background-color: @@_backgroundColor;
+ color: @@_textColor;
+ text-shadow: @@_textShadow;
+ background-image: @coloredBackgroundImage;
+ }
+ .ui.@{consequence}.button {
+ box-shadow: @coloredBoxShadow;
+ }
+ .ui.@{consequence}.buttons .button:hover,
+ .ui.@{consequence}.button:hover {
+ background-color: @@_backgroundColorHover;
+ color: @@_textColor;
+ text-shadow: @@_textShadow;
}
+ .ui.@{consequence}.buttons .button:focus,
+ .ui.@{consequence}.button:focus {
+ background-color: @@_backgroundColorFocus;
+ color: @@_textColor;
+ text-shadow: @@_textShadow;
+ }
+ .ui.@{consequence}.buttons .button:active,
+ .ui.@{consequence}.button:active {
+ background-color: @@_backgroundColorDown;
+ color: @@_textColor;
+ text-shadow: @@_textShadow;
+ }
+ .ui.@{consequence}.buttons .active.button,
+ .ui.@{consequence}.buttons .active.button:active,
+ .ui.@{consequence}.active.button,
+ .ui.@{consequence}.button .active.button:active {
+ background-color: @@_backgroundColorActive;
+ color: @@_textColor;
+ text-shadow: @@_textShadow;
+ }
+ & when (@variationButtonBasic) {
+ /* Basic */
+ .ui.basic.@{consequence}.buttons .button,
+ .ui.basic.@{consequence}.button {
+ background: transparent;
+ box-shadow: 0 0 0 @basicBorderSize @@_backgroundColor inset;
+ color: @@_backgroundColor;
+ }
+ .ui.basic.@{consequence}.buttons .button:hover,
+ .ui.basic.@{consequence}.button:hover {
+ background: transparent;
+ box-shadow: 0 0 0 @basicColoredBorderSize @@_backgroundColorHover inset;
+ color: @@_backgroundColorHover;
+ }
+ .ui.basic.@{consequence}.buttons .button:focus,
+ .ui.basic.@{consequence}.button:focus {
+ background: transparent;
+ box-shadow: 0 0 0 @basicColoredBorderSize @@_backgroundColorFocus inset;
+ color: @@_backgroundColorHover;
+ }
+ .ui.basic.@{consequence}.buttons .active.button,
+ .ui.basic.@{consequence}.active.button {
+ background: transparent;
+ box-shadow: 0 0 0 @basicColoredBorderSize @@_backgroundColorActive inset;
+ color: @@_backgroundColorDown;
+ }
+ .ui.basic.@{consequence}.buttons .button:active,
+ .ui.basic.@{consequence}.button:active {
+ box-shadow: 0 0 0 @basicColoredBorderSize @@_backgroundColorDown inset;
+ color: @@_backgroundColorDown;
+ }
+ .ui.buttons:not(.vertical) > .basic.@{consequence}.button:not(:first-child) {
+ margin-left: -@basicColoredBorderSize;
+ }
+ }
+ });
+}
+
+& when (@variationButtonGroups) {
+ /*******************************
+ Groups
+ *******************************/
- color: @a;
- }
+ .ui.buttons {
+ display: inline-flex;
+ flex-direction: row;
+ font-size: 0;
+ vertical-align: baseline;
+ margin: @verticalMargin @horizontalMargin 0 0;
}
- })
-}
-.addConsequence(@consequence) {
-
- @_backgroundColor: "@{consequence}Color";
- @_backgroundColorHover: "@{consequence}ColorHover";
- @_backgroundColorFocus: "@{consequence}ColorFocus";
- @_backgroundColorDown: "@{consequence}ColorDown";
- @_backgroundColorActive: "@{consequence}ColorActive";
- @_textColor: "@{consequence}TextColor";
- @_textShadow: "@{consequence}TextShadow";
-
- /* Standard */
- .ui.@{consequence}.buttons .button,
- .ui.@{consequence}.button {
- background-color: @@_backgroundColor;
- color: @@_textColor;
- text-shadow: @@_textShadow;
- background-image: @coloredBackgroundImage;
- }
- .ui.@{consequence}.button {
- box-shadow: @coloredBoxShadow;
- }
- .ui.@{consequence}.buttons .button:hover,
- .ui.@{consequence}.button:hover {
- background-color: @@_backgroundColorHover;
- color: @@_textColor;
- text-shadow: @@_textShadow;
- }
- .ui.@{consequence}.buttons .button:focus,
- .ui.@{consequence}.button:focus {
- background-color: @@_backgroundColorFocus;
- color: @@_textColor;
- text-shadow: @@_textShadow;
- }
- .ui.@{consequence}.buttons .button:active,
- .ui.@{consequence}.button:active {
- background-color: @@_backgroundColorDown;
- color: @@_textColor;
- text-shadow: @@_textShadow;
- }
- .ui.@{consequence}.buttons .active.button,
- .ui.@{consequence}.buttons .active.button:active,
- .ui.@{consequence}.active.button,
- .ui.@{consequence}.button .active.button:active {
- background-color: @@_backgroundColorActive;
- color: @@_textColor;
- text-shadow: @@_textShadow;
- }
- & when (@variationButtonBasic) {
- /* Basic */
- .ui.basic.@{consequence}.buttons .button,
- .ui.basic.@{consequence}.button {
- background: transparent;
- box-shadow: 0 0 0 @basicBorderSize @@_backgroundColor inset;
- color: @@_backgroundColor;
- }
- .ui.basic.@{consequence}.buttons .button:hover,
- .ui.basic.@{consequence}.button:hover {
- background: transparent;
- box-shadow: 0 0 0 @basicColoredBorderSize @@_backgroundColorHover inset;
- color: @@_backgroundColorHover;
- }
- .ui.basic.@{consequence}.buttons .button:focus,
- .ui.basic.@{consequence}.button:focus {
- background: transparent;
- box-shadow: 0 0 0 @basicColoredBorderSize @@_backgroundColorFocus inset;
- color: @@_backgroundColorHover;
- }
- .ui.basic.@{consequence}.buttons .active.button,
- .ui.basic.@{consequence}.active.button {
- background: transparent;
- box-shadow: 0 0 0 @basicColoredBorderSize @@_backgroundColorActive inset;
- color: @@_backgroundColorDown;
- }
- .ui.basic.@{consequence}.buttons .button:active,
- .ui.basic.@{consequence}.button:active {
- box-shadow: 0 0 0 @basicColoredBorderSize @@_backgroundColorDown inset;
- color: @@_backgroundColorDown;
- }
- .ui.buttons:not(.vertical) > .basic.@{consequence}.button:not(:first-child) {
- margin-left: -@basicColoredBorderSize;
- }
- }
-}
+ .ui.buttons:not(.basic):not(.inverted) {
+ box-shadow: @groupBoxShadow;
+ }
-/*---------------
- Positive
-----------------*/
+ /* Clearfix */
+ .ui.buttons::after {
+ content: ".";
+ display: block;
+ height: 0;
+ clear: both;
+ visibility: hidden;
+ }
-.addConsequence(positive);
+ /* Standard Group */
+ .ui.buttons .button {
+ flex: 1 0 auto;
+ border-radius: 0;
+ margin: @groupButtonOffset;
+ }
-/*---------------
- Negative
-----------------*/
+ .ui.buttons:not(.basic):not(.inverted) > .button:not(.basic):not(.inverted) {
+ box-shadow: @groupButtonBoxShadow;
+ }
-.addConsequence(negative);
+ .ui.buttons .button:first-child {
+ border-left: none;
+ margin-left: 0;
+ border-top-left-radius: @borderRadius;
+ border-bottom-left-radius: @borderRadius;
+ }
-& when (@variationButtonGroups) {
- /*******************************
- Groups
- *******************************/
-
- .ui.buttons {
- display: inline-flex;
- flex-direction: row;
- font-size: 0;
- vertical-align: baseline;
- margin: @verticalMargin @horizontalMargin 0 0;
- }
-
- .ui.buttons:not(.basic):not(.inverted) {
- box-shadow: @groupBoxShadow;
- }
-
- /* Clearfix */
- .ui.buttons::after {
- content: ".";
- display: block;
- height: 0;
- clear: both;
- visibility: hidden;
- }
-
- /* Standard Group */
- .ui.buttons .button {
- flex: 1 0 auto;
- border-radius: 0;
- margin: @groupButtonOffset;
- }
-
- .ui.buttons:not(.basic):not(.inverted) > .button:not(.basic):not(.inverted) {
- box-shadow: @groupButtonBoxShadow;
- }
-
- .ui.buttons .button:first-child {
- border-left: none;
- margin-left: 0;
- border-top-left-radius: @borderRadius;
- border-bottom-left-radius: @borderRadius;
- }
-
- .ui.buttons .button:last-child {
- border-top-right-radius: @borderRadius;
- border-bottom-right-radius: @borderRadius;
- }
- & when (@variationButtonVertical) {
- /* Vertical Style */
- .ui.vertical.buttons {
- display: inline-flex;
- flex-direction: column;
- }
-
- .ui.vertical.buttons .button {
- display: block;
- float: none;
- width: 100%;
- margin: @verticalGroupOffset;
- border-radius: 0;
- &:not(.basic) {
- box-shadow: @verticalBoxShadow;
- }
- }
-
- .ui.vertical.buttons .button:first-child {
- border-top-left-radius: @borderRadius;
- border-top-right-radius: @borderRadius;
- }
-
- .ui.vertical.buttons .button:last-child {
- margin-bottom: 0;
- border-bottom-left-radius: @borderRadius;
- border-bottom-right-radius: @borderRadius;
- }
-
- .ui.vertical.buttons .button:only-child {
- border-radius: @borderRadius;
+ .ui.buttons .button:last-child {
+ border-top-right-radius: @borderRadius;
+ border-bottom-right-radius: @borderRadius;
}
- & when (@variationButtonBasic) {
- .ui.vertical.buttons .basic.button:not(:first-child) {
- border-top: none;
- }
+ & when (@variationButtonVertical) {
+ /* Vertical Style */
+ .ui.vertical.buttons {
+ display: inline-flex;
+ flex-direction: column;
+ }
+
+ .ui.vertical.buttons .button {
+ display: block;
+ float: none;
+ width: 100%;
+ margin: @verticalGroupOffset;
+ border-radius: 0;
+ &:not(.basic) {
+ box-shadow: @verticalBoxShadow;
+ }
+ }
+
+ .ui.vertical.buttons .button:first-child {
+ border-top-left-radius: @borderRadius;
+ border-top-right-radius: @borderRadius;
+ }
+
+ .ui.vertical.buttons .button:last-child {
+ margin-bottom: 0;
+ border-bottom-left-radius: @borderRadius;
+ border-bottom-right-radius: @borderRadius;
+ }
+
+ .ui.vertical.buttons .button:only-child {
+ border-radius: @borderRadius;
+ }
+ & when (@variationButtonBasic) {
+ .ui.vertical.buttons .basic.button:not(:first-child) {
+ border-top: none;
+ }
+ }
}
- }
- & when (@variationButtonWrapping) {
- .ui.wrapping.buttons {
- flex-wrap: wrap;
+ & when (@variationButtonWrapping) {
+ .ui.wrapping.buttons {
+ flex-wrap: wrap;
+ }
+ & when (@variationButtonBasic) {
+ .ui.wrapping.basic.buttons {
+ border-bottom: none;
+ & .button {
+ border-bottom: @basicGroupBorder;
+ &:hover {
+ background: transparent !important;
+ }
+ }
+ }
+ }
+ & when (@variationButtonCompact) {
+ .ui.compact.wrapping.buttons .button {
+ flex: none;
+ }
+ }
}
- & when (@variationButtonBasic) {
- .ui.wrapping.basic.buttons {
- border-bottom: none;
- & .button {
- border-bottom: @basicGroupBorder;
- &:hover {
- background: transparent !important;
- }
- }
- }
- }
- & when (@variationButtonCompact) {
- .ui.compact.wrapping.buttons .button {
- flex: none;
- }
- }
- }
- & when (@variationButtonWrapped) {
- .ui.wrapped.buttons:not(.spaced) {
- border-top-right-radius: 0;
- & .button {
- &:first-child {
- border-radius: @basicBorderRadius 0 0 0;
- }
- &:last-child {
- border-radius: 0 0 @basicBorderRadius 0;
- }
- }
- }
- & when (@variationButtonAttached) {
- .ui.wrapped[class*="top attached"].buttons {
- border-radius: @basicBorderRadius 0 0 0;
- & .button:last-child {
- border-radius: 0;
- }
- }
- .ui.wrapped[class*="bottom attached"].buttons {
- border-radius: 0 0 0 @basicBorderRadius;
- & .button:first-child {
- border-radius: 0;
- }
- }
- }
- }
- & when (@variationButtonSpaced) {
- .ui.spaced.buttons .ui.button {
- margin-bottom: @spacedMargin;
- margin-right: @spacedMargin;
- border-radius: @basicBorderRadius;
+ & when (@variationButtonWrapped) {
+ .ui.wrapped.buttons:not(.spaced) {
+ border-top-right-radius: 0;
+ & .button {
+ &:first-child {
+ border-radius: @basicBorderRadius 0 0 0;
+ }
+ &:last-child {
+ border-radius: 0 0 @basicBorderRadius 0;
+ }
+ }
+ }
+ & when (@variationButtonAttached) {
+ .ui.wrapped[class*="top attached"].buttons {
+ border-radius: @basicBorderRadius 0 0 0;
+ & .button:last-child {
+ border-radius: 0;
+ }
+ }
+ .ui.wrapped[class*="bottom attached"].buttons {
+ border-radius: 0 0 0 @basicBorderRadius;
+ & .button:first-child {
+ border-radius: 0;
+ }
+ }
+ }
+ }
+ & when (@variationButtonSpaced) {
+ .ui.spaced.buttons .ui.button {
+ margin-bottom: @spacedMargin;
+ margin-right: @spacedMargin;
+ border-radius: @basicBorderRadius;
+ }
+ & when (@variationButtonBasic) {
+ .ui.spaced.basic.buttons {
+ border: none;
+ & .button {
+ border: @basicGroupBorder;
+ &.basic {
+ border: none;
+ }
+ }
+ }
+ & when (@variationButtonVertical) {
+ .ui.spaced.basic.vertical.buttons .button:first-child {
+ border-top: @basicGroupBorder;
+ }
+ }
+ & when (@variationButtonWrapping) {
+ .ui.spaced.basic.wrapping.buttons .button:not(.basic) {
+ border-top: @basicGroupBorder;
+ border-right: @basicGroupBorder;
+ &:first-child {
+ border-left: @basicGroupBorder;
+ }
+ }
+ }
+ & when (@variationButtonInverted) {
+ .ui.spaced.basic.inverted.buttons .basic.button {
+ margin-bottom: e(%("calc(%d + %d)", @spacedMargin, @basicColoredBorderSize));
+ margin-top: @basicColoredBorderSize;
+ }
+ }
+ }
}
+
& when (@variationButtonBasic) {
- .ui.spaced.basic.buttons {
- border: none;
- & .button {
- border: @basicGroupBorder;
- &.basic {
- border: none;
- }
- }
- }
- & when (@variationButtonVertical) {
- .ui.spaced.basic.vertical.buttons .button:first-child {
- border-top: @basicGroupBorder;
- }
- }
- & when (@variationButtonWrapping) {
- .ui.spaced.basic.wrapping.buttons .button:not(.basic) {
- border-top: @basicGroupBorder;
- border-right: @basicGroupBorder;
- &:first-child {
- border-left: @basicGroupBorder;
- }
- }
- }
- & when (@variationButtonInverted) {
- .ui.spaced.basic.inverted.buttons .basic.button {
- margin-bottom: e(%("calc(%d + %d)", @spacedMargin, @basicColoredBorderSize));
- margin-top: @basicColoredBorderSize;
- }
- }
- }
- }
-
- & when (@variationButtonBasic) {
- .ui.basic.buttons:not(.vertical).inverted .button,
- .ui.basic.buttons:not(.vertical) .basic.button {
- margin-left: -@basicColoredBorderSize;
- border-right: none;
- }
- .ui.basic.buttons:not(.vertical):not(.spaced):not(.inverted) .basic.button {
- margin-top: -@basicColoredBorderSize;
- border-bottom: none;
- }
- & when (@variationButtonAttached) or (@variationButtonInverted) {
- .ui.inverted.basic.buttons:not(.spaced) .button,
- .ui.attached.basic.buttons:not(.wrapping):not(.inverted) .basic.button {
- margin-bottom: @attachedOffset;
- }
- }
- .ui.basic.buttons:not(.vertical):not(.attached):not(.spaced):not(.wrapping):not(.inverted) .basic.button {
- margin-bottom: -@basicColoredBorderSize;
- }
- }
+ .ui.basic.buttons:not(.vertical).inverted .button,
+ .ui.basic.buttons:not(.vertical) .basic.button {
+ margin-left: -@basicColoredBorderSize;
+ border-right: none;
+ }
+ .ui.basic.buttons:not(.vertical):not(.spaced):not(.inverted) .basic.button {
+ margin-top: -@basicColoredBorderSize;
+ border-bottom: none;
+ }
+ & when (@variationButtonAttached) or (@variationButtonInverted) {
+ .ui.inverted.basic.buttons:not(.spaced) .button,
+ .ui.attached.basic.buttons:not(.wrapping):not(.inverted) .basic.button {
+ margin-bottom: @attachedOffset;
+ }
+ }
+ .ui.basic.buttons:not(.vertical):not(.attached):not(.spaced):not(.wrapping):not(.inverted) .basic.button {
+ margin-bottom: -@basicColoredBorderSize;
+ }
+ }
}
.loadUIOverrides();
diff --git a/definitions/elements/container.less b/definitions/elements/container.less
index 3272c9a..c6a637e 100644
--- a/definitions/elements/container.less
+++ b/definitions/elements/container.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Container
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,10 +12,10 @@
Theme
*******************************/
-@type : 'element';
-@element : 'container';
+@type: "element";
+@element: "container";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Container
@@ -23,104 +23,104 @@
/* All Sizes */
.ui.container {
- display: block;
- max-width: @maxWidth;
+ display: block;
+ max-width: @maxWidth;
}
/* Mobile */
@media only screen and (max-width: @largestMobileScreen) {
- .ui.ui.ui.container:not(.fluid) {
- width: @mobileWidth;
- margin-left: @mobileGutter;
- margin-right: @mobileGutter;
- }
- & when (@variationContainerGrid) or (@variationContainerRelaxed) {
- .ui.ui.ui.grid.container {
- width: @mobileGridWidth;
+ .ui.ui.ui.container:not(.fluid) {
+ width: @mobileWidth;
+ margin-left: @mobileGutter;
+ margin-right: @mobileGutter;
}
- & when (@variationContainerRelaxed) {
- .ui.ui.ui.relaxed.grid.container {
- width: @mobileRelaxedGridWidth;
- }
- & when (@variationContainerVeryRelaxed) {
- .ui.ui.ui.very.relaxed.grid.container {
- width: @mobileVeryRelaxedGridWidth;
+ & when (@variationContainerGrid) or (@variationContainerRelaxed) {
+ .ui.ui.ui.grid.container {
+ width: @mobileGridWidth;
+ }
+ & when (@variationContainerRelaxed) {
+ .ui.ui.ui.relaxed.grid.container {
+ width: @mobileRelaxedGridWidth;
+ }
+ & when (@variationContainerVeryRelaxed) {
+ .ui.ui.ui.very.relaxed.grid.container {
+ width: @mobileVeryRelaxedGridWidth;
+ }
+ }
}
- }
}
- }
}
/* Tablet */
@media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) {
- .ui.ui.ui.container:not(.fluid) {
- width: @tabletWidth;
- margin-left: @tabletGutter;
- margin-right: @tabletGutter;
- }
- & when (@variationContainerGrid) or (@variationContainerRelaxed) {
- .ui.ui.ui.grid.container {
- width: @tabletGridWidth;
+ .ui.ui.ui.container:not(.fluid) {
+ width: @tabletWidth;
+ margin-left: @tabletGutter;
+ margin-right: @tabletGutter;
}
- & when (@variationContainerRelaxed) {
- .ui.ui.ui.relaxed.grid.container {
- width: @tabletRelaxedGridWidth;
- }
- & when (@variationContainerVeryRelaxed) {
- .ui.ui.ui.very.relaxed.grid.container {
- width: @tabletVeryRelaxedGridWidth;
+ & when (@variationContainerGrid) or (@variationContainerRelaxed) {
+ .ui.ui.ui.grid.container {
+ width: @tabletGridWidth;
+ }
+ & when (@variationContainerRelaxed) {
+ .ui.ui.ui.relaxed.grid.container {
+ width: @tabletRelaxedGridWidth;
+ }
+ & when (@variationContainerVeryRelaxed) {
+ .ui.ui.ui.very.relaxed.grid.container {
+ width: @tabletVeryRelaxedGridWidth;
+ }
+ }
}
- }
}
- }
}
/* Small Monitor */
@media only screen and (min-width: @computerBreakpoint) and (max-width: @largestSmallMonitor) {
- .ui.ui.ui.container:not(.fluid) {
- width: @computerWidth;
- margin-left: @computerGutter;
- margin-right: @computerGutter;
- }
- & when (@variationContainerGrid) or (@variationContainerRelaxed) {
- .ui.ui.ui.grid.container {
- width: @computerGridWidth;
+ .ui.ui.ui.container:not(.fluid) {
+ width: @computerWidth;
+ margin-left: @computerGutter;
+ margin-right: @computerGutter;
}
- & when (@variationContainerRelaxed) {
- .ui.ui.ui.relaxed.grid.container {
- width: @computerRelaxedGridWidth;
- }
- & when (@variationContainerVeryRelaxed) {
- .ui.ui.ui.very.relaxed.grid.container {
- width: @computerVeryRelaxedGridWidth;
+ & when (@variationContainerGrid) or (@variationContainerRelaxed) {
+ .ui.ui.ui.grid.container {
+ width: @computerGridWidth;
+ }
+ & when (@variationContainerRelaxed) {
+ .ui.ui.ui.relaxed.grid.container {
+ width: @computerRelaxedGridWidth;
+ }
+ & when (@variationContainerVeryRelaxed) {
+ .ui.ui.ui.very.relaxed.grid.container {
+ width: @computerVeryRelaxedGridWidth;
+ }
+ }
}
- }
}
- }
}
/* Large Monitor */
@media only screen and (min-width: @largeMonitorBreakpoint) {
- .ui.ui.ui.container:not(.fluid) {
- width: @largeMonitorWidth;
- margin-left: @largeMonitorGutter;
- margin-right: @largeMonitorGutter;
- }
- & when (@variationContainerGrid) or (@variationContainerRelaxed) {
- .ui.ui.ui.grid.container {
- width: @largeMonitorGridWidth;
+ .ui.ui.ui.container:not(.fluid) {
+ width: @largeMonitorWidth;
+ margin-left: @largeMonitorGutter;
+ margin-right: @largeMonitorGutter;
}
- & when (@variationContainerRelaxed) {
- .ui.ui.ui.relaxed.grid.container {
- width: @largeMonitorRelaxedGridWidth;
- }
- & when (@variationContainerVeryRelaxed) {
- .ui.ui.ui.very.relaxed.grid.container {
- width: @largeMonitorVeryRelaxedGridWidth;
+ & when (@variationContainerGrid) or (@variationContainerRelaxed) {
+ .ui.ui.ui.grid.container {
+ width: @largeMonitorGridWidth;
+ }
+ & when (@variationContainerRelaxed) {
+ .ui.ui.ui.relaxed.grid.container {
+ width: @largeMonitorRelaxedGridWidth;
+ }
+ & when (@variationContainerVeryRelaxed) {
+ .ui.ui.ui.very.relaxed.grid.container {
+ width: @largeMonitorVeryRelaxedGridWidth;
+ }
+ }
}
- }
}
- }
}
/*******************************
@@ -128,170 +128,170 @@
*******************************/
& when (@variationContainerText) {
- /* Text Container */
- .ui.text.container {
- font-family: @textFontFamily;
- max-width: @textWidth;
- line-height: @textLineHeight;
- font-size: @textSize;
- }
+ /* Text Container */
+ .ui.text.container {
+ font-family: @textFontFamily;
+ max-width: @textWidth;
+ line-height: @textLineHeight;
+ font-size: @textSize;
+ }
}
& when (@variationContainerWide) {
- /* Wide Container */
- @media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) {
- .ui.ui.ui.wide.container {
- width: @tabletWideWidth;
+ /* Wide Container */
+ @media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) {
+ .ui.ui.ui.wide.container {
+ width: @tabletWideWidth;
+ }
}
- }
- @media only screen and (min-width: @computerBreakpoint) and (max-width: @largestSmallMonitor) {
- .ui.ui.ui.wide.container {
- width: @computerWideWidth;
+ @media only screen and (min-width: @computerBreakpoint) and (max-width: @largestSmallMonitor) {
+ .ui.ui.ui.wide.container {
+ width: @computerWideWidth;
+ }
}
- }
- @media only screen and (min-width: @largeMonitorBreakpoint) {
- .ui.ui.ui.wide.container {
- width: @largeMonitorWideWidth;
+ @media only screen and (min-width: @largeMonitorBreakpoint) {
+ .ui.ui.ui.wide.container {
+ width: @largeMonitorWideWidth;
+ }
}
- }
}
& when (@variationContainerFluid) {
- /* Fluid */
- .ui.fluid.container {
- width: 100%;
- }
+ /* Fluid */
+ .ui.fluid.container {
+ width: 100%;
+ }
}
/*******************************
Variations
*******************************/
& when (@variationContainerAligned) {
- .ui[class*="left aligned"].container {
- text-align: left;
- }
- .ui[class*="center aligned"].container {
- text-align: center;
- }
- .ui[class*="right aligned"].container {
- text-align: right;
- }
+ .ui[class*="left aligned"].container {
+ text-align: left;
+ }
+ .ui[class*="center aligned"].container {
+ text-align: center;
+ }
+ .ui[class*="right aligned"].container {
+ text-align: right;
+ }
}
& when (@variationContainerJustified) {
- .ui.justified.container {
- text-align: justify;
- hyphens: auto;
- }
+ .ui.justified.container {
+ text-align: justify;
+ hyphens: auto;
+ }
}
& when (@variationContainerScrolling) {
- /*--------------
- Scrolling
- ---------------*/
- .ui.scrolling.container {
- overflow: auto;
- }
- @media only screen and (max-width : @largestMobileScreen) {
- & when (@variationContainerScrollingShort) {
- .ui.scrolling.container.short {
- max-height: @scrollingMobileMaxHeight * 0.75;
- }
- }
- & when (@variationContainerScrollingVeryShort) {
- .ui.scrolling.container[class*="very short"] {
- max-height: @scrollingMobileMaxHeight * 0.5;
- }
- }
+ /* --------------
+ Scrolling
+ --------------- */
.ui.scrolling.container {
- max-height: @scrollingMobileMaxHeight;
+ overflow: auto;
+ overscroll-behavior: @overscrollBehavior;
}
- & when (@variationContainerScrollingLong) {
- .ui.scrolling.container.long {
- max-height: @scrollingMobileMaxHeight * 2;
- }
- }
- & when (@variationContainerScrollingVeryLong) {
- .ui.scrolling.container[class*="very long"] {
- max-height: @scrollingMobileMaxHeight * 3;
- }
+ @media only screen and (max-width: @largestMobileScreen) {
+ & when (@variationContainerScrollingShort) {
+ .ui.scrolling.container.short {
+ max-height: @scrollingMobileMaxHeight * 0.75;
+ }
+ }
+ & when (@variationContainerScrollingVeryShort) {
+ .ui.scrolling.container[class*="very short"] {
+ max-height: @scrollingMobileMaxHeight * 0.5;
+ }
+ }
+ .ui.scrolling.container {
+ max-height: @scrollingMobileMaxHeight;
+ }
+ & when (@variationContainerScrollingLong) {
+ .ui.scrolling.container.long {
+ max-height: @scrollingMobileMaxHeight * 2;
+ }
+ }
+ & when (@variationContainerScrollingVeryLong) {
+ .ui.scrolling.container[class*="very long"] {
+ max-height: @scrollingMobileMaxHeight * 3;
+ }
+ }
}
- }
- @media only screen and (min-width: @tabletBreakpoint) {
- & when (@variationContainerScrollingShort) {
- .ui.scrolling.container.short {
- max-height: @scrollingTabletMaxHeight * 0.75;
- }
- }
- & when (@variationContainerScrollingVeryShort) {
- .ui.scrolling.container[class*="very short"] {
- max-height: @scrollingTabletMaxHeight * 0.5;
- }
- }
- .ui.scrolling.container {
- max-height: @scrollingTabletMaxHeight;
- }
- & when (@variationContainerScrollingLong) {
- .ui.scrolling.container.long {
- max-height: @scrollingTabletMaxHeight * 2;
- }
- }
- & when (@variationContainerScrollingVeryLong) {
- .ui.scrolling.container[class*="very long"] {
- max-height: @scrollingTabletMaxHeight * 3;
- }
- }
- }
- @media only screen and (min-width: @computerBreakpoint) {
- & when (@variationContainerScrollingShort) {
- .ui.scrolling.container.short {
- max-height: @scrollingComputerMaxHeight * 0.75;
- }
- }
- & when (@variationContainerScrollingVeryShort) {
- .ui.scrolling.container[class*="very short"] {
- max-height: @scrollingComputerMaxHeight * 0.5;
- }
- }
- .ui.scrolling.container {
- max-height: @scrollingComputerMaxHeight;
- }
- & when (@variationContainerScrollingLong) {
- .ui.scrolling.container.long {
- max-height: @scrollingComputerMaxHeight * 2;
- }
- }
- & when (@variationContainerScrollingVeryLong) {
- .ui.scrolling.container[class*="very long"]{
- max-height: @scrollingComputerMaxHeight * 3;
- }
- }
- }
- @media only screen and (min-width: @widescreenMonitorBreakpoint) {
- & when (@variationContainerScrollingShort) {
- .ui.scrolling.container.short {
- max-height: @scrollingWidescreenMaxHeight * 0.75;
- }
- }
- & when (@variationContainerScrollingVeryShort) {
- .ui.scrolling.container[class*="very short"] {
- max-height: @scrollingWidescreenMaxHeight * 0.5;
- }
- }
- .ui.scrolling.container {
- max-height: @scrollingWidescreenMaxHeight;
+ @media only screen and (min-width: @tabletBreakpoint) {
+ & when (@variationContainerScrollingShort) {
+ .ui.scrolling.container.short {
+ max-height: @scrollingTabletMaxHeight * 0.75;
+ }
+ }
+ & when (@variationContainerScrollingVeryShort) {
+ .ui.scrolling.container[class*="very short"] {
+ max-height: @scrollingTabletMaxHeight * 0.5;
+ }
+ }
+ .ui.scrolling.container {
+ max-height: @scrollingTabletMaxHeight;
+ }
+ & when (@variationContainerScrollingLong) {
+ .ui.scrolling.container.long {
+ max-height: @scrollingTabletMaxHeight * 2;
+ }
+ }
+ & when (@variationContainerScrollingVeryLong) {
+ .ui.scrolling.container[class*="very long"] {
+ max-height: @scrollingTabletMaxHeight * 3;
+ }
+ }
}
- & when (@variationContainerScrollingLong) {
- .ui.scrolling.container.long {
- max-height: @scrollingWidescreenMaxHeight * 2;
- }
+ @media only screen and (min-width: @computerBreakpoint) {
+ & when (@variationContainerScrollingShort) {
+ .ui.scrolling.container.short {
+ max-height: @scrollingComputerMaxHeight * 0.75;
+ }
+ }
+ & when (@variationContainerScrollingVeryShort) {
+ .ui.scrolling.container[class*="very short"] {
+ max-height: @scrollingComputerMaxHeight * 0.5;
+ }
+ }
+ .ui.scrolling.container {
+ max-height: @scrollingComputerMaxHeight;
+ }
+ & when (@variationContainerScrollingLong) {
+ .ui.scrolling.container.long {
+ max-height: @scrollingComputerMaxHeight * 2;
+ }
+ }
+ & when (@variationContainerScrollingVeryLong) {
+ .ui.scrolling.container[class*="very long"] {
+ max-height: @scrollingComputerMaxHeight * 3;
+ }
+ }
}
- & when (@variationContainerScrollingVeryLong) {
- .ui.scrolling.container[class*="very long"] {
- max-height: @scrollingWidescreenMaxHeight * 3;
- }
+ @media only screen and (min-width: @widescreenMonitorBreakpoint) {
+ & when (@variationContainerScrollingShort) {
+ .ui.scrolling.container.short {
+ max-height: @scrollingWidescreenMaxHeight * 0.75;
+ }
+ }
+ & when (@variationContainerScrollingVeryShort) {
+ .ui.scrolling.container[class*="very short"] {
+ max-height: @scrollingWidescreenMaxHeight * 0.5;
+ }
+ }
+ .ui.scrolling.container {
+ max-height: @scrollingWidescreenMaxHeight;
+ }
+ & when (@variationContainerScrollingLong) {
+ .ui.scrolling.container.long {
+ max-height: @scrollingWidescreenMaxHeight * 2;
+ }
+ }
+ & when (@variationContainerScrollingVeryLong) {
+ .ui.scrolling.container[class*="very long"] {
+ max-height: @scrollingWidescreenMaxHeight * 3;
+ }
+ }
}
- }
}
-
.loadUIOverrides();
diff --git a/definitions/elements/divider.less b/definitions/elements/divider.less
index 399b1e4..94a6652 100644
--- a/definitions/elements/divider.less
+++ b/definitions/elements/divider.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Divider
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,203 +12,193 @@
Theme
*******************************/
-@type : 'element';
-@element : 'divider';
-
-@import (multiple) '../../theme.config';
+@type: "element";
+@element: "divider";
+@import (multiple) "../../theme.config";
/*******************************
Divider
*******************************/
.ui.divider {
- margin: @margin;
-
- line-height: 1;
- height: 0;
-
- font-weight: @fontWeight;
- text-transform: @textTransform;
- letter-spacing: @letterSpacing;
- color: @color;
-
- user-select: none;
- -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
+ margin: @margin;
+ line-height: 1;
+ height: 0;
+ font-weight: @fontWeight;
+ text-transform: @textTransform;
+ letter-spacing: @letterSpacing;
+ color: @color;
+ user-select: none;
+ -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
-/*--------------
+/* --------------
Basic
----------------*/
+--------------- */
.ui.divider:not(.vertical):not(.horizontal) {
- border-top: @shadowWidth @borderStyle @shadowColor;
- border-bottom: @highlightWidth @borderStyle @highlightColor;
+ border-top: @shadowWidth @borderStyle @shadowColor;
+ border-bottom: @highlightWidth @borderStyle @highlightColor;
}
-/*--------------
+/* --------------
Coupling
----------------*/
+--------------- */
/* Allow divider between each column row */
.ui.grid > .column + .divider,
.ui.grid > .row > .column + .divider {
- left: auto;
+ left: auto;
}
& when (@variationDividerHorizontal) {
- /*--------------
- Horizontal
- ---------------*/
+ /* --------------
+ Horizontal
+ --------------- */
+
+ .ui.horizontal.divider {
+ display: table;
+ white-space: nowrap;
+ height: auto;
+ margin: @horizontalMargin;
+ line-height: 1;
+ text-align: center;
+ }
- .ui.horizontal.divider {
- display: table;
- white-space: nowrap;
+ .ui.horizontal.divider::before,
+ .ui.horizontal.divider::after {
+ content: "";
+ display: table-cell;
+ position: relative;
+ top: 50%;
+ width: 50%;
+ background-repeat: no-repeat;
+ }
- height: auto;
- margin: @horizontalMargin;
- line-height: 1;
- text-align: center;
- }
-
- .ui.horizontal.divider::before,
- .ui.horizontal.divider::after {
- content: '';
- display: table-cell;
- position: relative;
- top: 50%;
- width: 50%;
- background-repeat: no-repeat;
- }
-
- .ui.horizontal.divider::before {
- background-position: right @horizontalDividerMargin top 50%;
- }
- .ui.horizontal.divider::after {
- background-position: left @horizontalDividerMargin top 50%;
- }
+ .ui.horizontal.divider::before {
+ background-position: right @horizontalDividerMargin top 50%;
+ }
+ .ui.horizontal.divider::after {
+ background-position: left @horizontalDividerMargin top 50%;
+ }
}
& when (@variationDividerVertical) {
- /*--------------
- Vertical
- ---------------*/
-
- .ui.vertical.divider {
- position: absolute;
- z-index: 2;
- top: 50%;
- left: 50%;
-
- margin: 0;
- padding: 0;
- width: auto;
- height: 50%;
-
- line-height: 0;
- text-align: center;
- transform: translateX(-50%);
- }
-
- .ui.vertical.divider::before,
- .ui.vertical.divider::after {
- position: absolute;
- left: 50%;
- content: '';
- z-index: 3;
-
- border-left: @shadowWidth @borderStyle @shadowColor;
- border-right: @highlightWidth @borderStyle @highlightColor;
-
- width: 0;
- height: @verticalDividerHeight;
- }
-
- .ui.vertical.divider::before {
- top: -100%;
- }
- .ui.vertical.divider::after {
- top: auto;
- bottom: 0;
- }
-
- /* Inside grid */
- @media only screen and (max-width : @largestMobileScreen) {
-
- .ui.stackable.grid .ui.vertical.divider,
- .ui.grid .stackable.row .ui.vertical.divider {
- display: table;
- white-space: nowrap;
- height: auto;
- margin: @horizontalMargin;
- overflow: hidden;
- line-height: 1;
- text-align: center;
- position: static;
- top: 0;
- left: 0;
- transform: none;
+ /* --------------
+ Vertical
+ --------------- */
+
+ .ui.vertical.divider {
+ position: absolute;
+ z-index: 2;
+ top: 50%;
+ left: 50%;
+ margin: 0;
+ padding: 0;
+ width: auto;
+ height: 50%;
+ line-height: 0;
+ text-align: center;
+ transform: translateX(-50%);
}
- .ui.stackable.grid .ui.vertical.divider::before,
- .ui.grid .stackable.row .ui.vertical.divider::before,
- .ui.stackable.grid .ui.vertical.divider::after,
- .ui.grid .stackable.row .ui.vertical.divider::after {
- left: 0;
- border-left: none;
- border-right: none;
- content: '';
- display: table-cell;
- position: relative;
- top: 50%;
- width: 50%;
- background-repeat: no-repeat;
+ .ui.vertical.divider::before,
+ .ui.vertical.divider::after {
+ position: absolute;
+ left: 50%;
+ content: "";
+ z-index: 3;
+ border-left: @shadowWidth @borderStyle @shadowColor;
+ border-right: @highlightWidth @borderStyle @highlightColor;
+ width: 0;
+ height: @verticalDividerHeight;
}
- .ui.stackable.grid .ui.vertical.divider::before,
- .ui.grid .stackable.row .ui.vertical.divider::before {
- background-position: right @horizontalDividerMargin top 50%;
+ .ui.vertical.divider::before {
+ top: -100%;
}
- .ui.stackable.grid .ui.vertical.divider::after,
- .ui.grid .stackable.row .ui.vertical.divider::after {
- background-position: left @horizontalDividerMargin top 50%;
+ .ui.vertical.divider::after {
+ top: auto;
+ bottom: 0;
+ }
+
+ /* Inside grid */
+ @media only screen and (max-width: @largestMobileScreen) {
+ .ui.stackable.grid .ui.vertical.divider,
+ .ui.grid .stackable.row .ui.vertical.divider {
+ display: table;
+ white-space: nowrap;
+ height: auto;
+ margin: @horizontalMargin;
+ overflow: hidden;
+ line-height: 1;
+ text-align: center;
+ position: static;
+ top: 0;
+ left: 0;
+ transform: none;
+ }
+
+ .ui.stackable.grid .ui.vertical.divider::before,
+ .ui.grid .stackable.row .ui.vertical.divider::before,
+ .ui.stackable.grid .ui.vertical.divider::after,
+ .ui.grid .stackable.row .ui.vertical.divider::after {
+ left: 0;
+ border-left: none;
+ border-right: none;
+ content: "";
+ display: table-cell;
+ position: relative;
+ top: 50%;
+ width: 50%;
+ background-repeat: no-repeat;
+ }
+
+ .ui.stackable.grid .ui.vertical.divider::before,
+ .ui.grid .stackable.row .ui.vertical.divider::before {
+ background-position: right @horizontalDividerMargin top 50%;
+ }
+ .ui.stackable.grid .ui.vertical.divider::after,
+ .ui.grid .stackable.row .ui.vertical.divider::after {
+ background-position: left @horizontalDividerMargin top 50%;
+ }
}
- }
}
& when (@variationDividerIcon) {
- /*--------------
- Icon
- ---------------*/
-
- .ui.divider > .icon {
- margin: @dividerIconMargin;
- font-size: @dividerIconSize;
- height: 1em;
- vertical-align: middle;
- }
+ /* --------------
+ Icon
+ --------------- */
+
+ .ui.divider > .icon {
+ margin: @dividerIconMargin;
+ font-size: @dividerIconSize;
+ height: 1em;
+ vertical-align: middle;
+ }
}
& when (@variationDividerHorizontal) {
- /*--------------
- Header
- ---------------*/
- .ui.horizontal.divider[class*="left aligned"] {
- &::before {
- display: none;
+ /* --------------
+ Header
+ --------------- */
+ .ui.horizontal.divider[class*="left aligned"] {
+ &::before {
+ display: none;
+ }
+ &::after {
+ width: 100%;
+ }
}
- &::after {
- width: 100%;
+ .ui.horizontal.divider[class*="right aligned"] {
+ &::before {
+ width: 100%;
+ }
+ &::after {
+ display: none;
+ }
}
- }
- .ui.horizontal.divider[class*="right aligned"] {
- &::before {
- width: 100%;
- }
- &::after {
- display: none;
- }
- }
}
/*******************************
@@ -216,83 +206,80 @@
*******************************/
& when (@variationDividerHidden) {
- /*--------------
- Hidden
- ---------------*/
-
- .ui.hidden.divider {
- border-color: transparent !important;
- }
-
- .ui.hidden.divider::before,
- .ui.hidden.divider::after {
- display: none;
- }
+ /* --------------
+ Hidden
+ --------------- */
+
+ .ui.hidden.divider {
+ border-color: transparent !important;
+ }
+
+ .ui.hidden.divider::before,
+ .ui.hidden.divider::after {
+ display: none;
+ }
}
-/*--------------
+/* --------------
Inverted
----------------*/
+--------------- */
& when (@variationDividerInverted) {
- .ui.divider.inverted,
- .ui.vertical.inverted.divider,
- .ui.horizontal.inverted.divider {
- color: @invertedTextColor;
- }
- .ui.divider.inverted,
- .ui.divider.inverted::after,
- .ui.divider.inverted::before {
- border-top-color: @invertedShadowColor !important;
- border-left-color: @invertedShadowColor !important;
- border-bottom-color: @invertedHighlightColor !important;
- border-right-color: @invertedHighlightColor !important;
- }
+ .ui.divider.inverted,
+ .ui.vertical.inverted.divider,
+ .ui.horizontal.inverted.divider {
+ color: @invertedTextColor;
+ }
+ .ui.divider.inverted,
+ .ui.divider.inverted::after,
+ .ui.divider.inverted::before {
+ border-color: @invertedShadowColor @invertedHighlightColor @invertedHighlightColor @invertedShadowColor !important;
+ }
}
-/*--------------
+/* --------------
Fitted
----------------*/
+--------------- */
& when (@variationDividerFitted) {
- .ui.fitted.divider {
- margin: 0;
- }
+ .ui.fitted.divider {
+ margin: 0;
+ }
}
& when (@variationDividerClearing) {
- /*--------------
- Clearing
- ---------------*/
+ /* --------------
+ Clearing
+ --------------- */
- .ui.clearing.divider {
- clear: both;
- }
+ .ui.clearing.divider {
+ clear: both;
+ }
}
& when (@variationDividerSection) {
- /*--------------
- Section
- ---------------*/
-
- .ui.section.divider {
- margin-top: @sectionMargin;
- margin-bottom: @sectionMargin;
- }
+ /* --------------
+ Section
+ --------------- */
+
+ .ui.section.divider {
+ margin-top: @sectionMargin;
+ margin-bottom: @sectionMargin;
+ }
}
-/*--------------
+/* --------------
Sizes
----------------*/
+--------------- */
.ui.divider {
- font-size: @medium;
+ font-size: @medium;
}
& when not (@variationDividerSizes = false) {
- each(@variationDividerSizes, {
- @s: @@value;
- .ui.@{value}.divider {
- font-size: @s;
- }
- })
+ each(@variationDividerSizes, {
+ @s: @@value;
+ .ui.@{value}.divider {
+ font-size: @s;
+ }
+ });
}
.loadUIOverrides();
diff --git a/definitions/elements/emoji.less b/definitions/elements/emoji.less
index 402a441..a32dc89 100644
--- a/definitions/elements/emoji.less
+++ b/definitions/elements/emoji.less
@@ -8,94 +8,87 @@
*
*/
-
/*******************************
Theme
*******************************/
-@type : 'element';
-@element : 'emoji';
-
-@import (multiple) '../../theme.config';
+@type: "element";
+@element: "emoji";
+@import (multiple) "../../theme.config";
/*******************************
Emoji
*******************************/
-
em[data-emoji] {
- opacity: @opacity;
-
- speak: none;
- backface-visibility: hidden;
+ opacity: @opacity;
+ speak: none;
+ backface-visibility: hidden;
}
em[data-emoji]::before {
- content:'\00A0\00A0\00A0\00A0\00A0\00A0\00A0';
- display: inline-block;
- line-height: @emojiLineHeight;
- background-repeat: no-repeat;
- background-position: center center;
- & when not (@emojiFileType = 'svg') {
- background-size: contain;
- }
+ content: "\00A0\00A0\00A0\00A0\00A0\00A0\00A0";
+ display: inline-block;
+ line-height: @emojiLineHeight;
+ background-repeat: no-repeat;
+ background-position: center center;
+ & when not (@emojiFileType = "svg") {
+ background-size: contain;
+ }
}
-
/*******************************
States
*******************************/
& when (@variationEmojiDisabled) {
- em[data-emoji].disabled {
- opacity: @disabledOpacity;
- }
+ em[data-emoji].disabled {
+ opacity: @disabledOpacity;
+ }
}
-
/*******************************
Variations
*******************************/
& when (@variationEmojiLoading) {
- em[data-emoji].loading::before {
- animation: loader @loadingDuration linear infinite;
- }
+ em[data-emoji].loading::before {
+ animation: loader @loadingDuration linear infinite;
+ }
}
-
& when (@variationEmojiLink) {
- /*-------------------
- Link
- --------------------*/
+ /* -------------------
+ Link
+ -------------------- */
- em[data-emoji].link:not(.disabled) {
- cursor: pointer;
- }
+ em[data-emoji].link:not(.disabled) {
+ cursor: pointer;
+ }
}
-/*rtl:begin:ignore*/
+/* rtl:begin:ignore */
each(@size-map, {
- em[data-emoji].@{key} {
- font-size: 1.5em * @value;
- vertical-align: middle;
- }
+ em[data-emoji].@{key} {
+ font-size: 1.5em * @value;
+ vertical-align: middle;
+ }
});
-each(@emoji-map,{
- & when (@variationEmojiColons) {
- em[data-emoji=":@{value}:"]::before {
- background-image: url("@{emojiPath}@{key}.@{emojiFileType}");
+each(@emoji-map, {
+ & when (@variationEmojiColons) {
+ em[data-emoji=":@{value}:"]::before {
+ background-image: url("@{emojiPath}@{key}.@{emojiFileType}");
+ }
+ em[data-emoji="@{value}"]::before:extend(em[data-emoji=":@{value}:"]::before) when (@variationEmojiNoColons) {}
+ }
+ em[data-emoji="@{value}"]::before when (@variationEmojiNoColons) and not (@variationEmojiColons) {
+ background-image: url("@{emojiPath}@{key}.@{emojiFileType}");
}
- em[data-emoji="@{value}"]::before:extend(em[data-emoji=":@{value}:"]::before) when (@variationEmojiNoColons) {}
- }
- em[data-emoji="@{value}"]::before when (@variationEmojiNoColons) and not (@variationEmojiColons) {
- background-image: url("@{emojiPath}@{key}.@{emojiFileType}");
- }
});
-/*rtl:end:ignore*/
+/* rtl:end:ignore */
.loadUIOverrides();
diff --git a/definitions/elements/flag.less b/definitions/elements/flag.less
index f95274d..02d6ed9 100644
--- a/definitions/elements/flag.less
+++ b/definitions/elements/flag.less
@@ -1,88 +1,86 @@
/*!
* # Fomantic-UI - Flag
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-
/*******************************
Theme
*******************************/
-@type : 'element';
-@element : 'flag';
-
-@import (multiple) '../../theme.config';
+@type: "element";
+@element: "flag";
+@import (multiple) "../../theme.config";
/*******************************
Flag
*******************************/
i.flag:not(.icon) {
- speak: none;
- backface-visibility: hidden;
+ speak: none;
+ backface-visibility: hidden;
}
i.flag:not(.icon)::before {
- content: '\00A0\00A0\00A0\00A0\00A0\00A0\00A0';
- display: inline-block;
- line-height: @flagLineHeight;
- background-repeat: no-repeat;
- background-position: center center;
- & when not (@flagFileType = 'svg') {
- background-size: contain;
- }
+ content: "\00A0\00A0\00A0\00A0\00A0\00A0\00A0";
+ display: inline-block;
+ line-height: @flagLineHeight;
+ background-repeat: no-repeat;
+ background-position: center center;
+ & when not (@flagFileType = "svg") {
+ background-size: contain;
+ }
}
each(@size-map, {
- i.flag.@{key} {
- font-size: 1.5em * @value;
- vertical-align: middle;
- }
+ i.flag.@{key} {
+ font-size: 1.5em * @value;
+ vertical-align: middle;
+ }
});
-/*rtl:begin:ignore*/
+/* rtl:begin:ignore */
// for simplicity, class and alias names have to be unique and different to countrycode otherwise false
each(@flags, {
- @unicode: replace(@key,'@','');
- @cc: replace(@flags[@@unicode][countrycode],'_','.','g');
- @cls: replace(@flags[@@unicode][class],'_','.','g');
- @alias: replace(@flags[@@unicode][aliasClass],'_','.','g');
- @alias2: replace(@flags[@@unicode][aliasClass2],'_','.','g');
- & when (@cls = false){
- i.flag.@{cc}::before {
- background-image: url("@{flagPath}@{unicode}.@{flagFileType}");
+ @unicode: replace(@key, "@", "");
+ @cc: replace(@flags[@@unicode][countrycode], "_", ".", "g");
+ @cls: replace(@flags[@@unicode][class], "_", ".", "g");
+ @alias: replace(@flags[@@unicode][aliasClass], "_", ".", "g");
+ @alias2: replace(@flags[@@unicode][aliasClass2], "_", ".", "g");
+ & when (@cls = false){
+ i.flag.@{cc}::before {
+ background-image: url("@{flagPath}@{unicode}.@{flagFileType}");
+ }
}
- }
- & when not (@cls = false) and (@alias = false) {
- i.flag.@{cc}::before,
- i.flag.@{cls}::before {
- background-image: url("@{flagPath}@{unicode}.@{flagFileType}");
+ & when not (@cls = false) and (@alias = false) {
+ i.flag.@{cc}::before,
+ i.flag.@{cls}::before {
+ background-image: url("@{flagPath}@{unicode}.@{flagFileType}");
+ }
}
- }
- & when not (@cls = false) and not (@alias = false) and (@alias2 = false) {
- i.flag.@{cc}::before,
- i.flag.@{cls}::before,
- i.flag.@{alias}::before {
- background-image: url("@{flagPath}@{unicode}.@{flagFileType}");
+ & when not (@cls = false) and not (@alias = false) and (@alias2 = false) {
+ i.flag.@{cc}::before,
+ i.flag.@{cls}::before,
+ i.flag.@{alias}::before {
+ background-image: url("@{flagPath}@{unicode}.@{flagFileType}");
+ }
}
- }
- & when not (@alias2 = false) {
- i.flag.@{cc}::before,
- i.flag.@{cls}::before,
- i.flag.@{alias}::before,
- i.flag.@{alias2}::before {
- background-image: url("@{flagPath}@{unicode}.@{flagFileType}");
+ & when not (@alias2 = false) {
+ i.flag.@{cc}::before,
+ i.flag.@{cls}::before,
+ i.flag.@{alias}::before,
+ i.flag.@{alias2}::before {
+ background-image: url("@{flagPath}@{unicode}.@{flagFileType}");
+ }
}
- }
});
-/*rtl:end:ignore*/
+/* rtl:end:ignore */
.loadUIOverrides();
diff --git a/definitions/elements/header.less b/definitions/elements/header.less
index c609aab..6f94a22 100644
--- a/definitions/elements/header.less
+++ b/definitions/elements/header.less
@@ -1,23 +1,21 @@
/*!
* # Fomantic-UI - Header
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-
/*******************************
Theme
*******************************/
-@type : 'element';
-@element : 'header';
-
-@import (multiple) '../../theme.config';
+@type: "element";
+@element: "header";
+@import (multiple) "../../theme.config";
/*******************************
Header
@@ -25,477 +23,471 @@
/* Standard */
.ui.header {
- border: none;
- margin: @margin;
- padding: @verticalPadding @horizontalPadding;
- font-family: @fontFamily;
- font-weight: @fontWeight;
- line-height: @lineHeight;
- text-transform: @textTransform;
- color: @textColor;
+ border: none;
+ margin: @margin;
+ padding: @verticalPadding @horizontalPadding;
+ font-family: @fontFamily;
+ font-weight: @fontWeight;
+ line-height: @lineHeight;
+ text-transform: @textTransform;
+ color: @textColor;
}
.ui.header:first-child {
- margin-top: @firstMargin;
+ margin-top: @firstMargin;
}
.ui.header:last-child {
- margin-bottom: @lastMargin;
+ margin-bottom: @lastMargin;
}
& when (@variationHeaderSub) {
- /*--------------
- Sub Header
- ---------------*/
-
- .ui.header .sub.header {
- display: block;
- font-weight: @normal;
- padding: 0;
- margin: @subHeaderMargin;
- font-size: @subHeaderFontSize;
- line-height: @subHeaderLineHeight;
- color: @subHeaderColor;
- }
+ /* --------------
+ Sub Header
+ --------------- */
+
+ .ui.header .sub.header {
+ display: block;
+ font-weight: @normal;
+ padding: 0;
+ margin: @subHeaderMargin;
+ font-size: @subHeaderFontSize;
+ line-height: @subHeaderLineHeight;
+ color: @subHeaderColor;
+ }
}
-/*--------------
+/* --------------
Icon
----------------*/
+--------------- */
.ui.header > .icons,
.ui.header > i.icon {
- display: table-cell;
- opacity: @iconOpacity;
- font-size: @iconSize;
- padding-top: @iconOffset;
- vertical-align: @iconAlignment;
+ display: table-cell;
+ opacity: @iconOpacity;
+ font-size: @iconSize;
+ padding-top: @iconOffset;
+ vertical-align: @iconAlignment;
}
/* With Text Node */
.ui.header:not(.icon) > .icons:only-child,
.ui.header:not(.icon) > i.icon:only-child {
- display: inline-block;
- padding: 0;
- margin-right: @iconMargin;
+ display: inline-block;
+ padding: 0;
+ margin-right: @iconMargin;
}
-/*-------------------
+/* -------------------
Image
---------------------*/
+-------------------- */
.ui.header > .image:not(.icon),
.ui.header > img {
- display: inline-block;
- margin-top: @imageOffset;
- width: @imageWidth;
- height: @imageHeight;
- vertical-align: @imageAlignment;
+ display: inline-block;
+ margin-top: @imageOffset;
+ width: @imageWidth;
+ height: @imageHeight;
+ vertical-align: @imageAlignment;
}
.ui.header > .image:not(.icon):only-child,
.ui.header > img:only-child {
- margin-right: @imageMargin;
+ margin-right: @imageMargin;
}
-/*--------------
+/* --------------
Content
----------------*/
+--------------- */
.ui.header .content {
- display: inline-block;
- vertical-align: @contentAlignment;
+ display: inline-block;
+ vertical-align: @contentAlignment;
}
/* After Image */
.ui.header > img + .content,
.ui.header > .image + .content {
- padding-left: @imageMargin;
- vertical-align: @contentImageAlignment;
+ padding-left: @imageMargin;
+ vertical-align: @contentImageAlignment;
}
/* After Icon */
.ui.header:not(.icon):not(.centered):not(.aligned) > .icons + .content,
.ui.header:not(.icon):not(.centered):not(.aligned) > i.icon + .content {
- padding-left: @iconMargin;
- display: table-cell;
- vertical-align: @contentIconAlignment;
+ padding-left: @iconMargin;
+ display: table-cell;
+ vertical-align: @contentIconAlignment;
}
-
-/*--------------
+/* --------------
Loose Coupling
----------------*/
+--------------- */
.ui.header .ui.label {
- font-size: @labelSize;
- margin-left: @labelDistance;
- vertical-align: @labelVerticalAlign;
+ font-size: @labelSize;
+ margin-left: @labelDistance;
+ vertical-align: @labelVerticalAlign;
}
/* Positioning */
.ui.header + p {
- margin-top: @nextParagraphDistance;
+ margin-top: @nextParagraphDistance;
}
-
-
/*******************************
Types
*******************************/
-
-/*--------------
+/* --------------
Page
----------------*/
+--------------- */
& when not (@variationHeaderTags = false) {
- each(@variationHeaderTags, {
- @sf: @{value}SubHeaderFontSize;
- @s: @@value;
- @{value}.ui.header {
- font-size: @s;
- }
- & when (@variationHeaderSub) {
- @{value}.ui.header .sub.header {
- font-size: @@sf;
- }
- }
- })
+ each(@variationHeaderTags, {
+ @sf: @{value}SubHeaderFontSize;
+ @s: @@value;
+ @{value}.ui.header {
+ font-size: @s;
+ }
+ & when (@variationHeaderSub) {
+ @{value}.ui.header .sub.header {
+ font-size: @@sf;
+ }
+ }
+ });
}
-/*--------------
+/* --------------
Content Heading
----------------*/
+--------------- */
& when not (@variationHeaderSizes = false) {
- each(@variationHeaderSizes, {
- @sf: @{value}SubHeaderFontSize;
- @shf: @{value}SubHeadingSize;
- @s: @{value}FontSize;;
- .ui.@{value}.header {
- font-size: @@s;
- & when (@@s >= 2) {
- min-height: 1em;
- }
- }
- & when (@variationHeaderSub) {
- .ui.@{value}.header .sub.header {
- font-size: @@sf;
- }
- .ui.@{value}.sub.header {
- font-size: @@shf;
- }
- }
- })
+ each(@variationHeaderSizes, {
+ @sf: @{value}SubHeaderFontSize;
+ @shf: @{value}SubHeadingSize;
+ @s: @{value}FontSize;;
+ .ui.@{value}.header {
+ font-size: @@s;
+ & when (@@s >= 2) {
+ min-height: 1em;
+ }
+ }
+ & when (@variationHeaderSub) {
+ .ui.@{value}.header .sub.header {
+ font-size: @@sf;
+ }
+ .ui.@{value}.sub.header {
+ font-size: @@shf;
+ }
+ }
+ });
}
& when (@variationHeaderSub) {
- /*--------------
- Sub Heading
- ---------------*/
-
- .ui.sub.header {
- padding: 0;
- margin-bottom: @subHeadingDistance;
- font-weight: @subHeadingFontWeight;
- font-size: @subHeadingFontSize;
- text-transform: @subHeadingTextTransform;
- color: @subHeadingColor;
- }
+ /* --------------
+ Sub Heading
+ --------------- */
+
+ .ui.sub.header {
+ padding: 0;
+ margin-bottom: @subHeadingDistance;
+ font-weight: @subHeadingFontWeight;
+ font-size: @subHeadingFontSize;
+ text-transform: @subHeadingTextTransform;
+ color: @subHeadingColor;
+ }
}
& when (@variationHeaderIcon) {
- /*-------------------
- Icon
- --------------------*/
+ /* -------------------
+ Icon
+ -------------------- */
+
+ .ui.icon.header {
+ display: inline-block;
+ text-align: center;
+ margin: @iconHeaderTopMargin 0 @iconHeaderBottomMargin;
+ }
+ .ui.icon.header::after {
+ content: "";
+ display: block;
+ height: 0;
+ clear: both;
+ visibility: hidden;
+ }
- .ui.icon.header {
- display: inline-block;
- text-align: center;
- margin: @iconHeaderTopMargin 0 @iconHeaderBottomMargin;
- }
- .ui.icon.header::after {
- content: '';
- display: block;
- height: 0;
- clear: both;
- visibility: hidden;
- }
-
- .ui.icon.header:first-child {
- margin-top: @iconHeaderFirstMargin;
- }
- .ui.icon.header > .image.icon,
- .ui.icon.header > .icons,
- .ui.icon.header > i.icon {
- float: none;
- display: block;
- width: auto;
- height: auto;
- line-height: 1;
- padding: 0;
- font-size: @iconHeaderSize;
- margin: 0 auto @iconHeaderMargin;
- opacity: @iconHeaderOpacity;
- }
- .ui.icon.header .corner.icon {
- font-size: @cornerIconHeaderSize;
- }
- .ui.icon.header .content {
- display: block;
- padding: 0;
- }
- .ui.icon.header > i.circular {
- font-size: @circularHeaderIconSize;
- }
- .ui.icon.header > i.square {
- font-size: @squareHeaderIconSize;
- }
- & when (@variationHeaderBlock) {
- .ui.block.icon.header > .image.icon,
- .ui.block.icon.header > .icons,
- .ui.block.icon.header > i.icon {
- margin-bottom: 0;
- }
- }
- & when (@variationHeaderAligned) {
- .ui.icon.header.aligned {
- margin-left: auto;
- margin-right: auto;
- display: block;
- }
- }
+ .ui.icon.header:first-child {
+ margin-top: @iconHeaderFirstMargin;
+ }
+ .ui.icon.header > .image.icon,
+ .ui.icon.header > .icons,
+ .ui.icon.header > i.icon {
+ float: none;
+ display: block;
+ width: auto;
+ height: auto;
+ line-height: 1;
+ padding: 0;
+ font-size: @iconHeaderSize;
+ margin: 0 auto @iconHeaderMargin;
+ opacity: @iconHeaderOpacity;
+ }
+ .ui.icon.header .corner.icon {
+ font-size: @cornerIconHeaderSize;
+ }
+ .ui.icon.header .content {
+ display: block;
+ padding: 0;
+ }
+ .ui.icon.header > i.circular {
+ font-size: @circularHeaderIconSize;
+ }
+ .ui.icon.header > i.square {
+ font-size: @squareHeaderIconSize;
+ }
+ & when (@variationHeaderBlock) {
+ .ui.block.icon.header > .image.icon,
+ .ui.block.icon.header > .icons,
+ .ui.block.icon.header > i.icon {
+ margin-bottom: 0;
+ }
+ }
+ & when (@variationHeaderAligned) {
+ .ui.icon.header.aligned {
+ margin-left: auto;
+ margin-right: auto;
+ display: block;
+ }
+ }
}
/*******************************
States
*******************************/
& when (@variationHeaderDisabled) {
- .ui.disabled.header {
- opacity: @disabledOpacity;
- }
+ .ui.disabled.header {
+ opacity: @disabledOpacity;
+ }
}
-
/*******************************
Variations
*******************************/
& when (@variationHeaderInverted) {
- /*-------------------
- Inverted
- --------------------*/
-
- .ui.inverted.header {
- color: @invertedColor;
- }
- .ui.inverted.header .sub.header {
- color: @invertedSubHeaderColor;
- }
- & when (@variationHeaderAttached) {
- .ui.inverted.attached.header {
- background: @invertedAttachedBackground;
- box-shadow: none;
- border-color: transparent;
- }
- }
- & when (@variationHeaderBlock) {
- .ui.inverted.block.header {
- background: @invertedBlockBackground;
- box-shadow: none;
- border-bottom: none;
- }
- }
-}
+ /* -------------------
+ Inverted
+ -------------------- */
+ .ui.inverted.header {
+ color: @invertedColor;
+ }
+ .ui.inverted.header .sub.header {
+ color: @invertedSubHeaderColor;
+ }
+ & when (@variationHeaderAttached) {
+ .ui.inverted.attached.header {
+ background: @invertedAttachedBackground;
+ box-shadow: none;
+ border-color: transparent;
+ }
+ }
+ & when (@variationHeaderBlock) {
+ .ui.inverted.block.header {
+ background: @invertedBlockBackground;
+ box-shadow: none;
+ border-bottom: none;
+ }
+ }
+}
-/*-------------------
+/* -------------------
Colors
---------------------*/
+-------------------- */
& when not (@variationHeaderColors = false) {
- each(@variationHeaderColors, {
- @color: @value;
- @c: @colors[@@color][color];
- @l: @colors[@@color][light];
- @h: @colors[@@color][hover];
- @lh: @colors[@@color][lightHover];
+ each(@variationHeaderColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+ @l: @colors[@@color][light];
+ @h: @colors[@@color][hover];
+ @lh: @colors[@@color][lightHover];
+
+ .ui.@{color}.header {
+ color: @c;
+ }
+ a.ui.@{color}.header:hover {
+ color: @h;
+ }
+ & when (@variationHeaderDividing) {
+ .ui.@{color}.dividing.header {
+ border-bottom: @dividedColoredBorderWidth solid @c;
+ }
+ }
+ & when (@variationHeaderInverted) {
+ .ui.inverted.@{color}.header.header.header {
+ color: @l;
+ }
+ a.ui.inverted.@{color}.header.header.header:hover {
+ color: @lh;
+ }
+ .ui.inverted.@{color}.dividing.header {
+ border-bottom: @dividedColoredBorderWidth solid @l;
+ }
+ }
+ });
+}
- .ui.@{color}.header {
- color: @c;
+& when (@variationHeaderAligned) {
+ /* -------------------
+ Aligned
+ -------------------- */
+
+ .ui.left.aligned.header {
+ text-align: left;
}
- a.ui.@{color}.header:hover {
- color: @h;
+ .ui.right.aligned.header {
+ text-align: right;
}
- & when (@variationHeaderDividing) {
- .ui.@{color}.dividing.header {
- border-bottom: @dividedColoredBorderWidth solid @c;
- }
+ .ui.centered.header,
+ .ui.center.aligned.header {
+ text-align: center;
}
- & when (@variationHeaderInverted) {
- .ui.inverted.@{color}.header.header.header {
- color: @l;
- }
- a.ui.inverted.@{color}.header.header.header:hover {
- color: @lh;
- }
- .ui.inverted.@{color}.dividing.header {
- border-bottom: @dividedColoredBorderWidth solid @l;
- }
- }
- })
-}
-
-& when (@variationHeaderAligned) {
- /*-------------------
- Aligned
- --------------------*/
-
- .ui.left.aligned.header {
- text-align: left;
- }
- .ui.right.aligned.header {
- text-align: right;
- }
- .ui.centered.header,
- .ui.center.aligned.header {
- text-align: center;
- }
}
& when (@variationHeaderJustified) {
- .ui.justified.header {
- text-align: justify;
- }
- .ui.justified.header::after {
- display: inline-block;
- content: '';
- width: 100%;
- }
+ .ui.justified.header {
+ text-align: justify;
+ }
+ .ui.justified.header::after {
+ display: inline-block;
+ content: "";
+ width: 100%;
+ }
}
& when (@variationHeaderFloated) {
- /*-------------------
- Floated
- --------------------*/
-
- .ui.floated.header,
- .ui[class*="left floated"].header {
- float: left;
- margin-top: 0;
- margin-right: @floatedMargin;
- }
- .ui[class*="right floated"].header {
- float: right;
- margin-top: 0;
- margin-left: @floatedMargin;
- }
+ /* -------------------
+ Floated
+ -------------------- */
+
+ .ui.floated.header,
+ .ui[class*="left floated"].header {
+ float: left;
+ margin-top: 0;
+ margin-right: @floatedMargin;
+ }
+ .ui[class*="right floated"].header {
+ float: right;
+ margin-top: 0;
+ margin-left: @floatedMargin;
+ }
}
& when (@variationHeaderFitted) {
- /*-------------------
- Fitted
- --------------------*/
+ /* -------------------
+ Fitted
+ -------------------- */
- .ui.fitted.header {
- padding: 0;
- }
+ .ui.fitted.header {
+ padding: 0;
+ }
}
& when (@variationHeaderDividing) {
- /*-------------------
- Dividing
- --------------------*/
-
- .ui.dividing.header {
- padding-bottom: @dividedBorderPadding;
- border-bottom: @dividedBorder;
- }
- & when (@variationHeaderSub) {
- .ui.dividing.header .sub.header {
- padding-bottom: @dividedSubHeaderPadding;
- }
- }
- .ui.dividing.header i.icon {
- margin-bottom: @dividedIconPadding;
- }
- & when (@variationHeaderInverted) {
- .ui.inverted.dividing.header {
- border-bottom-color: @invertedDividedBorderColor;
- }
- }
+ /* -------------------
+ Dividing
+ -------------------- */
+
+ .ui.dividing.header {
+ padding-bottom: @dividedBorderPadding;
+ border-bottom: @dividedBorder;
+ }
+ & when (@variationHeaderSub) {
+ .ui.dividing.header .sub.header {
+ padding-bottom: @dividedSubHeaderPadding;
+ }
+ }
+ .ui.dividing.header i.icon {
+ margin-bottom: @dividedIconPadding;
+ }
+ & when (@variationHeaderInverted) {
+ .ui.inverted.dividing.header {
+ border-bottom-color: @invertedDividedBorderColor;
+ }
+ }
}
& when (@variationHeaderBlock) {
- /*-------------------
- Block
- --------------------*/
-
- .ui.block.header {
- background: @blockBackground;
- padding: @blockVerticalPadding @blockHorizontalPadding;
- box-shadow: @blockBoxShadow;
- border: @blockBorder;
- border-radius: @blockBorderRadius;
- }
- .ui.block.header:not(h1):not(h2):not(h3):not(h4):not(h5):not(h6) {
- font-size: @mediumBlock;
- }
- & when not (@variationHeaderSizes = false) {
- each(@variationHeaderSizes, {
- @s: @{value}Block;
- .ui.@{value}.block.header {
- font-size: @@s;
- }
- })
- }
+ /* -------------------
+ Block
+ -------------------- */
+
+ .ui.block.header {
+ background: @blockBackground;
+ padding: @blockVerticalPadding @blockHorizontalPadding;
+ box-shadow: @blockBoxShadow;
+ border: @blockBorder;
+ border-radius: @blockBorderRadius;
+ }
+ .ui.block.header:not(h1):not(h2):not(h3):not(h4):not(h5):not(h6) {
+ font-size: @mediumBlock;
+ }
+ & when not (@variationHeaderSizes = false) {
+ each(@variationHeaderSizes, {
+ @s: @{value}Block;
+ .ui.@{value}.block.header {
+ font-size: @@s;
+ }
+ });
+ }
}
& when (@variationHeaderAttached) {
- /*-------------------
- Attached
- --------------------*/
-
- .ui.attached.header {
- background: @attachedBackground;
- padding: @attachedVerticalPadding @attachedHorizontalPadding;
- margin: 0 @attachedOffset 0 @attachedOffset;
- box-shadow: @attachedBoxShadow;
- border: @attachedBorder;
- border-radius: 0;
- }
- & when (@variationHeaderBlock) {
- .ui.attached.block.header {
- background: @blockBackground;
- }
- }
- .ui.attached:not(.top).header {
- border-top: none;
- }
- .ui.top.attached.header {
- border-radius: @attachedBorderRadius @attachedBorderRadius 0 0;
- }
- .ui.bottom.attached.header {
- border-radius: 0 0 @attachedBorderRadius @attachedBorderRadius;
- }
-
- /* Attached Sizes */
- .ui.attached.header:not(h1):not(h2):not(h3):not(h4):not(h5):not(h6) {
- font-size: @mediumAttachedSize;
- }
- & when not (@variationHeaderSizes = false) {
- each(@variationHeaderSizes, {
- @s: @{value}AttachedSize;
- .ui.@{value}.attached.header {
- font-size: @@s;
- }
- })
- }
+ /* -------------------
+ Attached
+ -------------------- */
+
+ .ui.attached.header {
+ background: @attachedBackground;
+ padding: @attachedVerticalPadding @attachedHorizontalPadding;
+ margin: 0 @attachedOffset;
+ box-shadow: @attachedBoxShadow;
+ border: @attachedBorder;
+ border-radius: 0;
+ }
+ & when (@variationHeaderBlock) {
+ .ui.attached.block.header {
+ background: @blockBackground;
+ }
+ }
+ .ui.attached:not(.top).header {
+ border-top: none;
+ }
+ .ui.top.attached.header {
+ border-radius: @attachedBorderRadius @attachedBorderRadius 0 0;
+ }
+ .ui.bottom.attached.header {
+ border-radius: 0 0 @attachedBorderRadius @attachedBorderRadius;
+ }
+
+ /* Attached Sizes */
+ .ui.attached.header:not(h1):not(h2):not(h3):not(h4):not(h5):not(h6) {
+ font-size: @mediumAttachedSize;
+ }
+ & when not (@variationHeaderSizes = false) {
+ each(@variationHeaderSizes, {
+ @s: @{value}AttachedSize;
+ .ui.@{value}.attached.header {
+ font-size: @@s;
+ }
+ });
+ }
}
-/*-------------------
+/* -------------------
Sizing
---------------------*/
+-------------------- */
.ui.header:not(h1):not(h2):not(h3):not(h4):not(h5):not(h6) {
- font-size: @mediumFontSize;
+ font-size: @mediumFontSize;
}
.loadUIOverrides();
diff --git a/definitions/elements/icon.less b/definitions/elements/icon.less
index 67cc588..7a60a26 100644
--- a/definitions/elements/icon.less
+++ b/definitions/elements/icon.less
@@ -1,60 +1,54 @@
/*!
* # Fomantic-UI - Icon
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-
/*******************************
Theme
*******************************/
-@type : 'element';
-@element : 'icon';
-
-@import (multiple) '../../theme.config';
+@type: "element";
+@element: "icon";
+@import (multiple) "../../theme.config";
/*******************************
Icon
*******************************/
& when (@importIcons) {
- each(@fonts, {
- @font-face {
- each(@value,{
- @{key}: @value;
- });
- }
- })
+ each(@fonts, {
+ @font-face {
+ each(@value, {
+ @{key}: @value;
+ });
+ }
+ });
}
i.icon {
- display: inline-block;
- opacity: @opacity;
-
- margin: 0 @distanceFromText 0 0;
-
- width: @width;
- height: @height;
-
- font-family: @fontName;
- font-style: normal;
- font-weight: @normal;
- text-decoration: inherit;
- text-align: center;
-
- speak: none;
- -moz-osx-font-smoothing: grayscale;
- -webkit-font-smoothing: antialiased;
- backface-visibility: hidden;
+ display: inline-block;
+ opacity: @opacity;
+ margin: 0 @distanceFromText 0 0;
+ width: @width;
+ height: @height;
+ font-family: @fontName;
+ font-style: normal;
+ font-weight: @normal;
+ text-decoration: inherit;
+ text-align: center;
+ speak: none;
+ -moz-osx-font-smoothing: grayscale;
+ -webkit-font-smoothing: antialiased;
+ backface-visibility: hidden;
}
i.icon::before {
- background: none !important;
+ background: none !important;
}
/*******************************
@@ -62,35 +56,40 @@ i.icon::before {
*******************************/
& when (@variationIconLoading) {
- /*--------------
- Loading
- ---------------*/
-
- i.loading.icon {
- height: 1em;
- line-height: 1;
- }
- i.loading.icon, i.loading.icons {
- animation: loader @loadingDuration linear infinite;
- }
+ /* --------------
+ Loading
+ --------------- */
+
+ i.loading.icon {
+ height: 1em;
+ line-height: 1;
+ }
+ i.loading.icon,
+ i.loading.icons {
+ animation: loader @loadingDuration linear infinite;
+ }
}
/*******************************
States
*******************************/
-i.icon:hover, i.icons:hover,
-i.icon:active, i.icons:active,
-i.emphasized.icon:not(.disabled), i.emphasized.icons:not(.disabled) {
- opacity: 1;
+i.icon:hover,
+i.icons:hover,
+i.icon:active,
+i.icons:active,
+i.emphasized.icon:not(.disabled),
+i.emphasized.icons:not(.disabled) {
+ opacity: 1;
}
& when (@variationIconDisabled) {
- i.disabled.icon, i.disabled.icons {
- opacity: @disabledOpacity;
- cursor: default;
- pointer-events: none;
- }
+ i.disabled.icon,
+ i.disabled.icons {
+ opacity: @disabledOpacity;
+ cursor: default;
+ pointer-events: none;
+ }
}
/*******************************
@@ -98,504 +97,562 @@ i.emphasized.icon:not(.disabled), i.emphasized.icons:not(.disabled) {
*******************************/
& when (@variationIconFitted) {
- /*-------------------
- Fitted
- --------------------*/
-
- i.fitted.icons,
- i.fitted.icon {
- width: auto;
- margin: 0 !important;
- }
+ /* -------------------
+ Fitted
+ -------------------- */
+
+ i.fitted.icons,
+ i.fitted.icon {
+ width: auto;
+ margin: 0 !important;
+ }
}
& when (@variationIconLink) {
- /*-------------------
- Link
- --------------------*/
-
- i.link.icon:not(.disabled), i.link.icons:not(.disabled) {
- cursor: pointer;
- opacity: @linkOpacity;
- transition: opacity @defaultDuration @defaultEasing;
- }
- i.link.icon:hover, i.link.icons:hover {
- opacity: 1;
- }
+ /* -------------------
+ Link
+ -------------------- */
+
+ i.link.icon:not(.disabled),
+ i.link.icons:not(.disabled) {
+ cursor: pointer;
+ opacity: @linkOpacity;
+ transition: opacity @defaultDuration @defaultEasing;
+ }
+ i.link.icon:hover,
+ i.link.icons:hover {
+ opacity: 1;
+ }
}
& when (@variationIconCircular) {
- /*-------------------
- Circular
- --------------------*/
-
- i.circular.icon {
- border-radius: 500em !important;
- line-height: 1 !important;
-
- padding: @circularPadding !important;
- box-shadow: @circularShadow;
-
- width: @circularSize !important;
- height: @circularSize !important;
- &.colored when (@variationIconColored){
- box-shadow: @coloredBoxShadow;
+ /* -------------------
+ Circular
+ -------------------- */
+
+ i.circular.icon {
+ border-radius: 500em !important;
+ line-height: 1 !important;
+ padding: @circularPadding !important;
+ box-shadow: @circularShadow;
+ width: @circularSize !important;
+ height: @circularSize !important;
+ &.colored when (@variationIconColored) {
+ box-shadow: @coloredBoxShadow;
+ }
}
- }
- & when (@variationIconInverted) {
- i.circular.inverted.icon {
- border: none;
- box-shadow: none;
+ & when (@variationIconInverted) {
+ i.circular.inverted.icon {
+ border: none;
+ box-shadow: none;
+ }
}
- }
}
& when (@variationIconFlipped) {
- /*-------------------
- Flipped
- --------------------*/
-
- i.flipped.icon,
- i.horizontally.flipped.icon {
- transform: scale(-1, 1);
- }
- i.vertically.flipped.icon {
- transform: scale(1, -1);
- }
-
- & when(@variationIconGroups) {
- .icons i.flipped.icon:not(.corner):not(:first-child),
- .icons i.horizontally.flipped.icon:not(.corner):not(:first-child) {
- transform: translateX(-50%) translateY(-50%) scale(-1, 1);
- }
- .icons i.vertically.flipped.icon:not(.corner):not(:first-child) {
- transform: translateX(-50%) translateY(-50%) scale(1, -1);
- }
- }
+ /* -------------------
+ Flipped
+ -------------------- */
+
+ i.flipped.icon,
+ i.horizontally.flipped.icon {
+ transform: scale(-1, 1);
+ }
+ i.vertically.flipped.icon {
+ transform: scale(1, -1);
+ }
+
+ & when (@variationIconGroups) {
+ .icons i.flipped.icon:not(.corner):not(:first-child),
+ .icons i.horizontally.flipped.icon:not(.corner):not(:first-child) {
+ transform: translateX(-50%) translateY(-50%) scale(-1, 1);
+ }
+ .icons i.vertically.flipped.icon:not(.corner):not(:first-child) {
+ transform: translateX(-50%) translateY(-50%) scale(1, -1);
+ }
+ }
}
& when (@variationIconRotated) {
- /*-------------------
- Rotated
- --------------------*/
-
- i.rotated.icon,
- i.right.rotated.icon,
- i.clockwise.rotated.icon {
- transform: rotate(90deg);
- }
-
- i.left.rotated.icon,
- i.counterclockwise.rotated.icon {
- transform: rotate(-90deg);
- }
-
- i.halfway.rotated.icon {
- transform: rotate(180deg);
- }
-
- & when(@variationIconGroups) {
- .icons i.rotated.rotated.icon:not(.corner):not(:first-child),
- .icons i.right.rotated.icon:not(.corner):not(:first-child),
- .icons i.clockwise.rotated.icon:not(.corner):not(:first-child) {
- transform: translateX(-50%) translateY(-50%) rotate(90deg);
- }
- .icons i.left.rotated.icon:not(.corner):not(:first-child),
- .icons i.counterclockwise.rotated.icon:not(.corner):not(:first-child) {
- transform: translateX(-50%) translateY(-50%) rotate(-90deg);
- }
- .icons i.halfway.rotated.icon:not(.corner):not(:first-child) {
- transform: translateX(-50%) translateY(-50%) rotate(180deg);
- }
- }
+ /* -------------------
+ Rotated
+ -------------------- */
+
+ i.rotated.icon,
+ i.right.rotated.icon,
+ i.clockwise.rotated.icon {
+ transform: rotate(90deg);
+ }
+
+ i.left.rotated.icon,
+ i.counterclockwise.rotated.icon {
+ transform: rotate(-90deg);
+ }
+
+ i.halfway.rotated.icon {
+ transform: rotate(180deg);
+ }
+
+ & when (@variationIconGroups) {
+ .icons i.rotated.rotated.icon:not(.corner):not(:first-child),
+ .icons i.right.rotated.icon:not(.corner):not(:first-child),
+ .icons i.clockwise.rotated.icon:not(.corner):not(:first-child) {
+ transform: translateX(-50%) translateY(-50%) rotate(90deg);
+ }
+ .icons i.left.rotated.icon:not(.corner):not(:first-child),
+ .icons i.counterclockwise.rotated.icon:not(.corner):not(:first-child) {
+ transform: translateX(-50%) translateY(-50%) rotate(-90deg);
+ }
+ .icons i.halfway.rotated.icon:not(.corner):not(:first-child) {
+ transform: translateX(-50%) translateY(-50%) rotate(180deg);
+ }
+ }
}
& when (@variationIconFlipped) and (@variationIconRotated) {
- /*--------------------------
- Flipped & Rotated
- ---------------------------*/
-
- i.rotated.flipped.icon,
- i.right.rotated.flipped.icon,
- i.clockwise.rotated.flipped.icon {
- transform: scale(-1, 1) rotate(90deg);
- }
-
- i.left.rotated.flipped.icon,
- i.counterclockwise.rotated.flipped.icon {
- transform: scale(-1, 1) rotate(-90deg);
- }
-
- i.halfway.rotated.flipped.icon {
- transform: scale(-1, 1) rotate(180deg);
- }
-
- i.rotated.vertically.flipped.icon,
- i.right.rotated.vertically.flipped.icon,
- i.clockwise.rotated.vertically.flipped.icon {
- transform: scale(1, -1) rotate(90deg);
- }
-
- i.left.rotated.vertically.flipped.icon,
- i.counterclockwise.rotated.vertically.flipped.icon {
- transform: scale(1, -1) rotate(-90deg);
- }
-
- i.halfway.rotated.vertically.flipped.icon {
- transform: scale(1, -1) rotate(180deg);
- }
-
- & when(@variationIconGroups) {
- .icons i.rotated.flipped.icon:not(.corner):not(:first-child),
- .icons i.right.rotated.flipped.icon:not(.corner):not(:first-child),
- .icons i.clockwise.rotated.flipped.icon:not(.corner):not(:first-child) {
- transform: translateX(-50%) translateY(-50%) scale(-1, 1) rotate(90deg);
- }
- .icons i.left.rotated.flipped.icon:not(.corner):not(:first-child),
- .icons i.counterclockwise.rotated.flipped.icon:not(.corner):not(:first-child) {
- transform: translateX(-50%) translateY(-50%) scale(-1, 1) rotate(-90deg);
- }
- .icons i.halfway.rotated.flipped.icon:not(.corner):not(:first-child) {
- transform: translateX(-50%) translateY(-50%) scale(-1, 1) rotate(180deg);
- }
- .icons i.rotated.vertically.flipped.icon:not(.corner):not(:first-child),
- .icons i.right.rotated.vertically.flipped.icon:not(.corner):not(:first-child),
- .icons i.clockwise.rotated.vertically.flipped.icon:not(.corner):not(:first-child) {
- transform: translateX(-50%) translateY(-50%) scale(1, -1) rotate(90deg);
- }
- .icons i.left.rotated.vertically.flipped.icon:not(.corner):not(:first-child),
- .icons i.counterclockwise.rotated.vertically.flipped.icon:not(.corner):not(:first-child) {
- transform: translateX(-50%) translateY(-50%) scale(1, -1) rotate(-90deg);
- }
- .icons i.halfway.rotated.vertically.flipped.icon:not(.corner):not(:first-child) {
- transform: translateX(-50%) translateY(-50%) scale(1, -1) rotate(180deg);
- }
- }
+ /* --------------------------
+ Flipped & Rotated
+ --------------------------- */
+
+ i.rotated.flipped.icon,
+ i.right.rotated.flipped.icon,
+ i.clockwise.rotated.flipped.icon {
+ transform: scale(-1, 1) rotate(90deg);
+ }
+
+ i.left.rotated.flipped.icon,
+ i.counterclockwise.rotated.flipped.icon {
+ transform: scale(-1, 1) rotate(-90deg);
+ }
+
+ i.halfway.rotated.flipped.icon {
+ transform: scale(-1, 1) rotate(180deg);
+ }
+
+ i.rotated.vertically.flipped.icon,
+ i.right.rotated.vertically.flipped.icon,
+ i.clockwise.rotated.vertically.flipped.icon {
+ transform: scale(1, -1) rotate(90deg);
+ }
+
+ i.left.rotated.vertically.flipped.icon,
+ i.counterclockwise.rotated.vertically.flipped.icon {
+ transform: scale(1, -1) rotate(-90deg);
+ }
+
+ i.halfway.rotated.vertically.flipped.icon {
+ transform: scale(1, -1) rotate(180deg);
+ }
+
+ & when (@variationIconGroups) {
+ .icons i.rotated.flipped.icon:not(.corner):not(:first-child),
+ .icons i.right.rotated.flipped.icon:not(.corner):not(:first-child),
+ .icons i.clockwise.rotated.flipped.icon:not(.corner):not(:first-child) {
+ transform: translateX(-50%) translateY(-50%) scale(-1, 1) rotate(90deg);
+ }
+ .icons i.left.rotated.flipped.icon:not(.corner):not(:first-child),
+ .icons i.counterclockwise.rotated.flipped.icon:not(.corner):not(:first-child) {
+ transform: translateX(-50%) translateY(-50%) scale(-1, 1) rotate(-90deg);
+ }
+ .icons i.halfway.rotated.flipped.icon:not(.corner):not(:first-child) {
+ transform: translateX(-50%) translateY(-50%) scale(-1, 1) rotate(180deg);
+ }
+ .icons i.rotated.vertically.flipped.icon:not(.corner):not(:first-child),
+ .icons i.right.rotated.vertically.flipped.icon:not(.corner):not(:first-child),
+ .icons i.clockwise.rotated.vertically.flipped.icon:not(.corner):not(:first-child) {
+ transform: translateX(-50%) translateY(-50%) scale(1, -1) rotate(90deg);
+ }
+ .icons i.left.rotated.vertically.flipped.icon:not(.corner):not(:first-child),
+ .icons i.counterclockwise.rotated.vertically.flipped.icon:not(.corner):not(:first-child) {
+ transform: translateX(-50%) translateY(-50%) scale(1, -1) rotate(-90deg);
+ }
+ .icons i.halfway.rotated.vertically.flipped.icon:not(.corner):not(:first-child) {
+ transform: translateX(-50%) translateY(-50%) scale(1, -1) rotate(180deg);
+ }
+ }
}
& when (@variationIconBordered) {
- /*-------------------
- Bordered
- --------------------*/
-
- i.bordered.icon {
- line-height: 1;
- vertical-align: baseline;
-
- width: @borderedSize;
- height: @borderedSize;
- padding: @borderedVerticalPadding @borderedHorizontalPadding !important;
- box-shadow: @borderedShadow;
- &.colored when (@variationIconColored){
- box-shadow: @coloredBoxShadow;
- }
- }
- & when (@variationIconInverted) {
- i.bordered.inverted.icon {
- border: none;
- box-shadow: none;
- }
- }
+ /* -------------------
+ Bordered
+ -------------------- */
+
+ i.bordered.icon {
+ line-height: 1;
+ vertical-align: baseline;
+ width: @borderedSize;
+ height: @borderedSize;
+ padding: @borderedVerticalPadding @borderedHorizontalPadding !important;
+ box-shadow: @borderedShadow;
+ &.colored when (@variationIconColored) {
+ box-shadow: @coloredBoxShadow;
+ }
+ }
+ & when (@variationIconInverted) {
+ i.bordered.inverted.icon {
+ border: none;
+ box-shadow: none;
+ }
+ }
}
& when (@variationIconInverted) {
- /*-------------------
- Inverted
- --------------------*/
-
- /* Inverted Shapes */
- i.inverted.bordered.icon,
- i.inverted.circular.icon {
- background-color: @black;
- color: @white;
- }
-
- i.inverted.icon {
- color: @white;
- }
+ /* -------------------
+ Inverted
+ -------------------- */
+
+ /* Inverted Shapes */
+ i.inverted.bordered.icon,
+ i.inverted.circular.icon {
+ background-color: @black;
+ color: @white;
+ }
+
+ i.inverted.icon {
+ color: @white;
+ }
}
-/*-------------------
+/* -------------------
Colors
---------------------*/
+-------------------- */
& when not (@variationIconColors = false) {
- each(@variationIconColors, {
- @color: @value;
- @c: @colors[@@color][color];
- @l: @colors[@@color][light];
+ each(@variationIconColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+ @l: @colors[@@color][light];
- i.@{color}.icon.icon.icon.icon.icon {
- color: @c;
- }
- & when (@variationIconInverted) {
- i.inverted.@{color}.icon.icon.icon.icon.icon {
- color: @l;
- }
- & when (@variationIconBordered) or (@variationIconCircular) {
- i.inverted.bordered.@{color}.icon.icon.icon.icon.icon,
- i.inverted.circular.@{color}.icon.icon.icon.icon.icon,
- i.inverted.bordered.@{color}.icons,
- i.inverted.circular.@{color}.icons {
- background-color: @c;
- color: @white;
- }
- }
- }
- })
+ i.@{color}.icon.icon.icon.icon.icon {
+ color: @c;
+ }
+ & when (@variationIconInverted) {
+ i.inverted.@{color}.icon.icon.icon.icon.icon {
+ color: @l;
+ }
+ & when (@variationIconBordered) or (@variationIconCircular) {
+ i.inverted.bordered.@{color}.icon.icon.icon.icon.icon,
+ i.inverted.circular.@{color}.icon.icon.icon.icon.icon,
+ i.inverted.bordered.@{color}.icons,
+ i.inverted.circular.@{color}.icons {
+ background-color: @c;
+ color: @white;
+ }
+ }
+ }
+ });
}
-
-/*-------------------
+/* -------------------
Sizes
---------------------*/
+-------------------- */
i.icon,
i.icons {
- font-size: @medium;
- line-height: @lineHeight;
- font-style: normal;
+ font-size: @medium;
+ line-height: @lineHeight;
+ font-style: normal;
}
& when not (@variationIconSizes = false) {
- each(@variationIconSizes, {
- @s: @@value;
- i.@{value}.@{value}.@{value}.icon,
- i.@{value}.@{value}.@{value}.icons {
- font-size: @s;
- vertical-align: middle;
- }
- })
+ each(@variationIconSizes, {
+ @s: @@value;
+ i.@{value}.@{value}.@{value}.icon,
+ i.@{value}.@{value}.@{value}.icons {
+ font-size: @s;
+ vertical-align: middle;
+ }
+ });
}
& when (@variationIconGroups) or (@variationIconCorner) {
- /*******************************
- Groups
- *******************************/
+ /*******************************
+ Groups
+ *******************************/
+
+ i.icons {
+ display: inline-block;
+ position: relative;
+ line-height: 1;
+ min-width: @width;
+ min-height: @height;
+ margin: 0 @distanceFromText 0 0;
+ text-align: center;
+ }
+
+ i.icons .icon {
+ position: absolute;
+ top: 50%;
+ left: 50%;
+ margin: 0;
+ &:not(.corner):not(.rotated):not(.flipped) {
+ transform: translateX(-50%) translateY(-50%);
+ }
+ }
- i.icons {
- display: inline-block;
- position: relative;
- line-height: 1;
- min-width: @width;
- min-height: @height;
- margin: 0 @distanceFromText 0 0;
- text-align: center;
- }
-
- i.icons .icon {
- position: absolute;
- top: 50%;
- left: 50%;
- margin: 0;
- &:not(.corner):not(.rotated):not(.flipped) {
- transform: translateX(-50%) translateY(-50%);
- }
- }
-
- i.icons .icon:first-child {
- position: static;
- width: auto;
- height: auto;
- vertical-align: top;
- }
- i.icons:not(.bordered):not(.circular) .icon:first-child:not(.rotated):not(.flipped) {
- transform: none;
- }
-
- & when (@variationIconCorner) {
- /* Corner Icon */
- i.icons .corner.icon {
- top: auto;
- left: auto;
- right: @cornerOffset;
- bottom: @cornerOffset;
- font-size: @cornerIconSize;
- text-shadow: @cornerIconShadow;
- &:not(.rotated):not(.flipped) {
+ i.icons .icon:first-child {
+ position: static;
+ width: auto;
+ height: auto;
+ vertical-align: top;
+ }
+ i.icons:not(.bordered):not(.circular) .icon:first-child:not(.rotated):not(.flipped) {
transform: none;
- }
- }
- i.icons .icon.corner[class*="top right"] {
- top: @cornerOffset;
- left: auto;
- right: @cornerOffset;
- bottom: auto;
- }
- i.icons .icon.corner[class*="top left"] {
- top: @cornerOffset;
- left: @cornerOffset;
- right: auto;
- bottom: auto;
- }
- i.icons .icon.corner[class*="bottom left"] {
- top: auto;
- left: @cornerOffset;
- right: auto;
- bottom: @cornerOffset;
- }
- i.icons .icon.corner[class*="bottom right"] {
- top: auto;
- left: auto;
- right: @cornerOffset;
- bottom: @cornerOffset;
}
- & when (@variationIconInverted) {
- i.icons .inverted.corner.icon {
- text-shadow: @cornerIconInvertedShadow;
- }
+
+ & when (@variationIconCorner) {
+ /* Corner Icon */
+ i.icons .corner.icon {
+ top: auto;
+ left: auto;
+ right: @cornerOffset;
+ bottom: @cornerOffset;
+ font-size: @cornerIconSize;
+ text-shadow: @cornerIconShadow;
+ &:not(.rotated):not(.flipped) {
+ transform: none;
+ }
+ }
+ i.icons .icon.corner[class*="top right"] {
+ top: @cornerOffset;
+ left: auto;
+ right: @cornerOffset;
+ bottom: auto;
+ }
+ i.icons .icon.corner[class*="top left"] {
+ top: @cornerOffset;
+ left: @cornerOffset;
+ right: auto;
+ bottom: auto;
+ }
+ i.icons .icon.corner[class*="bottom left"] {
+ top: auto;
+ left: @cornerOffset;
+ right: auto;
+ bottom: @cornerOffset;
+ }
+ i.icons .icon.corner[class*="bottom right"] {
+ top: auto;
+ left: auto;
+ right: @cornerOffset;
+ bottom: @cornerOffset;
+ }
+ & when (@variationIconInverted) {
+ i.icons .inverted.corner.icon {
+ text-shadow: @cornerIconInvertedShadow;
+ }
+ }
}
- }
}
-& when ((@variationIconGroups) or (@variationIconCorner))
- and ((@variationIconBordered) or (@variationIconCircular)) {
- /*************************************************
- Bordered/circular with corner or group icons
- *************************************************/
- i.bordered.icons,
- i.circular.icons {
- width: @borderedSize;
- height: @borderedSize;
- box-shadow: @borderedShadow;
- vertical-align: middle;
- &.colored when (@variationIconColored){
- box-shadow: @coloredBoxShadow;
- }
- }
- i.circular.icons {
- border-radius: 500em;
- }
- i.bordered.icons i.icon:first-child,
- i.circular.icons i.icon:first-child {
- position: absolute;
- transform: translateX(-50%) translateY(-50%);
- }
-
- & when (@variationIconInverted) {
- /* Inverted Icon */
- i.bordered.inverted.icons,
- i.circular.inverted.icons {
- border: none;
- box-shadow: none;
- background-color: @black;
- color: @white;
- }
- }
-
- & when (@variationIconCorner) {
- /* Corner Icon */
- i.bordered.icons .icon.corner,
- i.circular.icons .icon.corner,
- i.bordered.icons .icon.corner[class*="bottom right"],
- i.circular.icons .icon.corner[class*="bottom right"] {
- top: auto;
- left: auto;
- right: @borderedGroupCornerOffset;
- bottom: @borderedGroupCornerOffset;
- }
- i.bordered.icons .icon.corner[class*="top right"],
- i.circular.icons .icon.corner[class*="top right"] {
- top: @borderedGroupCornerOffset;
- left: auto;
- right: @borderedGroupCornerOffset;
- bottom: auto;
- }
- i.bordered.icons .icon.corner[class*="top left"],
- i.circular.icons .icon.corner[class*="top left"] {
- top: @borderedGroupCornerOffset;
- left: @borderedGroupCornerOffset;
- right: auto;
- bottom: auto;
- }
- i.bordered.icons .icon.corner[class*="bottom left"],
- i.circular.icons .icon.corner[class*="bottom left"] {
- top: auto;
- left: @borderedGroupCornerOffset;
- right: auto;
- bottom: @borderedGroupCornerOffset;
- }
- }
-}
+& when ((@variationIconGroups) or (@variationIconCorner)) and ((@variationIconBordered) or (@variationIconCircular)) {
+ /*************************************************
+ Bordered/circular with corner or group icons
+ *************************************************/
+ i.bordered.icons,
+ i.circular.icons {
+ width: @borderedSize;
+ height: @borderedSize;
+ box-shadow: @borderedShadow;
+ vertical-align: middle;
+ &.colored when (@variationIconColored) {
+ box-shadow: @coloredBoxShadow;
+ }
+ }
+ i.circular.icons {
+ border-radius: 500em;
+ }
+ i.bordered.icons i.icon:first-child,
+ i.circular.icons i.icon:first-child {
+ position: absolute;
+ transform: translateX(-50%) translateY(-50%);
+ }
-.generateIcons(@map, @fontFamily) {
- each(@map,{
- @escapedKey: replace(@key,'^([0-9])','\3$1 ');
- @normalizedKey: replace(@escapedKey,'_','.','g');
- i.icon.@{normalizedKey}::before {
- content: "@{value}";
- & when not (@fontFamily = false) {
- font-family: @fontFamily;
- }
+ & when (@variationIconInverted) {
+ /* Inverted Icon */
+ i.bordered.inverted.icons,
+ i.circular.inverted.icons {
+ border: none;
+ box-shadow: none;
+ background-color: @black;
+ color: @white;
+ }
}
- });
-};
-& when (@variationIconDeprecated) {
+ & when (@variationIconCorner) {
+ /* Corner Icon */
+ i.bordered.icons .icon.corner,
+ i.circular.icons .icon.corner,
+ i.bordered.icons .icon.corner[class*="bottom right"],
+ i.circular.icons .icon.corner[class*="bottom right"] {
+ top: auto;
+ left: auto;
+ right: @borderedGroupCornerOffset;
+ bottom: @borderedGroupCornerOffset;
+ }
+ i.bordered.icons .icon.corner[class*="top right"],
+ i.circular.icons .icon.corner[class*="top right"] {
+ top: @borderedGroupCornerOffset;
+ left: auto;
+ right: @borderedGroupCornerOffset;
+ bottom: auto;
+ }
+ i.bordered.icons .icon.corner[class*="top left"],
+ i.circular.icons .icon.corner[class*="top left"] {
+ top: @borderedGroupCornerOffset;
+ left: @borderedGroupCornerOffset;
+ right: auto;
+ bottom: auto;
+ }
+ i.bordered.icons .icon.corner[class*="bottom left"],
+ i.circular.icons .icon.corner[class*="bottom left"] {
+ top: auto;
+ left: @borderedGroupCornerOffset;
+ right: auto;
+ bottom: @borderedGroupCornerOffset;
+ }
+ }
+}
- /* Deprecated *In/Out Naming Conflict) */
- .generateIcons(@icon-deprecated-map,false);
+.generateIcons(@map, @fontFamily: false, @pseudo: before) {
+ each(@map, {
+ @escapedKey: replace(@key, "^([0-9])", "\3$1 ");
+ @normalizedKey: replace(@escapedKey, "_", @iconClassSeparator, "g");
+ @unorderedKey: e(%(".%s::%s",@normalizedKey, @pseudo));
+ @orderedKey: e(%('[%s*="%s"]::%s', @iconForcedAttribute, @normalizedKey, @pseudo));
+ @selectorKey: if(@iconForcedOrder or @iconClassSeparator = " ", @orderedKey, @unorderedKey);
+ i.icon@{selectorKey} {
+ content: "@{value}";
+ & when not (@fontFamily = false) {
+ font-family: @fontFamily;
+ }
+ }
+ });
}
-& when (@variationIconSolid) {
- /*******************************
- Solid Icons
- *******************************/
+& when (@variationIconDeprecated) {
+ /* Deprecated *In/Out Naming Conflict) */
+ .generateIcons(@icon-deprecated-map);
+}
- /* Icons */
- .generateIcons(@icon-map,false);
- & when (@variationIconAliases) {
+& when (@variationIconSolid) {
+ /*******************************
+ Solid Icons
+ *******************************/
- /* Aliases */
- .generateIcons(@icon-aliases-map,false);
- }
+ /* Icons */
+ .generateIcons(@icon-map);
+ & when (@variationIconAliases) {
+ /* Aliases */
+ .generateIcons(@icon-aliases-map);
+ }
}
& when (@variationIconOutline) {
- /*******************************
- Outline Icons
- *******************************/
-
- i.icon.outline {
- font-family: @outlineFontName;
- }
+ /*******************************
+ Outline Icons
+ *******************************/
- /* Icons */
- .generateIcons(@icon-outline-map,false);
- & when (@variationIconAliases) {
+ i.icon.outline {
+ font-family: @outlineFontName;
+ }
- /* Aliases */
- .generateIcons(@icon-outline-aliases-map,false);
- }
+ /* Icons */
+ .generateIcons(@icon-outline-map);
+ & when (@variationIconAliases) {
+ /* Aliases */
+ .generateIcons(@icon-outline-aliases-map);
+ }
}
& when (@variationIconThin) {
- /*******************************
- Thin Icons
- *******************************/
-
- /* Icons */
- i.icon.thin {
- font-family: @thinFontName;
- }
- .generateIcons(@icon-thin-map,false);
- & when (@variationIconAliases) {
-
- /* Aliases */
- .generateIcons(@icon-thin-aliases-map,false);
- }
+ /*******************************
+ Thin Icons
+ *******************************/
+
+ /* Icons */
+ i.icon.thin {
+ font-family: @thinFontName;
+ }
+ .generateIcons(@icon-thin-map);
+ & when (@variationIconAliases) {
+ /* Aliases */
+ .generateIcons(@icon-thin-aliases-map);
+ }
+}
+
+& when (@variationIconBrand) {
+ /*******************************
+ Brand Icons
+ *******************************/
+
+ /* Icons */
+ .generateIcons(@icon-brand-map, @brandFontName);
+ & when (@variationIconAliases) {
+ /* Aliases */
+ .generateIcons(@icon-brand-aliases-map, @brandFontName);
+ }
}
-& when(@variationIconBrand) {
- /*******************************
- Brand Icons
- *******************************/
+& when (@variationIconDuotone) {
+ /*******************************
+ Duotone Icons
+ *******************************/
- /* Icons */
- .generateIcons(@icon-brand-map,@brandFontName);
- & when (@variationIconAliases) {
+ /* Make duotone icons use the proper font */
+ i.icon.duotone {
+ font-family: @duotoneFontName;
+
+ /* To position the secondary layer on top of the first layer */
+ position: relative;
+ }
+
+ /* Set the default opacity levels and colors for each layer */
+ i.icon.duotone::before {
+ color: @duotonePrimaryColor;
+ opacity: @duotonePrimaryOpacity;
+ }
- /* Aliases */
- .generateIcons(@icon-brand-aliases-map,@brandFontName);
- }
+ i.icon.duotone::after {
+ /* Position secondary layer to the left, centered horizontally and aligned vertically to flex with different line heights */
+ position: absolute;
+ left: 0;
+ top: 50%;
+ transform: translateY(-50%);
+ text-align: center;
+ color: @duotoneSecondaryColor;
+ opacity: @duotoneSecondaryOpacity;
+ }
+
+ .generateIcons(@icon-duotone-map);
+ .generateIcons(@icon-duotone-secondary-map, false, after);
+
+ & when (@variationIconAliases) {
+ /* Aliases */
+ .generateIcons(@icon-duotone-aliases-map);
+ .generateIcons(@icon-duotone-secondary-aliases-map, false, after);
+ }
+
+ /*
+ * Colors for duotone icons, in the form `primary-secondary`(e.g. `black-grey duotone icon`).
+ */
+ & when not (@variationIconColors = false) {
+ each(@variationIconColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+ @l: @colors[@@color][light];
+
+ i.icon.duotone[class*="@{color}-"]::before,
+ i.icon.duotone[class*="-@{color}"]::after {
+ color: @c;
+ }
+
+ & when (@variationIconInverted) {
+ i.icon.inverted.duotone[class*="@{color}-"]::before,
+ i.icon.inverted.duotone[class*="-@{color}"]::after {
+ color: @l;
+ }
+ }
+ });
+ }
}
.loadUIOverrides();
diff --git a/definitions/elements/image.less b/definitions/elements/image.less
index 651b81e..348e3fa 100644
--- a/definitions/elements/image.less
+++ b/definitions/elements/image.less
@@ -1,321 +1,310 @@
/*!
* # Fomantic-UI - Image
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-
/*******************************
Theme
*******************************/
-@type : 'element';
-@element : 'image';
-
-@import (multiple) '../../theme.config';
+@type: "element";
+@element: "image";
+@import (multiple) "../../theme.config";
/*******************************
Image
*******************************/
.ui.image {
- position: relative;
- display: inline-block;
- vertical-align: middle;
- max-width: 100%;
- background-color: @placeholderColor;
+ position: relative;
+ display: inline-block;
+ vertical-align: middle;
+ max-width: 100%;
+ background-color: @placeholderColor;
}
img.ui.image {
- display: block;
+ display: block;
}
.ui.image svg,
.ui.image img {
- display: block;
- max-width: 100%;
- height: auto;
+ display: block;
+ max-width: 100%;
+ height: auto;
}
-
/*******************************
States
*******************************/
.ui.hidden.images,
.ui.ui.hidden.image {
- display: none;
+ display: none;
}
.ui.hidden.transition.images,
.ui.hidden.transition.image {
- display: block;
- visibility: hidden;
+ display: block;
+ visibility: hidden;
}
.ui.images > .hidden.transition {
- display: inline-block;
- visibility: hidden;
+ display: inline-block;
+ visibility: hidden;
}
& when (@variationImageDisabled) {
- .ui.disabled.images,
- .ui.disabled.image {
- cursor: default;
- opacity: @disabledOpacity;
- }
+ .ui.disabled.images,
+ .ui.disabled.image {
+ cursor: default;
+ opacity: @disabledOpacity;
+ }
}
-
/*******************************
Variations
*******************************/
& when (@variationImageInline) {
- /*--------------
- Inline
- ---------------*/
-
- .ui.inline.image,
- .ui.inline.image svg,
- .ui.inline.image img {
- display: inline-block;
- }
+ /* --------------
+ Inline
+ --------------- */
+
+ .ui.inline.image,
+ .ui.inline.image svg,
+ .ui.inline.image img {
+ display: inline-block;
+ }
}
& when (@variationImageAligned) {
- /*------------------
- Vertical Aligned
- -------------------*/
-
- .ui.top.aligned.image,
- .ui.top.aligned.image svg,
- .ui.top.aligned.image img {
- display: inline-block;
- vertical-align: top;
- }
- .ui.middle.aligned.image,
- .ui.middle.aligned.image svg,
- .ui.middle.aligned.image img {
- display: inline-block;
- vertical-align: middle;
- }
- .ui.bottom.aligned.image,
- .ui.bottom.aligned.image svg,
- .ui.bottom.aligned.image img {
- display: inline-block;
- vertical-align: bottom;
- }
- .ui.top.aligned.images .image,
- .ui.images .ui.top.aligned.image {
- align-self: flex-start;
- }
- .ui.middle.aligned.images .image,
- .ui.images .ui.middle.aligned.image {
- align-self: center;
- }
- .ui.bottom.aligned.images .image,
- .ui.images .ui.bottom.aligned.image {
- align-self: flex-end;
- }
+ /* ------------------
+ Vertical Aligned
+ ------------------- */
+
+ .ui.top.aligned.image,
+ .ui.top.aligned.image svg,
+ .ui.top.aligned.image img {
+ display: inline-block;
+ vertical-align: top;
+ }
+ .ui.middle.aligned.image,
+ .ui.middle.aligned.image svg,
+ .ui.middle.aligned.image img {
+ display: inline-block;
+ vertical-align: middle;
+ }
+ .ui.bottom.aligned.image,
+ .ui.bottom.aligned.image svg,
+ .ui.bottom.aligned.image img {
+ display: inline-block;
+ vertical-align: bottom;
+ }
+ .ui.top.aligned.images .image,
+ .ui.images .ui.top.aligned.image {
+ align-self: flex-start;
+ }
+ .ui.middle.aligned.images .image,
+ .ui.images .ui.middle.aligned.image {
+ align-self: center;
+ }
+ .ui.bottom.aligned.images .image,
+ .ui.images .ui.bottom.aligned.image {
+ align-self: flex-end;
+ }
}
& when (@variationImageRounded) {
- /*--------------
- Rounded
- ---------------*/
-
- .ui.rounded.images .image,
- .ui.rounded.image,
- .ui.rounded.images .image > *,
- .ui.rounded.image > * {
- border-radius: @roundedBorderRadius;
- }
+ /* --------------
+ Rounded
+ --------------- */
+
+ .ui.rounded.images .image,
+ .ui.rounded.image,
+ .ui.rounded.images .image > *,
+ .ui.rounded.image > * {
+ border-radius: @roundedBorderRadius;
+ }
}
& when (@variationImageBordered) {
- /*--------------
- Bordered
- ---------------*/
-
- .ui.bordered.images .image,
- .ui.bordered.images img,
- .ui.bordered.images svg,
- .ui.bordered.image img,
- .ui.bordered.image svg,
- img.ui.bordered.image {
- border: @imageBorder;
- }
+ /* --------------
+ Bordered
+ --------------- */
+
+ .ui.bordered.images .image,
+ .ui.bordered.images img,
+ .ui.bordered.images svg,
+ .ui.bordered.image img,
+ .ui.bordered.image svg,
+ img.ui.bordered.image {
+ border: @imageBorder;
+ }
}
& when (@variationImageCircular) {
- /*--------------
- Circular
- ---------------*/
-
- .ui.circular.images,
- .ui.circular.image {
- overflow: hidden;
- }
-
- .ui.circular.images .image,
- .ui.circular.image,
- .ui.circular.images .image > *,
- .ui.circular.image > * {
- -webkit-border-radius: @circularRadius;
- -moz-border-radius: @circularRadius;
- border-radius: @circularRadius;
- }
+ /* --------------
+ Circular
+ --------------- */
+
+ .ui.circular.images,
+ .ui.circular.image {
+ overflow: hidden;
+ }
+
+ .ui.circular.images .image,
+ .ui.circular.image,
+ .ui.circular.images .image > *,
+ .ui.circular.image > * {
+ border-radius: @circularRadius;
+ }
}
& when (@variationImageFluid) {
- /*--------------
- Fluid
- ---------------*/
-
- .ui.fluid.images,
- .ui.fluid.image,
- .ui.fluid.images img,
- .ui.fluid.images svg,
- .ui.fluid.image svg,
- .ui.fluid.image img {
- display: block;
- width: 100%;
- height: auto;
- }
+ /* --------------
+ Fluid
+ --------------- */
+
+ .ui.fluid.images,
+ .ui.fluid.image,
+ .ui.fluid.images img,
+ .ui.fluid.images svg,
+ .ui.fluid.image svg,
+ .ui.fluid.image img {
+ display: block;
+ width: 100%;
+ height: auto;
+ }
}
& when (@variationImageAvatar) {
- /*--------------
- Avatar
- ---------------*/
-
- .ui.avatar.images .image,
- .ui.avatar.images img,
- .ui.avatar.images svg,
- .ui.avatar.image img,
- .ui.avatar.image svg,
- .ui.avatar.image {
- margin-right: @avatarMargin;
-
- display: inline-block;
- width: @avatarSize;
- height: @avatarSize;
-
- -webkit-border-radius: @circularRadius;
- -moz-border-radius: @circularRadius;
- border-radius: @circularRadius;
- }
+ /* --------------
+ Avatar
+ --------------- */
+
+ .ui.avatar.images .image,
+ .ui.avatar.images img,
+ .ui.avatar.images svg,
+ .ui.avatar.image img,
+ .ui.avatar.image svg,
+ .ui.avatar.image {
+ margin-right: @avatarMargin;
+ display: inline-block;
+ width: @avatarSize;
+ height: @avatarSize;
+ border-radius: @circularRadius;
+ }
}
& when (@variationImageSpaced) {
- /*-------------------
- Spaced
- --------------------*/
-
- .ui.spaced.image {
- display: inline-block !important;
- margin-left: @spacedDistance;
- margin-right: @spacedDistance;
- }
-
- .ui[class*="left spaced"].image {
- margin-left: @spacedDistance;
- margin-right: 0;
- }
-
- .ui[class*="right spaced"].image {
- margin-left: 0;
- margin-right: @spacedDistance;
- }
+ /* -------------------
+ Spaced
+ -------------------- */
+
+ .ui.spaced.image {
+ display: inline-block !important;
+ margin-left: @spacedDistance;
+ margin-right: @spacedDistance;
+ }
+
+ .ui[class*="left spaced"].image {
+ margin-left: @spacedDistance;
+ margin-right: 0;
+ }
+
+ .ui[class*="right spaced"].image {
+ margin-left: 0;
+ margin-right: @spacedDistance;
+ }
}
& when (@variationImageFloated) {
- /*-------------------
- Floated
- --------------------*/
-
- .ui.floated.image,
- .ui.floated.images {
- float: left;
- margin-right: @floatedHorizontalMargin;
- margin-bottom: @floatedVerticalMargin;
- }
- .ui.right.floated.images,
- .ui.right.floated.image {
- float: right;
- margin-right: 0;
- margin-bottom: @floatedVerticalMargin;
- margin-left: @floatedHorizontalMargin;
- }
-
- .ui.floated.images:last-child,
- .ui.floated.image:last-child {
- margin-bottom: 0;
- }
+ /* -------------------
+ Floated
+ -------------------- */
+
+ .ui.floated.image,
+ .ui.floated.images {
+ float: left;
+ margin-right: @floatedHorizontalMargin;
+ margin-bottom: @floatedVerticalMargin;
+ }
+ .ui.right.floated.images,
+ .ui.right.floated.image {
+ float: right;
+ margin-right: 0;
+ margin-bottom: @floatedVerticalMargin;
+ margin-left: @floatedHorizontalMargin;
+ }
+
+ .ui.floated.images:last-child,
+ .ui.floated.image:last-child {
+ margin-bottom: 0;
+ }
}
& when (@variationImageCentered) {
- .ui.centered.image {
- display: block;
- margin-left: auto;
- margin-right: auto;
- }
- .ui.centered.images {
- display: flex;
- flex-direction: row;
- flex-wrap: wrap;
- align-items: stretch;
- justify-content: center;
- }
+ .ui.centered.image {
+ display: block;
+ margin-left: auto;
+ margin-right: auto;
+ }
+ .ui.centered.images {
+ display: flex;
+ flex-flow: row wrap;
+ align-items: stretch;
+ justify-content: center;
+ }
}
-/*--------------
+/* --------------
Sizes
----------------*/
+--------------- */
.ui.medium.images .image,
.ui.medium.images img,
.ui.medium.images svg,
.ui.medium.image {
- width: @mediumWidth;
- height: auto;
- font-size: @medium;
+ width: @mediumWidth;
+ height: auto;
+ font-size: @medium;
}
& when not (@variationImageSizes = false) {
- each(@variationImageSizes, {
- @w: @{value}Width;
- @s: @@value;
- .ui.@{value}.images .image,
- .ui.@{value}.images img,
- .ui.@{value}.images svg,
- .ui.@{value}.image {
- width: @@w;
- height: auto;
- font-size: @s;
- }
- })
+ each(@variationImageSizes, {
+ @w: @{value}Width;
+ @s: @@value;
+ .ui.@{value}.images .image,
+ .ui.@{value}.images img,
+ .ui.@{value}.images svg,
+ .ui.@{value}.image {
+ width: @@w;
+ height: auto;
+ font-size: @s;
+ }
+ });
}
& when (@variationImageGroups) {
- /*******************************
- Groups
- *******************************/
-
- .ui.images {
- font-size: 0;
- margin: 0 -@imageHorizontalMargin 0;
- }
-
- .ui.images .image,
- .ui.images > img,
- .ui.images > svg {
- display: inline-block;
- margin: 0 @imageHorizontalMargin @imageVerticalMargin;
- }
+ /*******************************
+ Groups
+ *******************************/
+
+ .ui.images {
+ font-size: 0;
+ margin: 0 -@imageHorizontalMargin;
+ }
+
+ .ui.images .image,
+ .ui.images > img,
+ .ui.images > svg {
+ display: inline-block;
+ margin: 0 @imageHorizontalMargin @imageVerticalMargin;
+ }
}
.loadUIOverrides();
diff --git a/definitions/elements/input.less b/definitions/elements/input.less
index 47817c0..9964448 100644
--- a/definitions/elements/input.less
+++ b/definitions/elements/input.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Input
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,803 +12,797 @@
Theme
*******************************/
-@type : 'element';
-@element : 'input';
-
-@import (multiple) '../../theme.config';
+@type: "element";
+@element: "input";
+@import (multiple) "../../theme.config";
/*******************************
Standard
*******************************/
-
-/*--------------------
+/* --------------------
Inputs
----------------------*/
+--------------------- */
.ui.input {
- position: relative;
- font-weight: @normal;
- font-style: normal;
- display: inline-flex;
- color: @inputColor;
+ position: relative;
+ font-weight: @normal;
+ font-style: normal;
+ display: inline-flex;
+ color: @inputColor;
}
.ui.input > input {
- margin: 0;
- max-width: 100%;
- flex: 1 0 auto;
- outline: none;
- -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
- text-align: @textAlign;
- line-height: @lineHeight;
-
- font-family: @inputFont;
-
- background: @background;
- border: @border;
- color: @inputColor;
- border-radius: @borderRadius;
- transition: @transition;
-
- box-shadow: @boxShadow;
- &:not([type="color"]) {
- padding: @padding;
- }
- &::-webkit-calendar-picker-indicator {
- padding: 0;
- opacity: @iconOpacity;
- transition: @iconTransition;
- cursor: pointer;
- }
+ margin: 0;
+ max-width: 100%;
+ flex: 1 0 auto;
+ outline: none;
+ -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
+ text-align: @textAlign;
+ line-height: @lineHeight;
+ font-family: @inputFont;
+ background: @background;
+ border: @border;
+ color: @inputColor;
+ border-radius: @borderRadius;
+ transition: @transition;
+ box-shadow: @boxShadow;
+ &:not([type="color"]) {
+ padding: @padding;
+ }
+ &::-webkit-calendar-picker-indicator {
+ padding: 0;
+ opacity: @iconOpacity;
+ transition: @iconTransition;
+ cursor: pointer;
+ }
}
-
-/*--------------------
+/* --------------------
Placeholder
----------------------*/
+--------------------- */
/* browsers require these rules separate */
.ui.input > input::-webkit-input-placeholder {
- color: @placeholderColor;
+ color: @placeholderColor;
}
.ui.input > input::-moz-placeholder {
- color: @placeholderColor;
- opacity: 1;
+ color: @placeholderColor;
+ opacity: 1;
}
-.ui.input > input:-ms-input-placeholder when (@supportIE){
- color: @placeholderColor;
+.ui.input > input:-ms-input-placeholder when (@supportIE) {
+ color: @placeholderColor;
}
-
/*******************************
States
*******************************/
& when (@variationInputDisabled) {
- /*--------------------
- Disabled
- ---------------------*/
-
- .ui.disabled.input,
- .ui.input:not(.disabled) input[disabled] {
- opacity: @disabledOpacity;
- }
-
- .ui.disabled.input > input,
- .ui.input:not(.disabled) input[disabled] {
- pointer-events: none;
- }
+ /* --------------------
+ Disabled
+ --------------------- */
+
+ .ui.disabled.input,
+ .ui.input:not(.disabled) input[disabled] {
+ opacity: @disabledOpacity;
+ }
+
+ .ui.disabled.input > input,
+ .ui.input:not(.disabled) input[disabled] {
+ pointer-events: @disabledPointerEvents;
+ }
}
-/*--------------------
+/* --------------------
Active
----------------------*/
+--------------------- */
.ui.input > input:active,
.ui.input.down input {
- border-color: @downBorderColor;
- background: @downBackground;
- color: @downColor;
- box-shadow: @downBoxShadow;
+ border-color: @downBorderColor;
+ background: @downBackground;
+ color: @downColor;
+ box-shadow: @downBoxShadow;
}
& when (@variationInputLoading) {
- /*--------------------
- Loading
- ---------------------*/
-
- .ui.loading.loading.input > i.icon::before {
- position: absolute;
- content: '';
- top: 50%;
- left: 50%;
-
- margin: @loaderMargin;
- width: @loaderSize;
- height: @loaderSize;
-
- border-radius: @circularRadius;
- border: @loaderLineWidth solid @loaderFillColor;
- }
- .ui.loading.loading.input > i.icon::after {
- position: absolute;
- content: '';
- top: 50%;
- left: 50%;
-
- margin: @loaderMargin;
- width: @loaderSize;
- height: @loaderSize;
-
- animation: loader @loaderSpeed infinite linear;
-
- border: @loaderLineWidth solid @loaderLineColor;
- border-radius: @circularRadius;
-
- box-shadow: 0 0 0 1px transparent;
- }
+ /* --------------------
+ Loading
+ --------------------- */
+
+ .ui.loading.loading.input > i.icon::before {
+ position: absolute;
+ content: "";
+ top: 50%;
+ left: 50%;
+ margin: @loaderMargin;
+ width: @loaderSize;
+ height: @loaderSize;
+ border-radius: @circularRadius;
+ border: @loaderLineWidth solid @loaderFillColor;
+ }
+ .ui.loading.loading.input > i.icon::after {
+ position: absolute;
+ content: "";
+ top: 50%;
+ left: 50%;
+ margin: @loaderMargin;
+ width: @loaderSize;
+ height: @loaderSize;
+ animation: loader @loaderSpeed infinite linear;
+ border: @loaderLineWidth solid @loaderLineColor;
+ border-radius: @circularRadius;
+ box-shadow: 0 0 0 1px transparent;
+ }
}
-
-/*--------------------
+/* --------------------
Focus
----------------------*/
+--------------------- */
.ui.input.focus > input,
-.ui.input > input:focus {
- border-color: @focusBorderColor;
- background: @focusBackground;
- color: @focusColor;
- box-shadow: @focusBoxShadow;
+.ui.input > input:focus {
+ border-color: @focusBorderColor;
+ background: @focusBackground;
+ color: @focusColor;
+ box-shadow: @focusBoxShadow;
}
.ui.input.focus > input::-webkit-input-placeholder,
.ui.input > input:focus::-webkit-input-placeholder {
- color: @placeholderFocusColor;
+ color: @placeholderFocusColor;
}
.ui.input.focus > input::-moz-placeholder,
.ui.input > input:focus::-moz-placeholder {
- color: @placeholderFocusColor;
+ color: @placeholderFocusColor;
}
& when (@supportIE) {
- .ui.input.focus > input:-ms-input-placeholder,
- .ui.input > input:focus:-ms-input-placeholder {
- color: @placeholderFocusColor;
- }
+ .ui.input.focus > input:-ms-input-placeholder,
+ .ui.input > input:focus:-ms-input-placeholder {
+ color: @placeholderFocusColor;
+ }
}
-
& when not (@variationInputStates = false) {
- /*--------------------
- States
- ---------------------*/
- each(@variationInputStates, {
- @state: @value;
-
- .ui.input.@{state} > input {
- background-color: @formStates[@@state][background];
- border-color: @formStates[@@state][borderColor];
- color: @formStates[@@state][color];
- box-shadow: @formStates[@@state][boxShadow];
- }
- & when (@state=error) {
- .ui.input > input:not(:placeholder-shown):invalid {
- background-color: @formStates[@@state][background];
- border-color: @formStates[@@state][borderColor];
- color: @formStates[@@state][color];
- box-shadow: @formStates[@@state][boxShadow];
- }
- .ui.input > input:not(:-ms-input-placeholder):invalid when (@supportIE){
- background-color: @formStates[@@state][background];
- border-color: @formStates[@@state][borderColor];
- color: @formStates[@@state][color];
- box-shadow: @formStates[@@state][boxShadow];
- }
- }
-
- /* Placeholder */
- .ui.input.@{state} > input::-webkit-input-placeholder {
- color: @formStates[@@state][inputPlaceholderColor];
- }
- .ui.input.@{state} > input::-moz-placeholder {
- color: @formStates[@@state][inputPlaceholderColor];
- }
- .ui.input.@{state} > input:-ms-input-placeholder when (@supportIE) {
- color: @formStates[@@state][inputPlaceholderColor] !important;
- }
-
- /* Focused Placeholder */
- .ui.input.@{state} > input:focus::-webkit-input-placeholder {
- color: @formStates[@@state][inputPlaceholderFocusColor];
- }
- .ui.input.@{state} > input:focus::-moz-placeholder {
- color: @formStates[@@state][inputPlaceholderFocusColor];
- }
- .ui.input.@{state} > input:focus:-ms-input-placeholder when (@supportIE){
- color: @formStates[@@state][inputPlaceholderFocusColor] !important;
- }
- })
+ /* --------------------
+ States
+ --------------------- */
+ each(@variationInputStates, {
+ @state: @value;
+
+ .ui.input.@{state} > input {
+ background-color: @formStates[@@state][background];
+ border-color: @formStates[@@state][borderColor];
+ color: @formStates[@@state][color];
+ box-shadow: @formStates[@@state][boxShadow];
+ }
+ & when (@state=error) and (@variationInputInvalid) {
+ .ui.input > input:not(:placeholder-shown):invalid {
+ background-color: @formStates[@@state][background];
+ border-color: @formStates[@@state][borderColor];
+ color: @formStates[@@state][color];
+ box-shadow: @formStates[@@state][boxShadow];
+ }
+ .ui.input > input:not(:-ms-input-placeholder):invalid when (@supportIE){
+ background-color: @formStates[@@state][background];
+ border-color: @formStates[@@state][borderColor];
+ color: @formStates[@@state][color];
+ box-shadow: @formStates[@@state][boxShadow];
+ }
+ }
+
+ /* Placeholder */
+ .ui.input.@{state} > input::-webkit-input-placeholder {
+ color: @formStates[@@state][inputPlaceholderColor];
+ }
+ .ui.input.@{state} > input::-moz-placeholder {
+ color: @formStates[@@state][inputPlaceholderColor];
+ }
+ .ui.input.@{state} > input:-ms-input-placeholder when (@supportIE) {
+ color: @formStates[@@state][inputPlaceholderColor] !important;
+ }
+
+ /* Focused Placeholder */
+ .ui.input.@{state} > input:focus::-webkit-input-placeholder {
+ color: @formStates[@@state][inputPlaceholderFocusColor];
+ }
+ .ui.input.@{state} > input:focus::-moz-placeholder {
+ color: @formStates[@@state][inputPlaceholderFocusColor];
+ }
+ .ui.input.@{state} > input:focus:-ms-input-placeholder when (@supportIE){
+ color: @formStates[@@state][inputPlaceholderFocusColor] !important;
+ }
+ });
}
+
/*******************************
Variations
*******************************/
& when (@variationInputTransparent) {
- /*--------------------
- Transparent
- ---------------------*/
-
-
- .ui.transparent.input > textarea,
- .ui.transparent.input > input {
- border-color: transparent !important;
- background-color: transparent !important;
- padding: 0;
- box-shadow: none !important;
- border-radius: 0 !important;
- }
- .field .ui.transparent.input > textarea {
- padding: @padding;
- }
-
- /* Transparent Icon */
- :not(.field) > .ui.transparent.icon.input > i.icon {
- width: @transparentIconWidth;
- }
- :not(.field) > .ui.ui.ui.transparent.icon.input > input {
- padding-left: 0;
- padding-right: @transparentIconMargin;
- }
- :not(.field) > .ui.ui.ui.transparent[class*="left icon"].input > input {
- padding-left: @transparentIconMargin;
- padding-right: 0;
- }
- & when (@variationInputInverted) {
- /* Transparent Inverted */
- .ui.transparent.inverted.input {
- color: @transparentInvertedColor;
- }
- .ui.ui.transparent.inverted.input > textarea,
- .ui.ui.transparent.inverted.input > input {
- color: inherit;
- }
-
- .ui.transparent.inverted.input > input::-webkit-input-placeholder {
- color: @transparentInvertedPlaceholderColor;
- }
- .ui.transparent.inverted.input > input::-moz-placeholder {
- color: @transparentInvertedPlaceholderColor;
- }
- .ui.transparent.inverted.input > input:-ms-input-placeholder when (@supportIE) {
- color: @transparentInvertedPlaceholderColor;
- }
- }
+ /* --------------------
+ Transparent
+ --------------------- */
+
+ .ui.transparent.input > textarea,
+ .ui.transparent.input > input {
+ border-color: transparent !important;
+ background-color: transparent !important;
+ padding: 0;
+ box-shadow: none !important;
+ border-radius: 0 !important;
+ }
+ .field .ui.transparent.input > textarea {
+ padding: @padding;
+ }
+
+ /* Transparent Icon */
+ :not(.field) > .ui.transparent.icon.input > i.icon {
+ width: @transparentIconWidth;
+ }
+ :not(.field) > .ui.ui.ui.transparent.icon.input > input {
+ padding-left: 0;
+ padding-right: @transparentIconMargin;
+ }
+ :not(.field) > .ui.ui.ui.transparent[class*="left icon"].input > input {
+ padding-left: @transparentIconMargin;
+ padding-right: 0;
+ }
+ & when (@variationInputInverted) {
+ /* Transparent Inverted */
+ .ui.transparent.inverted.input {
+ color: @transparentInvertedColor;
+ }
+ .ui.ui.transparent.inverted.input > textarea,
+ .ui.ui.transparent.inverted.input > input {
+ color: inherit;
+ }
+
+ .ui.transparent.inverted.input > input::-webkit-input-placeholder {
+ color: @transparentInvertedPlaceholderColor;
+ }
+ .ui.transparent.inverted.input > input::-moz-placeholder {
+ color: @transparentInvertedPlaceholderColor;
+ }
+ .ui.transparent.inverted.input > input:-ms-input-placeholder when (@supportIE) {
+ color: @transparentInvertedPlaceholderColor;
+ }
+ }
}
& when (@variationInputIcon) {
- /*--------------------
- Icon
- ---------------------*/
-
- .ui.icon.input > i.icon {
- cursor: default;
- position: absolute;
- line-height: 1;
- text-align: center;
- top: 0;
- right: 0;
- margin: 0;
- height: 100%;
-
- width: @iconWidth;
- opacity: @iconOpacity;
- border-radius: 0 @borderRadius @borderRadius 0;
- transition: @iconTransition;
- }
- .ui.icon.input > i.icon:not(.link) {
- pointer-events: none;
- }
- .ui.ui.ui.ui.icon.input:not(.corner) > textarea,
- .ui.ui.ui.ui.icon.input:not(.corner) > input {
- padding-right: @iconMargin;
- }
-
- .ui.icon.input > i.icon::before,
- .ui.icon.input > i.icon::after {
- left: 0;
- position: absolute;
- text-align: center;
- top: 50%;
- width: 100%;
- margin-top: @iconOffset;
- }
- .ui.icon.input > i.link.icon {
- cursor: pointer;
- }
- .ui.icon.input > i.circular.icon {
- top: @circularIconVerticalOffset;
- right: @circularIconHorizontalOffset;
- }
-
- /* Left Icon Input */
- .ui[class*="left icon"].input > i.icon {
- right: auto;
- left: @borderWidth;
- border-radius: @borderRadius 0 0 @borderRadius;
- }
- .ui[class*="left icon"].input > i.circular.icon {
- right: auto;
- left: @circularIconHorizontalOffset;
- }
- .ui.ui.ui.ui[class*="left icon"]:not([class*="left corner"]).input > textarea,
- .ui.ui.ui.ui[class*="left icon"]:not([class*="left corner"]).input > input {
- padding-left: @iconMargin;
- }
- .ui.ui.ui.ui[class*="left icon"]:not(.corner).input > textarea,
- .ui.ui.ui.ui[class*="left icon"]:not(.corner).input > input {
- padding-right: @horizontalPadding;
- }
-
- /* Focus */
- .ui.input > input:focus::-webkit-calendar-picker-indicator,
- .ui.icon.input > textarea:focus ~ i.icon,
- .ui.icon.input > input:focus ~ i.icon {
- opacity: @iconFocusOpacity;
- }
+ /* --------------------
+ Icon
+ --------------------- */
+
+ .ui.icon.input > i.icon {
+ cursor: default;
+ position: absolute;
+ line-height: 1;
+ text-align: center;
+ top: 0;
+ right: 0;
+ margin: 0;
+ height: 100%;
+ width: @iconWidth;
+ opacity: @iconOpacity;
+ border-radius: 0 @borderRadius @borderRadius 0;
+ transition: @iconTransition;
+ }
+ .ui.icon.input > i.icon:not(.link) {
+ pointer-events: none;
+ }
+ .ui.ui.ui.ui.icon.input:not(.corner) > textarea,
+ .ui.ui.ui.ui.icon.input:not(.corner) > input {
+ padding-right: @iconMargin;
+ }
+
+ .ui.icon.input > i.icon::before,
+ .ui.icon.input > i.icon::after {
+ left: 0;
+ position: absolute;
+ text-align: center;
+ top: 50%;
+ width: 100%;
+ margin-top: @iconOffset;
+ }
+ .ui.icon.input > i.link.icon {
+ cursor: pointer;
+ }
+ .ui.icon.input > i.circular.icon {
+ top: @circularIconVerticalOffset;
+ right: @circularIconHorizontalOffset;
+ }
+
+ /* Left Icon Input */
+ .ui[class*="left icon"].input > i.icon {
+ right: auto;
+ left: @borderWidth;
+ border-radius: @borderRadius 0 0 @borderRadius;
+ }
+ .ui[class*="left icon"].input > i.circular.icon {
+ right: auto;
+ left: @circularIconHorizontalOffset;
+ }
+ .ui.ui.ui.ui[class*="left icon"]:not([class*="left corner"]).input > textarea,
+ .ui.ui.ui.ui[class*="left icon"]:not([class*="left corner"]).input > input {
+ padding-left: @iconMargin;
+ }
+ .ui.ui.ui.ui[class*="left icon"]:not(.corner).input > textarea,
+ .ui.ui.ui.ui[class*="left icon"]:not(.corner).input > input {
+ padding-right: @horizontalPadding;
+ }
+
+ /* Focus */
+ .ui.input > input:focus::-webkit-calendar-picker-indicator,
+ .ui.icon.input > textarea:focus ~ i.icon,
+ .ui.icon.input > input:focus ~ i.icon {
+ opacity: @iconFocusOpacity;
+ }
}
& when (@variationInputLabeled) {
- /*--------------------
- Labeled
- ---------------------*/
+ /* --------------------
+ Labeled
+ --------------------- */
- /* Adjacent Label */
- .ui.labeled.input > .label {
- flex: 0 0 auto;
- margin: 0;
- font-size: @relativeMedium;
- }
- .ui.labeled.input > .label:not(.corner) {
- padding-top: @verticalPadding;
- padding-bottom: @verticalPadding;
- }
-
- /* Regular Label on Left */
- .ui.labeled.input:not([class*="corner labeled"]) .label:first-child {
- border-top-right-radius: 0;
- border-bottom-right-radius: 0;
- }
- .ui.labeled.input:not([class*="corner labeled"]) .label:first-child + input {
- border-top-left-radius: 0;
- border-bottom-left-radius: 0;
- border-left-color: transparent;
- }
- .ui.labeled.input:not([class*="corner labeled"]) .label:first-child + input:focus {
- border-left-color: @focusBorderColor;
- }
-
- /* Regular Label on Right */
- .ui[class*="right labeled"].input > input {
- border-top-right-radius: 0 !important;
- border-bottom-right-radius: 0 !important;
- border-right-color: transparent !important;
- }
- .ui[class*="right labeled"].input > input + .label {
- border-top-left-radius: 0;
- border-bottom-left-radius: 0;
- }
-
- .ui[class*="right labeled"].input > input:focus {
- border-right-color: @focusBorderColor !important;
- }
+ /* Adjacent Label */
+ .ui.labeled.input > .label {
+ flex: 0 0 auto;
+ margin: 0;
+ font-size: @relativeMedium;
+ }
+ .ui.labeled.input > .label:not(.corner) {
+ padding-top: @verticalPadding;
+ padding-bottom: @verticalPadding;
+ }
+
+ /* Regular Label on Left */
+ .ui.labeled.input:not([class*="corner labeled"]) .label:first-child {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+ }
+ .ui.labeled.input:not([class*="corner labeled"]) .label:first-child + input {
+ border-top-left-radius: 0;
+ border-bottom-left-radius: 0;
+ border-left-color: transparent;
+ }
+ .ui.labeled.input:not([class*="corner labeled"]) .label:first-child + input:focus {
+ border-left-color: @focusBorderColor;
+ }
+
+ /* Regular Label on Right */
+ .ui[class*="right labeled"].input > input {
+ border-top-right-radius: 0 !important;
+ border-bottom-right-radius: 0 !important;
+ border-right-color: transparent !important;
+ }
+ .ui[class*="right labeled"].input > input + .label {
+ border-top-left-radius: 0;
+ border-bottom-left-radius: 0;
+ }
+
+ .ui[class*="right labeled"].input > input:focus {
+ border-right-color: @focusBorderColor !important;
+ }
}
& when (@variationInputCorner) {
- /* Corner Label */
- .ui.labeled.input .corner.label {
- top: @labelCornerTop;
- right: @labelCornerRight;
- font-size: @labelCornerSize;
- border-radius: 0 @borderRadius 0 0;
- }
-
- /* Spacing with corner label */
- .ui[class*="corner labeled"]:not([class*="left corner labeled"]).input > .ui.dropdown,
- .ui[class*="corner labeled"]:not([class*="left corner labeled"]).input > textarea,
- .ui[class*="corner labeled"]:not([class*="left corner labeled"]).input > input {
- padding-right: @labeledMargin;
- }
- .ui[class*="corner labeled"].icon.input:not([class*="left corner labeled"]) > .ui.dropdown,
- .ui[class*="corner labeled"].icon.input:not([class*="left corner labeled"]) > textarea,
- .ui[class*="corner labeled"].icon.input:not([class*="left corner labeled"]) > input {
- padding-right: @labeledIconInputMargin;
- }
- .ui[class*="corner labeled"].icon.input:not([class*="left corner labeled"]) > i.icon {
- margin-right: @labeledIconMargin;
- }
-
- /* Left Labeled */
- .ui[class*="left icon"].input > .ui.dropdown,
- .ui[class*="left corner labeled"].input > .ui.dropdown,
- .ui[class*="left corner labeled"].input > textarea,
- .ui[class*="left corner labeled"].input > input {
- padding-left: @labeledMargin;
- }
- & when (@variationInputIcon) {
- .ui[class*="corner labeled"]:not([class*="left corner labeled"])[class*="left icon"].input > .ui.dropdown,
- .ui[class*="corner labeled"]:not([class*="left corner labeled"])[class*="left icon"].input > textarea,
- .ui[class*="corner labeled"]:not([class*="left corner labeled"])[class*="left icon"].input > input {
- padding-right: @labeledIconInputMargin;
- }
- .ui[class*="left corner labeled"][class*="left icon"].input > .ui.dropdown,
- .ui[class*="left corner labeled"][class*="left icon"].input > textarea,
- .ui[class*="left corner labeled"][class*="left icon"].input > input {
- padding-left: @labeledAndIconMargin;
- }
- .ui[class*="left corner labeled"].icon.input > i.icon {
- margin-left: @labeledIconMargin;
- }
- .ui[class*="left corner labeled"].icon:not([class*="left icon"]).input > input {
- padding-right: @labeledMargin;
- }
- .ui[class*="corner labeled"]:not([class*="left corner labeled"]).icon:not([class*="left icon"]).input > input {
- padding-right: @labeledMargin * 2;
- }
- }
-
- .ui[class*="left icon"].input > .ui.dropdown,
- .ui[class*="left corner labeled"].input > .ui.dropdown {
- & > .search {
- padding-left: @labeledMargin;
- }
- & > .menu {
- padding-left: @labeledIconMargin;
- & > .item {
+ /* Corner Label */
+ .ui.labeled.input .corner.label {
+ top: @labelCornerTop;
+ right: @labelCornerRight;
+ font-size: @labelCornerSize;
+ border-radius: 0 @borderRadius 0 0;
+ }
+
+ /* Spacing with corner label */
+ .ui[class*="corner labeled"]:not([class*="left corner labeled"]).input > .ui.dropdown,
+ .ui[class*="corner labeled"]:not([class*="left corner labeled"]).input > textarea,
+ .ui[class*="corner labeled"]:not([class*="left corner labeled"]).input > input {
+ padding-right: @labeledMargin;
+ }
+ .ui[class*="corner labeled"].icon.input:not([class*="left corner labeled"]) > .ui.dropdown,
+ .ui[class*="corner labeled"].icon.input:not([class*="left corner labeled"]) > textarea,
+ .ui[class*="corner labeled"].icon.input:not([class*="left corner labeled"]) > input {
+ padding-right: @labeledIconInputMargin;
+ }
+ .ui[class*="corner labeled"].icon.input:not([class*="left corner labeled"]) > i.icon {
+ margin-right: @labeledIconMargin;
+ }
+
+ /* Left Labeled */
+ .ui[class*="left icon"].input > .ui.dropdown:first-child,
+ .ui[class*="left icon"].input > i.icon + .ui.dropdown,
+ .ui[class*="left corner labeled"].input > .ui.dropdown,
+ .ui[class*="left corner labeled"].input > textarea,
+ .ui[class*="left corner labeled"].input > input {
padding-left: @labeledMargin;
- margin-left: -@labeledIconMargin;
- }
- }
- }
- .ui[class*="left corner labeled"][class*="left icon"].input > .ui.dropdown {
- & > .search {
- padding-left: @labeledAndIconMargin;
- }
- & > .menu > .item {
- padding-left: @labeledAndIconMargin;
- }
- }
- .ui.icon.input:not([class*="left icon"]) > .ui.dropdown,
- .ui[class*="corner labeled"]:not([class*="left corner labeled"]).input > .ui.dropdown {
- & > .search {
- padding-right: @labeledMargin + @labeledIconInputMargin;
- }
- & > .remove.icon,
- > .dropdown.icon {
- padding-right: @labeledMargin;
- }
- }
- .ui[class*="corner labeled"]:not([class*="left corner labeled"]).icon:not([class*="left icon"]).input > .ui.dropdown {
- & > .search {
- padding-right: @labeledAndIconMargin + @labeledIconInputMargin;
- }
- & > .remove.icon,
- > .dropdown.icon {
- padding-right: @labeledAndIconMargin;
- }
- }
- .ui.icon.input > .ui.visible.dropdown ~ i.icon,
- .ui.icon.input > .ui.active.dropdown ~ i.icon,
- .ui[class*="corner labeled"].input > .ui.visible.dropdown ~ .ui.corner.label,
- .ui[class*="corner labeled"].input > .ui.active.dropdown ~ .ui.corner.label {
- z-index: @labeledDropdownZIndex;
- }
+ }
+ & when (@variationInputIcon) {
+ .ui[class*="corner labeled"]:not([class*="left corner labeled"])[class*="left icon"].input > .ui.dropdown,
+ .ui[class*="corner labeled"]:not([class*="left corner labeled"])[class*="left icon"].input > textarea,
+ .ui[class*="corner labeled"]:not([class*="left corner labeled"])[class*="left icon"].input > input {
+ padding-right: @labeledIconInputMargin;
+ }
+ .ui.ui[class*="left corner labeled"][class*="left icon"].input > .ui.dropdown,
+ .ui.ui[class*="left corner labeled"][class*="left icon"].input > textarea,
+ .ui.ui[class*="left corner labeled"][class*="left icon"].input > input {
+ padding-left: @labeledAndIconMargin;
+ }
+ .ui[class*="left corner labeled"].icon.input > i.icon {
+ margin-left: @labeledIconMargin;
+ }
+ .ui[class*="left corner labeled"].icon:not([class*="left icon"]).input > input {
+ padding-right: @labeledMargin;
+ }
+ .ui[class*="corner labeled"]:not([class*="left corner labeled"]).icon:not([class*="left icon"]).input > input {
+ padding-right: @labeledMargin * 2;
+ }
+ }
+
+ .ui[class*="left icon"].input > .ui.dropdown,
+ .ui[class*="left corner labeled"].input > .ui.dropdown {
+ & > .search {
+ padding-left: @labeledMargin;
+ }
+ & > .menu {
+ padding-left: @labeledIconMargin;
+ & > .item {
+ padding-left: @labeledMargin;
+ margin-left: -@labeledIconMargin;
+ }
+ }
+ }
+ .ui[class*="left corner labeled"][class*="left icon"].input > .ui.dropdown {
+ & > .search {
+ padding-left: @labeledAndIconMargin;
+ }
+ & > .menu > .item {
+ padding-left: @labeledAndIconMargin;
+ }
+ }
+ .ui.icon.input:not([class*="left icon"]) > .ui.dropdown,
+ .ui[class*="corner labeled"]:not([class*="left corner labeled"]).input > .ui.dropdown {
+ & > .search {
+ padding-right: @labeledMargin + @labeledIconInputMargin;
+ }
+ & > .remove.icon,
+ > .dropdown.icon {
+ padding-right: @labeledMargin;
+ }
+ }
+ @supports selector(:has(.f)) {
+ .ui.icon.input:not([class*="left icon"]) > .ui.dropdown > .dropdown.icon {
+ padding-right: initial;
+ }
+ .ui.icon.input:not([class*="left icon"]):not(:has(.ui.dropdown ~ input)) > .ui.dropdown > .dropdown.icon {
+ padding-right: @labeledMargin;
+ }
+ }
+ .ui.ui[class*="corner labeled"]:not([class*="left corner labeled"]).icon:not([class*="left icon"]).input > .ui.dropdown {
+ & > .search {
+ padding-right: @labeledAndIconMargin + @labeledIconInputMargin;
+ }
+ & > .remove.icon,
+ > .dropdown.icon {
+ padding-right: @labeledAndIconMargin;
+ }
+ }
+ .ui.icon.input > .ui.visible.dropdown ~ i.icon,
+ .ui.icon.input > .ui.active.dropdown ~ i.icon,
+ .ui[class*="corner labeled"].input > .ui.visible.dropdown ~ .ui.corner.label,
+ .ui[class*="corner labeled"].input > .ui.active.dropdown ~ .ui.corner.label {
+ z-index: @labeledDropdownZIndex;
+ }
}
& when (@variationInputIcon) {
- .ui.icon.input > textarea ~ i.icon {
- height: @textareaIconHeight;
- }
- :not(.field) > .ui.transparent.icon.input > textarea ~ i.icon {
- height: @transparentTextareaIconHeight;
- }
+ .ui.icon.input > textarea ~ i.icon {
+ height: @textareaIconHeight;
+ }
+ :not(.field) > .ui.transparent.icon.input > textarea ~ i.icon {
+ height: @transparentTextareaIconHeight;
+ }
}
& when (@variationInputCorner) {
- /* Corner Label Position */
- .ui.input > .ui.corner.label {
- top: @borderWidth;
- right: @borderWidth;
- }
- .ui.input > .ui.left.corner.label {
- right: auto;
- left: @borderWidth;
- }
+ /* Corner Label Position */
+ .ui.input > .ui.corner.label {
+ top: @borderWidth;
+ right: @borderWidth;
+ }
+ .ui.input > .ui.left.corner.label {
+ right: auto;
+ left: @borderWidth;
+ }
}
& when ((@variationInputLabeled) or (@variationInputAction)) and not (@variationInputStates = false) {
- /* Labeled and action input states */
- each(@variationInputStates, {
- @state: @value;
- @borderColor: @formStates[@@state][borderColor];
-
- .ui.form .field.@{state} > .ui.action.input > .ui.button,
- .ui.form .field.@{state} > .ui.labeled.input:not([class*="corner labeled"]) > .ui.label,
- .ui.action.input.@{state} > .ui.button,
- .ui.labeled.input.@{state}:not([class*="corner labeled"]) > .ui.label {
- border-top: @borderWidth solid @borderColor;
- border-bottom: @borderWidth solid @borderColor;
- }
- .ui.form .field.@{state} > .ui[class*="left action"].input > .ui.button,
- .ui.form .field.@{state} > .ui.labeled.input:not(.right):not([class*="corner labeled"]) > .ui.label,
- .ui[class*="left action"].input.@{state} > .ui.button,
- .ui.labeled.input.@{state}:not(.right):not([class*="corner labeled"]) > .ui.label {
- border-left: @borderWidth solid @borderColor;
- }
- .ui.form .field.@{state} > .ui.action.input:not([class*="left action"]) > input + .ui.button,
- .ui.form .field.@{state} > .ui.right.labeled.input:not([class*="corner labeled"]) > input + .ui.label,
- .ui.action.input.@{state}:not([class*="left action"]) > input + .ui.button,
- .ui.right.labeled.input.@{state}:not([class*="corner labeled"]) > input + .ui.label {
- border-right: @borderWidth solid @borderColor;
- }
- .ui.form .field.@{state} > .ui.right.labeled.input:not([class*="corner labeled"]) > .ui.label:first-child,
- .ui.right.labeled.input.@{state}:not([class*="corner labeled"]) > .ui.label:first-child {
- border-left: @borderWidth solid @borderColor;
- }
- })
+ /* Labeled and action input states */
+ each(@variationInputStates, {
+ @state: @value;
+ @borderColor: @formStates[@@state][borderColor];
+
+ .ui.form .field.@{state} > .ui.action.input > .ui.button,
+ .ui.form .field.@{state} > .ui.labeled.input:not([class*="corner labeled"]) > .ui.label,
+ .ui.action.input.@{state} > .ui.button,
+ .ui.labeled.input.@{state}:not([class*="corner labeled"]) > .ui.label {
+ border-top: @borderWidth solid @borderColor;
+ border-bottom: @borderWidth solid @borderColor;
+ }
+ .ui.form .field.@{state} > .ui[class*="left action"].input > .ui.button,
+ .ui.form .field.@{state} > .ui.labeled.input:not(.right):not([class*="corner labeled"]) > .ui.label,
+ .ui[class*="left action"].input.@{state} > .ui.button,
+ .ui.labeled.input.@{state}:not(.right):not([class*="corner labeled"]) > .ui.label {
+ border-left: @borderWidth solid @borderColor;
+ }
+ .ui.form .field.@{state} > .ui.action.input:not([class*="left action"]) > input + .ui.button,
+ .ui.form .field.@{state} > .ui.right.labeled.input:not([class*="corner labeled"]) > input + .ui.label,
+ .ui.action.input.@{state}:not([class*="left action"]) > input + .ui.button,
+ .ui.right.labeled.input.@{state}:not([class*="corner labeled"]) > input + .ui.label {
+ border-right: @borderWidth solid @borderColor;
+ }
+ .ui.form .field.@{state} > .ui.right.labeled.input:not([class*="corner labeled"]) > .ui.label:first-child,
+ .ui.right.labeled.input.@{state}:not([class*="corner labeled"]) > .ui.label:first-child {
+ border-left: @borderWidth solid @borderColor;
+ }
+ });
}
& when (@variationInputAction) {
- /*--------------------
- Action
- ---------------------*/
-
- .ui.action.input > .button,
- .ui.action.input > .buttons {
- display: flex;
- align-items: center;
- flex: 0 0 auto;
- }
- .ui.action.input > .button,
- .ui.action.input > .buttons > .button {
- padding-top: @verticalPadding;
- padding-bottom: @verticalPadding;
- margin: 0;
- }
-
- /* Input when ui Left*/
- .ui[class*="left action"].input > input {
- border-top-left-radius: 0;
- border-bottom-left-radius: 0;
- border-left-color: transparent;
- }
-
- /* Input when ui Right*/
- .ui.action.input:not([class*="left action"]) > input {
- border-top-right-radius: 0;
- border-bottom-right-radius: 0;
- border-right-color: transparent;
- }
-
- /* Button and Dropdown */
- .ui.action.input > .dropdown:first-child,
- .ui.action.input > .button:first-child,
- .ui.action.input > .buttons:first-child > .button {
- border-radius: @borderRadius 0 0 @borderRadius;
- }
- .ui.action.input > .dropdown:not(:first-child),
- .ui.action.input > .button:not(:first-child),
- .ui.action.input > .buttons:not(:first-child) > .button {
- border-radius: 0;
- }
- .ui.action.input > .dropdown:last-child,
- .ui.action.input > .button:last-child,
- .ui.action.input > .buttons:last-child > .button {
- border-radius: 0 @borderRadius @borderRadius 0;
- }
-
- /* Input Focus */
- .ui.action.input:not([class*="left action"]) > input:focus {
- border-right-color: @focusBorderColor;
- }
-
- .ui.ui[class*="left action"].input > input:focus {
- border-left-color: @focusBorderColor;
- }
+ /* --------------------
+ Action
+ --------------------- */
+
+ .ui.action.input > .button,
+ .ui.action.input > .buttons {
+ display: flex;
+ align-items: center;
+ flex: 0 0 auto;
+ }
+ .ui.action.input > .button,
+ .ui.action.input > .buttons > .button {
+ padding-top: @verticalPadding;
+ padding-bottom: @verticalPadding;
+ margin: 0;
+ }
+
+ /* Input when ui Left */
+ .ui[class*="left action"].input > input {
+ border-top-left-radius: 0;
+ border-bottom-left-radius: 0;
+ border-left-color: transparent;
+ }
+
+ /* Input when ui Right */
+ .ui.action.input:not([class*="left action"]) > input {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+ border-right-color: transparent;
+ }
+
+ /* Button and Dropdown */
+ .ui.action.input > .dropdown:first-child,
+ .ui.action.input > .button:first-child,
+ .ui.action.input > .buttons:first-child > .button {
+ border-radius: @borderRadius 0 0 @borderRadius;
+ }
+ .ui.action.input > .dropdown:not(:first-child),
+ .ui.action.input > .button:not(:first-child),
+ .ui.action.input > .buttons:not(:first-child) > .button {
+ border-radius: 0;
+ }
+ .ui.action.input > .dropdown:last-child,
+ .ui.action.input > .button:last-child,
+ .ui.action.input > .buttons:last-child > .button {
+ border-radius: 0 @borderRadius @borderRadius 0;
+ }
+
+ /* Input Focus */
+ .ui.action.input:not([class*="left action"]) > input:focus {
+ border-right-color: @focusBorderColor;
+ }
+
+ .ui.ui[class*="left action"].input > input:focus {
+ border-left-color: @focusBorderColor;
+ }
}
& when (@variationInputInverted) {
- /*--------------------
- Inverted
- ---------------------*/
-
- /* Standard */
- .ui.inverted.input > input {
- border: none;
- }
+ /* --------------------
+ Inverted
+ --------------------- */
+
+ /* Standard */
+ .ui.inverted.input > input {
+ border: none;
+ }
}
& when (@variationInputFluid) {
- /*--------------------
- Fluid
- ---------------------*/
-
- .ui.fluid.input {
- display: flex;
- }
- .ui.fluid.input > input {
- width: 0 !important;
- }
-}
+ /* --------------------
+ Fluid
+ --------------------- */
+ .ui.fluid.input {
+ display: flex;
+ }
+ .ui.fluid.input > input {
+ width: 0 !important;
+ }
+}
& when (@variationInputFile) {
- /*--------------------
- File
- ---------------------*/
-
- /* width hack for chrome/edge */
- .ui.file.input {
- width: 100%;
- & input[type="file"] {
- width: 0;
- }
- }
-
- .ui.form .field > input[type="file"],
- .ui.file.input:not(.action) input[type="file"] {
- padding: 0;
- }
-
- .ui.action.file.input input[type="file"]::-webkit-file-upload-button {
- display: none;
- }
- .ui.form .field input[type="file"]::-webkit-file-upload-button,
- .ui.file.input input[type="file"]::-webkit-file-upload-button {
- border: none;
- cursor: pointer;
- padding: @padding;
- margin-right: @fileButtonMargin;
- background: @fileButtonBackground;
- font-weight: @fileButtonFontWeight;
- color: @fileButtonTextColor;
- &:hover {
- background: @fileButtonBackgroundHover;
- color: @fileButtonTextColor;
- }
- }
- & when (@supportIE) {
- .ui.action.file.input input[type="file"]::-ms-browse {
- display: none;
- }
- .ui.form .field input[type="file"]::-ms-browse,
- .ui.file.input input[type="file"]::-ms-browse {
- border: none;
- cursor: pointer;
- padding: @padding;
- margin: 0;
- background: @fileButtonBackground;
- font-weight: @fileButtonFontWeight;
- color: @fileButtonTextColor;
- &:hover {
- background: @fileButtonBackgroundHover;
+ /* --------------------
+ File
+ --------------------- */
+
+ /* width hack for chrome/edge */
+ .ui.file.input {
+ width: 100%;
+ & input[type="file"] {
+ width: 0;
+ }
+ }
+
+ .ui.form .field > input[type="file"],
+ .ui.file.input:not(.action) input[type="file"] {
+ padding: 0;
+ }
+
+ .ui.action.file.input input[type="file"]::-webkit-file-upload-button {
+ display: none;
+ }
+ .ui.form .field input[type="file"]::-webkit-file-upload-button,
+ .ui.file.input input[type="file"]::-webkit-file-upload-button {
+ border: none;
+ cursor: pointer;
+ padding: @padding;
+ margin-right: @fileButtonMargin;
+ background: @fileButtonBackground;
+ font-weight: @fileButtonFontWeight;
color: @fileButtonTextColor;
- }
- }
- /* IE needs additional styling for input field :S */
- @media all and (-ms-high-contrast: none) {
- .ui.file.input > input[type="file"],
- input[type="file"].ui.file.input {
- padding: 0 !important;
- }
- }
- }
-
- .ui.action.file.input input[type="file"]::file-selector-button {
- display: none;
- }
- .ui.form .field input[type="file"]::file-selector-button,
- .ui.file.input input[type="file"]::file-selector-button {
- border: none;
- cursor: pointer;
- padding: @padding;
- margin-right: @fileButtonMargin;
- background: @fileButtonBackground;
- font-weight: @fileButtonFontWeight;
- color: @fileButtonTextColor;
- &:hover {
- background: @fileButtonBackgroundHover;
- color: @fileButtonTextColor;
- }
- }
-
- .ui.form .field input[type="file"]:required:invalid,
- .ui.file.input input[type="file"]:required:invalid {
- color: @negativeTextColor;
- background: @negativeBackgroundColor ;
- border-color: @negativeBorderColor;
- }
-
- input[type="file"].ui.invisible.file.input,
- .ui.invisible.file.input input[type="file"] {
- left: -99999px;
- position: absolute;
- }
-
- input[type="file"].ui.file.input:focus + label.ui.button:not(.basic):not(.tertiary),
- .ui.file.input input[type="file"]:focus + label.ui.button:not(.basic):not(.tertiary) {
- background: @fileButtonBackgroundHover;
- color: @hoveredTextColor;
- &.inverted {
- background: @fileButtonInvertedBackgroundHover;
- }
- }
-
- /* this is related to existing buttons, so the button color variable is used here! */
- & when not (@variationButtonColors = false) {
- each(@variationButtonColors, {
- @color: @value;
- @h: @colors[@@color][hover];
- @lh: @colors[@@color][lightHover];
-
- input[type="file"].ui.file.input:focus + label.ui.@{color}.button:not(.basic):not(.tertiary),
- .ui.file.input input[type="file"]:focus + label.ui.@{color}.button:not(.basic):not(.tertiary) {
- background-color: @h;
- color: @white;
- &.inverted when (@variationButtonInverted) {
- background-color: @lh;
- }
- }
- })
- }
-
- & when not (@variationInputColors = false) {
- each(@variationInputColors, {
- @color: @value;
- @c: @colors[@@color][color];
- @h: @colors[@@color][hover];
-
- input[type="file"].ui.@{color}.file.input::-webkit-file-upload-button,
- .ui.@{color}.file.input input[type="file"]::-webkit-file-upload-button {
- background: @c;
- color: @white;
&:hover {
- background: @h;
- }
- }
- & when (@supportIE) {
- input[type="file"].ui.@{color}.file.input::-ms-browse,
- .ui.@{color}.file.input input[type="file"]::-ms-browse {
- background: @c;
- color: @white;
- &:hover {
- background: @h;
- }
- }
- }
- input[type="file"].ui.@{color}.file.input::file-selector-button,
- .ui.@{color}.file.input input[type="file"]::file-selector-button {
- background: @c;
- color: @white;
+ background: @fileButtonBackgroundHover;
+ color: @fileButtonTextColor;
+ }
+ }
+ & when (@supportIE) {
+ .ui.action.file.input input[type="file"]::-ms-browse {
+ display: none;
+ }
+ .ui.form .field input[type="file"]::-ms-browse,
+ .ui.file.input input[type="file"]::-ms-browse {
+ border: none;
+ cursor: pointer;
+ padding: @padding;
+ margin: 0;
+ background: @fileButtonBackground;
+ font-weight: @fileButtonFontWeight;
+ color: @fileButtonTextColor;
+ &:hover {
+ background: @fileButtonBackgroundHover;
+ color: @fileButtonTextColor;
+ }
+ }
+
+ /* IE needs additional styling for input field :S */
+ @media all and (-ms-high-contrast: none) {
+ .ui.file.input > input[type="file"],
+ input[type="file"].ui.file.input {
+ padding: 0 !important;
+ }
+ }
+ }
+
+ .ui.action.file.input input[type="file"]::file-selector-button {
+ display: none;
+ }
+ .ui.form .field input[type="file"]::file-selector-button,
+ .ui.file.input input[type="file"]::file-selector-button {
+ border: none;
+ cursor: pointer;
+ padding: @padding;
+ margin-right: @fileButtonMargin;
+ background: @fileButtonBackground;
+ font-weight: @fileButtonFontWeight;
+ color: @fileButtonTextColor;
&:hover {
- background: @h;
+ background: @fileButtonBackgroundHover;
+ color: @fileButtonTextColor;
+ }
+ }
+ & when (@variationInputInvalid) {
+ .ui.form .field input[type="file"]:required:invalid,
+ .ui.file.input input[type="file"]:required:invalid {
+ color: @negativeTextColor;
+ background: @negativeBackgroundColor;
+ border-color: @negativeBorderColor;
}
- }
- })
- }
+ }
+
+ input[type="file"].ui.invisible.file.input,
+ .ui.invisible.file.input input[type="file"] {
+ left: -99999px;
+ position: absolute;
+ }
+
+ input[type="file"].ui.file.input:focus + label.ui.button:not(.basic):not(.tertiary),
+ .ui.file.input input[type="file"]:focus + label.ui.button:not(.basic):not(.tertiary) {
+ background: @fileButtonBackgroundHover;
+ color: @hoveredTextColor;
+ &.inverted {
+ background: @fileButtonInvertedBackgroundHover;
+ }
+ }
+
+ /* this is related to existing buttons, so the button color variable is used here! */
+ & when not (@variationButtonColors = false) {
+ each(@variationButtonColors, {
+ @color: @value;
+ @h: @colors[@@color][hover];
+ @lh: @colors[@@color][lightHover];
+
+ input[type="file"].ui.file.input:focus + label.ui.@{color}.button:not(.basic):not(.tertiary),
+ .ui.file.input input[type="file"]:focus + label.ui.@{color}.button:not(.basic):not(.tertiary) {
+ background-color: @h;
+ color: @white;
+ &.inverted when (@variationButtonInverted) {
+ background-color: @lh;
+ }
+ }
+ });
+ }
+
+ & when not (@variationInputColors = false) {
+ each(@variationInputColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+ @h: @colors[@@color][hover];
+
+ input[type="file"].ui.@{color}.file.input::-webkit-file-upload-button,
+ .ui.@{color}.file.input input[type="file"]::-webkit-file-upload-button {
+ background: @c;
+ color: @white;
+ &:hover {
+ background: @h;
+ }
+ }
+ & when (@supportIE) {
+ input[type="file"].ui.@{color}.file.input::-ms-browse,
+ .ui.@{color}.file.input input[type="file"]::-ms-browse {
+ background: @c;
+ color: @white;
+ &:hover {
+ background: @h;
+ }
+ }
+ }
+ input[type="file"].ui.@{color}.file.input::file-selector-button,
+ .ui.@{color}.file.input input[type="file"]::file-selector-button {
+ background: @c;
+ color: @white;
+ &:hover {
+ background: @h;
+ }
+ }
+ });
+ }
}
-/*--------------------
+/* --------------------
Size
----------------------*/
+--------------------- */
.ui.input {
- font-size: @relativeMedium;
+ font-size: @relativeMedium;
}
& when not (@variationInputSizes = false) {
- each(@variationInputSizes, {
- @s: @{value}InputSize;
- .ui.@{value}.input {
- font-size: @@s;
- }
- })
+ each(@variationInputSizes, {
+ @s: @{value}InputSize;
+ .ui.@{value}.input {
+ font-size: @@s;
+ }
+ });
}
.loadUIOverrides();
diff --git a/definitions/elements/label.less b/definitions/elements/label.less
index d86fea6..338e60a 100644
--- a/definitions/elements/label.less
+++ b/definitions/elements/label.less
@@ -1,1036 +1,1014 @@
/*!
* # Fomantic-UI - Label
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-
/*******************************
Theme
*******************************/
-@type : 'element';
-@element : 'label';
+@type: "element";
+@element: "label";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Label
*******************************/
.ui.label {
- display: inline-block;
- line-height: 1;
- vertical-align: @verticalAlign;
-
- margin: @verticalMargin @horizontalMargin;
-
- background-color: @backgroundColor;
- background-image: @backgroundImage;
- padding: @verticalPadding @horizontalPadding;
- color: @color;
-
- text-transform: @textTransform;
- font-weight: @fontWeight;
-
- border: @border;
- border-radius: @borderRadius;
- transition: @transition;
+ display: inline-block;
+ line-height: 1;
+ vertical-align: @verticalAlign;
+ margin: @verticalMargin @horizontalMargin;
+ background-color: @backgroundColor;
+ background-image: @backgroundImage;
+ padding: @verticalPadding @horizontalPadding;
+ color: @color;
+ text-transform: @textTransform;
+ font-weight: @fontWeight;
+ border: @border;
+ border-radius: @borderRadius;
+ transition: @transition;
}
.ui.label:first-child {
- margin-left: 0;
+ margin-left: 0;
}
.ui.label:last-child {
- margin-right: 0;
+ margin-right: 0;
}
/* Link */
a.ui.label {
- cursor: pointer;
+ cursor: pointer;
}
/* Inside Link */
.ui.label > a {
- cursor: pointer;
- color: inherit;
- opacity: @linkOpacity;
- transition: @linkTransition;
+ cursor: pointer;
+ color: inherit;
+ opacity: @linkOpacity;
+ transition: @linkTransition;
}
.ui.label > a:hover {
- opacity: 1;
+ opacity: 1;
}
/* Image */
.ui.label > img {
- width: auto !important;
- vertical-align: middle;
- height: @imageHeight;
+ width: auto !important;
+ vertical-align: middle;
+ height: @imageHeight;
}
/* Icon */
.ui.ui[class*="left icon"].label > .icon,
.ui.label > .icon {
- width: auto;
- margin: 0 @iconDistance 0 0;
+ width: auto;
+ margin: 0 @iconDistance 0 0;
}
/* Detail */
.ui.label > .detail {
- display: inline-block;
- vertical-align: top;
- font-weight: @detailFontWeight;
- margin-left: @detailMargin;
- opacity: @detailOpacity;
+ display: inline-block;
+ vertical-align: top;
+ font-weight: @detailFontWeight;
+ margin-left: @detailMargin;
+ opacity: @detailOpacity;
}
.ui.label > .detail .icon {
- margin: 0 @detailIconDistance 0 0;
+ margin: 0 @detailIconDistance 0 0;
}
/* Removable label */
.ui.label > .close.icon,
.ui.label > .delete.icon {
- cursor: pointer;
- font-size: @deleteSize;
- opacity: @deleteOpacity;
- transition: @deleteTransition;
+ cursor: pointer;
+ font-size: @deleteSize;
+ opacity: @deleteOpacity;
+ transition: @deleteTransition;
}
.ui.label > .close.icon:hover,
.ui.label > .delete.icon:hover {
- opacity: 1;
+ opacity: 1;
}
/* Backward compatible positioning */
.ui.label[class*="left icon"] > .close.icon,
.ui.label[class*="left icon"] > .delete.icon {
- margin: 0 @deleteMargin 0 0;
- &.right {
- margin: 0 0 0 @deleteMargin;
- }
+ margin: 0 @deleteMargin 0 0;
+ &.right {
+ margin: 0 0 0 @deleteMargin;
+ }
}
.ui.label:not(.icon) > .close.icon,
.ui.label:not(.icon) > .delete.icon {
- margin: 0 0 0 @deleteMargin;
+ margin: 0 0 0 @deleteMargin;
}
/* Label for only an icon */
.ui.icon.label > .icon {
- margin: 0 auto;
+ margin: 0 auto;
}
/* Right Side Icon */
.ui[class*="right icon"].label > .icon {
- margin: 0 0 0 @iconDistance;
+ margin: 0 0 0 @iconDistance;
}
-/*-------------------
+/* -------------------
Group
---------------------*/
+-------------------- */
.ui.labels > .label {
- margin: 0 @groupHorizontalMargin @groupVerticalMargin 0;
+ margin: 0 @groupHorizontalMargin @groupVerticalMargin 0;
}
-
-/*-------------------
+/* -------------------
Coupling
---------------------*/
+-------------------- */
.ui.header > .ui.label {
- margin-top: @lineHeightOffset;
+ margin-top: @lineHeightOffset;
}
-
/* Remove border radius on attached segment */
.ui.attached.segment > .ui.top.left.attached.label,
-.ui.bottom.attached.segment > .ui.top.left.attached.label {
- border-top-left-radius: 0;
+.ui.bottom.attached.segment > .ui.top.left.attached.label {
+ border-top-left-radius: 0;
}
.ui.attached.segment > .ui.top.right.attached.label,
-.ui.bottom.attached.segment > .ui.top.right.attached.label {
- border-top-right-radius: 0;
+.ui.bottom.attached.segment > .ui.top.right.attached.label {
+ border-top-right-radius: 0;
}
-.ui.top.attached.segment > .ui.bottom.left.attached.label {
- border-bottom-left-radius: 0;
+.ui.top.attached.segment > .ui.bottom.left.attached.label {
+ border-bottom-left-radius: 0;
}
-.ui.top.attached.segment > .ui.bottom.right.attached.label {
- border-bottom-right-radius: 0;
+.ui.top.attached.segment > .ui.bottom.right.attached.label {
+ border-bottom-right-radius: 0;
}
/* Padding on next content after a label */
.ui.top.attached.label ~ .ui.bottom.attached.label + :not(.attached),
.ui.top.attached.label + :not(.attached) {
- margin-top: @attachedSegmentPadding !important;
+ margin-top: @attachedSegmentPadding !important;
}
.ui.bottom.attached.label ~ :last-child:not(.attached) {
- margin-top:0;
- margin-bottom: @attachedSegmentPadding !important;
+ margin-top: 0;
+ margin-bottom: @attachedSegmentPadding !important;
}
.ui.segment:not(.basic) > .ui.top.attached.label {
- margin-top: @attachedOffset;
+ margin-top: @attachedOffset;
}
.ui.segment:not(.basic) > .ui.bottom.attached.label {
- margin-bottom: @attachedOffset;
+ margin-bottom: @attachedOffset;
}
.ui.segment:not(.basic) > .ui.attached.label:not(.right) {
- margin-left: @attachedOffset;
+ margin-left: @attachedOffset;
}
.ui.segment:not(.basic) > .ui.right.attached.label {
- margin-right: @attachedOffset;
+ margin-right: @attachedOffset;
}
.ui.segment:not(.basic) > .ui.attached.label:not(.left):not(.right) {
- width: @attachedWidthOffset;
+ width: @attachedWidthOffset;
}
-
-
/*******************************
Types
*******************************/
& when (@variationLabelImage) {
- .ui.image.label {
- width: auto;
- margin-top: 0;
- margin-bottom: 0;
- max-width: 9999px;
- vertical-align: baseline;
- text-transform: none;
-
- background: @imageLabelBackground;
- padding: @imageLabelPadding;
- border-radius: @imageLabelBorderRadius;
- box-shadow: @imageLabelBoxShadow;
- &.attached:not(.basic) when (@variationLabelAttached) {
- padding: @imageLabelPadding;
+ .ui.image.label {
+ width: auto;
+ margin-top: 0;
+ margin-bottom: 0;
+ max-width: 9999px;
+ vertical-align: baseline;
+ text-transform: none;
+ background: @imageLabelBackground;
+ padding: @imageLabelPadding;
+ border-radius: @imageLabelBorderRadius;
+ box-shadow: @imageLabelBoxShadow;
+ &.attached:not(.basic) when (@variationLabelAttached) {
+ padding: @imageLabelPadding;
+ }
}
- }
- .ui.image.label img {
- display: inline-block;
- vertical-align: top;
-
- height: @imageLabelImageHeight;
- margin: @imageLabelImageMargin;
- border-radius: @imageLabelImageBorderRadius;
- }
+ .ui.image.label img {
+ display: inline-block;
+ vertical-align: top;
+ height: @imageLabelImageHeight;
+ margin: @imageLabelImageMargin;
+ border-radius: @imageLabelImageBorderRadius;
+ }
- .ui.image.label .detail {
- background: @imageLabelDetailBackground;
- margin: @imageLabelDetailMargin;
- padding: @imageLabelDetailPadding;
- border-radius: 0 @imageLabelBorderRadius @imageLabelBorderRadius 0;
- }
- & when (@variationLabelAttached) {
- .ui.bottom.attached.image.label:not(.right) > img,
- .ui.top.right.attached.image.label > img {
- border-top-left-radius: 0;
+ .ui.image.label .detail {
+ background: @imageLabelDetailBackground;
+ margin: @imageLabelDetailMargin;
+ padding: @imageLabelDetailPadding;
+ border-radius: 0 @imageLabelBorderRadius @imageLabelBorderRadius 0;
}
+ & when (@variationLabelAttached) {
+ .ui.bottom.attached.image.label:not(.right) > img,
+ .ui.top.right.attached.image.label > img {
+ border-top-left-radius: 0;
+ }
- .ui.top.attached.image.label:not(.right) > img,
- .ui.bottom.right.attached.image.label > img {
- border-bottom-left-radius: 0;
+ .ui.top.attached.image.label:not(.right) > img,
+ .ui.bottom.right.attached.image.label > img {
+ border-bottom-left-radius: 0;
+ }
}
- }
}
& when (@variationLabelTag) {
-/*-------------------
- Tag
---------------------*/
-
- .ui.tag.labels .label,
- .ui.tag.label {
- margin-left: 1em;
- position: relative;
- padding-left: @tagHorizontalPadding;
- padding-right: @tagHorizontalPadding;
-
- border-radius: 0 @borderRadius @borderRadius 0;
- transition: @tagTransition;
- }
- .ui.tag.labels .label::before,
- .ui.tag.label::before {
- position: absolute;
- transform: translateY(-50%) translateX(50%) rotate(-45deg);
-
- top: @tagTriangleTopOffset;
- right: @tagTriangleRightOffset;
- content: '';
-
- background-color: inherit;
- background-image: @tagTriangleBackgroundImage;
-
- width: @tagTriangleSize;
- height: @tagTriangleSize;
- transition: @tagTransition;
- }
-
-
- .ui.tag.labels .label::after,
- .ui.tag.label::after {
- position: absolute;
- content: '';
- top: 50%;
- left: -(@tagCircleSize / 2);
-
- margin-top: -(@tagCircleSize / 2);
- background-color: @tagCircleColor;
- width: @tagCircleSize;
- height: @tagCircleSize;
-
- box-shadow: @tagCircleBoxShadow;
- border-radius: @circularRadius;
- }
- & when (@variationLabelBasic) {
- .ui.basic.tag.labels .label::before,
- .ui.basic.tag.label::before {
- border-color: inherit;
- border-width: @basicBorderWidth 0 0 @basicBorderWidth;
- border-style: inherit;
- right: @basicBorderFullWidthOffset;
- }
- .ui.basic.tag.labels .label::after,
- .ui.basic.tag.label::after {
- box-shadow: @basicTagCircleBoxShadow;
- }
- }
+ /* -------------------
+ Tag
+ -------------------- */
+
+ .ui.tag.labels .label,
+ .ui.tag.label {
+ margin-left: 1em;
+ position: relative;
+ padding-left: @tagHorizontalPadding;
+ padding-right: @tagHorizontalPadding;
+ border-radius: 0 @borderRadius @borderRadius 0;
+ transition: @tagTransition;
+ }
+ .ui.tag.labels .label::before,
+ .ui.tag.label::before {
+ position: absolute;
+ transform: translateY(-50%) translateX(50%) rotate(-45deg);
+ top: @tagTriangleTopOffset;
+ right: @tagTriangleRightOffset;
+ content: "";
+ background-color: inherit;
+ background-image: @tagTriangleBackgroundImage;
+ width: @tagTriangleSize;
+ height: @tagTriangleSize;
+ transition: @tagTransition;
+ }
+
+ .ui.tag.labels .label::after,
+ .ui.tag.label::after {
+ position: absolute;
+ content: "";
+ top: 50%;
+ left: -(@tagCircleSize / 2);
+ margin-top: -(@tagCircleSize / 2);
+ background-color: @tagCircleColor;
+ width: @tagCircleSize;
+ height: @tagCircleSize;
+ box-shadow: @tagCircleBoxShadow;
+ border-radius: @circularRadius;
+ }
+ & when (@variationLabelBasic) {
+ .ui.basic.tag.labels .label::before,
+ .ui.basic.tag.label::before {
+ border-color: inherit;
+ border-width: @basicBorderWidth 0 0 @basicBorderWidth;
+ border-style: inherit;
+ right: @basicBorderFullWidthOffset;
+ }
+ .ui.basic.tag.labels .label::after,
+ .ui.basic.tag.label::after {
+ box-shadow: @basicTagCircleBoxShadow;
+ }
+ }
}
& when (@variationLabelCorner) {
-/*-------------------
- Corner Label
---------------------*/
-
- .ui.corner.label {
- position: absolute;
- top: 0;
- right: 0;
- margin: 0;
- padding: 0;
- text-align: center;
+ /* -------------------
+ Corner Label
+ -------------------- */
+
+ .ui.corner.label {
+ position: absolute;
+ top: 0;
+ right: 0;
+ margin: 0;
+ padding: 0;
+ text-align: center;
+ border-color: @backgroundColor;
+ width: @cornerTriangleSize;
+ height: @cornerTriangleSize;
+ z-index: @cornerTriangleZIndex;
+ transition: @cornerTriangleTransition;
+ }
+
+ /* Icon Label */
+ .ui.corner.label {
+ background-color: transparent !important;
+ }
+ .ui.corner.label::after {
+ position: absolute;
+ content: "";
+ right: 0;
+ top: 0;
+ z-index: -1;
+ width: 0;
+ height: 0;
+ background-color: transparent;
+ border-top: 0 solid transparent;
+ border-right: @cornerTriangleSize solid transparent;
+ border-bottom: @cornerTriangleSize solid transparent;
+ border-left: 0 solid transparent;
+ border-right-color: inherit;
+ transition: @cornerTriangleTransition;
+ }
+
+ .ui.corner.label .icon {
+ cursor: inherit;
+ position: absolute;
+ top: @cornerIconTopOffset;
+ left: auto;
+ right: @cornerIconRightOffset;
+ font-size: @cornerIconSize;
+ margin: 0;
+ }
+
+ /* Left Corner */
+ .ui.left.corner.label,
+ .ui.left.corner.label::after {
+ right: auto;
+ left: 0;
+ }
+ .ui.left.corner.label::after {
+ border-top: @cornerTriangleSize solid transparent;
+ border-right: @cornerTriangleSize solid transparent;
+ border-bottom: 0 solid transparent;
+ border-left: 0 solid transparent;
+ border-top-color: inherit;
+ }
+ .ui.left.corner.label .icon {
+ left: @cornerIconLeftOffset;
+ right: auto;
+ }
- border-color: @backgroundColor;
-
- width: @cornerTriangleSize;
- height: @cornerTriangleSize;
- z-index: @cornerTriangleZIndex;
- transition: @cornerTriangleTransition;
- }
-
- /* Icon Label */
- .ui.corner.label{
- background-color: transparent !important;
- }
- .ui.corner.label::after {
- position: absolute;
- content: "";
- right: 0;
- top: 0;
- z-index: -1;
-
- width: 0;
- height: 0;
- background-color: transparent;
-
- border-top: 0 solid transparent;
- border-right: @cornerTriangleSize solid transparent;
- border-bottom: @cornerTriangleSize solid transparent;
- border-left: 0 solid transparent;
-
- border-right-color: inherit;
- transition: @cornerTriangleTransition;
- }
-
- .ui.corner.label .icon {
- cursor: inherit;
- position: absolute;
- top: @cornerIconTopOffset;
- left: auto;
- right: @cornerIconRightOffset;
- font-size: @cornerIconSize;
- margin: 0;
- }
-
- /* Left Corner */
- .ui.left.corner.label,
- .ui.left.corner.label::after {
- right: auto;
- left: 0;
- }
- .ui.left.corner.label::after {
- border-top: @cornerTriangleSize solid transparent;
- border-right: @cornerTriangleSize solid transparent;
- border-bottom: 0 solid transparent;
- border-left: 0 solid transparent;
-
- border-top-color: inherit;
- }
- .ui.left.corner.label .icon {
- left: @cornerIconLeftOffset;
- right: auto;
- }
-
- /* Segment */
- .ui.segment > .ui.corner.label {
- top: -1px;
- right: -1px;
- }
- .ui.segment > .ui.left.corner.label {
- right: auto;
- left: -1px;
- }
+ /* Segment */
+ .ui.segment > .ui.corner.label {
+ top: -1px;
+ right: -1px;
+ }
+ .ui.segment > .ui.left.corner.label {
+ right: auto;
+ left: -1px;
+ }
}
& when (@variationLabelRibbon) {
- /*-------------------
- Ribbon
- --------------------*/
-
- .ui.ribbon.label {
- position: relative;
- margin: 0;
- min-width: max-content;
- border-radius: 0 @borderRadius @borderRadius 0;
- border-color: @ribbonShadowColor;
- }
-
- .ui.ribbon.label::after {
- position: absolute;
- content: '';
-
- top: 100%;
- left: 0;
- background-color: transparent;
-
- border-style: solid;
- border-width: 0 @ribbonTriangleSize @ribbonTriangleSize 0;
- border-color: transparent;
- border-right-color: inherit;
-
- width: 0;
- height: 0;
- }
- /* Positioning */
- .ui.ribbon.label {
- left: @ribbonOffset;
- margin-right: -@ribbonTriangleSize;
- padding-left: @ribbonDistance;
- padding-right: @ribbonTriangleSize;
- }
- .ui[class*="right ribbon"].label {
- left: @rightRibbonOffset;
- padding-left: @ribbonTriangleSize;
- padding-right: @ribbonDistance;
- }
- & when (@variationLabelBasic) {
- .ui.basic.ribbon.label {
- padding-top: @basicRibbonOffset;
- padding-bottom: @basicRibbonOffset;
- }
- .ui.basic.ribbon.label:not([class*="right ribbon"]) {
- padding-left: @basicRibbonTriangleSizeOffset;
- padding-right: @basicRibbonTriangleSize;
- }
- .ui.basic[class*="right ribbon"].label {
- padding-left: @basicRibbonTriangleSize;
- padding-right: @basicRibbonTriangleSizeOffset;
- }
- .ui.basic.ribbon.label::after {
- top: @basicBorderFullWidthOffset;
- }
- .ui.basic.ribbon.label:not([class*="right ribbon"])::after {
- left: @basicBorderWidthOffset;
- }
- .ui.basic[class*="right ribbon"].label::after {
- right: @basicBorderWidthOffset;
- }
- }
- /* Right Ribbon */
- .ui[class*="right ribbon"].label {
- text-align: left;
- transform: translateX(-100%);
- border-radius: @borderRadius 0 0 @borderRadius;
- }
- .ui[class*="right ribbon"].label::after {
- left: auto;
- right: 0;
-
- border-style: solid;
- border-width: @ribbonTriangleSize @ribbonTriangleSize 0 0;
- border-color: transparent;
- border-top-color: inherit;
- }
-
- /* Inside Table */
- .ui.image > .ribbon.label,
- .ui.card .image > .ribbon.label {
- position: absolute;
- top: @ribbonImageTopDistance;
- }
- .ui.card .image > .ui.ribbon.label,
- .ui.image > .ui.ribbon.label {
- left: @ribbonImageOffset;
- }
- .ui.card .image > .ui[class*="right ribbon"].label,
- .ui.image > .ui[class*="right ribbon"].label {
- left: @rightRibbonImageOffset;
- padding-left: @horizontalPadding;
- }
-
- /* Inside Table */
- .ui.table td > .ui.ribbon.label {
- left: @ribbonTableOffset;
- }
- .ui.table td > .ui[class*="right ribbon"].label {
- left: @rightRibbonTableOffset;
- padding-left: @horizontalPadding;
- }
+ /* -------------------
+ Ribbon
+ -------------------- */
+
+ .ui.ribbon.label {
+ position: relative;
+ margin: 0;
+ min-width: max-content;
+ border-radius: 0 @borderRadius @borderRadius 0;
+ border-color: @ribbonShadowColor;
+ }
+
+ .ui.ribbon.label::after {
+ position: absolute;
+ content: "";
+ top: 100%;
+ left: 0;
+ background-color: transparent;
+ border-style: solid;
+ border-width: 0 @ribbonTriangleSize @ribbonTriangleSize 0;
+ border-color: transparent;
+ border-right-color: inherit;
+ width: 0;
+ height: 0;
+ }
+
+ /* Positioning */
+ .ui.ribbon.label {
+ left: @ribbonOffset;
+ margin-right: -@ribbonTriangleSize;
+ padding-left: @ribbonDistance;
+ padding-right: @ribbonTriangleSize;
+ }
+ .ui[class*="right ribbon"].label {
+ left: @rightRibbonOffset;
+ padding-left: @ribbonTriangleSize;
+ padding-right: @ribbonDistance;
+ }
+ & when (@variationLabelBasic) {
+ .ui.basic.ribbon.label {
+ padding-top: @basicRibbonOffset;
+ padding-bottom: @basicRibbonOffset;
+ }
+ .ui.basic.ribbon.label:not([class*="right ribbon"]) {
+ padding-left: @basicRibbonTriangleSizeOffset;
+ padding-right: @basicRibbonTriangleSize;
+ }
+ .ui.basic[class*="right ribbon"].label {
+ padding-left: @basicRibbonTriangleSize;
+ padding-right: @basicRibbonTriangleSizeOffset;
+ }
+ .ui.basic.ribbon.label::after {
+ top: @basicBorderFullWidthOffset;
+ }
+ .ui.basic.ribbon.label:not([class*="right ribbon"])::after {
+ left: @basicBorderWidthOffset;
+ }
+ .ui.basic[class*="right ribbon"].label::after {
+ right: @basicBorderWidthOffset;
+ }
+ }
+
+ /* Right Ribbon */
+ .ui[class*="right ribbon"].label {
+ text-align: left;
+ transform: translateX(-100%);
+ border-radius: @borderRadius 0 0 @borderRadius;
+ }
+ .ui[class*="right ribbon"].label::after {
+ left: auto;
+ right: 0;
+ border-style: solid;
+ border-width: @ribbonTriangleSize @ribbonTriangleSize 0 0;
+ border-color: transparent;
+ border-top-color: inherit;
+ }
+
+ /* Inside Table */
+ .ui.image > .ribbon.label,
+ .ui.card .image > .ribbon.label {
+ position: absolute;
+ top: @ribbonImageTopDistance;
+ }
+ .ui.card .image > .ui.ribbon.label,
+ .ui.image > .ui.ribbon.label {
+ left: @ribbonImageOffset;
+ }
+ .ui.card .image > .ui[class*="right ribbon"].label,
+ .ui.image > .ui[class*="right ribbon"].label {
+ left: @rightRibbonImageOffset;
+ padding-left: @horizontalPadding;
+ }
+
+ /* Inside Table */
+ .ui.table td > .ui.ribbon.label {
+ left: @ribbonTableOffset;
+ }
+ .ui.table td > .ui[class*="right ribbon"].label {
+ left: @rightRibbonTableOffset;
+ padding-left: @horizontalPadding;
+ }
}
& when (@variationLabelAttached) {
- /*-------------------
- Attached
- --------------------*/
-
- .ui[class*="top attached"].label,
- .ui.attached.label {
- width: 100%;
- position: absolute;
- margin: 0;
- top: 0;
- left: 0;
-
- padding: @attachedVerticalPadding @attachedHorizontalPadding;
-
- border-radius: @attachedCornerBorderRadius @attachedCornerBorderRadius 0 0;
- }
- .ui[class*="bottom attached"].label {
- top: auto;
- bottom: 0;
- border-radius: 0 0 @attachedCornerBorderRadius @attachedCornerBorderRadius;
- }
-
- .ui[class*="top left attached"].label {
- width: auto;
- margin-top: 0;
- border-radius: @attachedCornerBorderRadius 0 @attachedBorderRadius 0;
- }
+ /* -------------------
+ Attached
+ -------------------- */
+
+ .ui[class*="top attached"].label,
+ .ui.attached.label {
+ width: 100%;
+ position: absolute;
+ margin: 0;
+ top: 0;
+ left: 0;
+ padding: @attachedVerticalPadding @attachedHorizontalPadding;
+ border-radius: @attachedCornerBorderRadius @attachedCornerBorderRadius 0 0;
+ }
+ .ui[class*="bottom attached"].label {
+ top: auto;
+ bottom: 0;
+ border-radius: 0 0 @attachedCornerBorderRadius @attachedCornerBorderRadius;
+ }
- .ui[class*="top right attached"].label {
- width: auto;
- left: auto;
- right: 0;
- border-radius: 0 @attachedCornerBorderRadius 0 @attachedBorderRadius;
- }
- .ui[class*="bottom left attached"].label {
- width: auto;
- top: auto;
- bottom: 0;
- border-radius: 0 @attachedBorderRadius 0 @attachedCornerBorderRadius;
- }
- .ui[class*="bottom right attached"].label {
- top: auto;
- bottom: 0;
- left: auto;
- right: 0;
- width: auto;
- border-radius: @attachedBorderRadius 0 @attachedCornerBorderRadius 0;
- }
+ .ui[class*="top left attached"].label {
+ width: auto;
+ margin-top: 0;
+ border-radius: @attachedCornerBorderRadius 0 @attachedBorderRadius 0;
+ }
+
+ .ui[class*="top right attached"].label {
+ width: auto;
+ left: auto;
+ right: 0;
+ border-radius: 0 @attachedCornerBorderRadius 0 @attachedBorderRadius;
+ }
+ .ui[class*="bottom left attached"].label {
+ width: auto;
+ top: auto;
+ bottom: 0;
+ border-radius: 0 @attachedBorderRadius 0 @attachedCornerBorderRadius;
+ }
+ .ui[class*="bottom right attached"].label {
+ top: auto;
+ bottom: 0;
+ left: auto;
+ right: 0;
+ width: auto;
+ border-radius: @attachedBorderRadius 0 @attachedCornerBorderRadius 0;
+ }
}
/*******************************
States
*******************************/
-/*-------------------
+/* -------------------
Disabled
---------------------*/
+-------------------- */
& when (@variationLabelDisabled) {
- .ui.label.disabled {
- opacity: 0.5;
- }
+ .ui.disabled.labels .label,
+ .ui.label.disabled {
+ opacity: @disabledOpacity;
+ pointer-events: @disabledPointerEvents;
+ }
}
-/*-------------------
+
+/* -------------------
Hover
---------------------*/
+-------------------- */
.ui.labels a.label:hover,
a.ui.label:hover {
- background-color: @labelHoverBackgroundColor;
- border-color: @labelHoverBackgroundColor;
-
- background-image: @labelHoverBackgroundImage;
- color: @labelHoverTextColor;
+ background-color: @labelHoverBackgroundColor;
+ border-color: @labelHoverBackgroundColor;
+ background-image: @labelHoverBackgroundImage;
+ color: @labelHoverTextColor;
}
.ui.labels a.label:hover::before,
a.ui.label:hover::before {
- color: @labelHoverTextColor;
+ color: @labelHoverTextColor;
}
-/*-------------------
+/* -------------------
Active
---------------------*/
+-------------------- */
.ui.active.label {
- background-color: @labelActiveBackgroundColor;
- border-color: @labelActiveBackgroundColor;
-
- background-image: @labelActiveBackgroundImage;
- color: @labelActiveTextColor;
+ background-color: @labelActiveBackgroundColor;
+ border-color: @labelActiveBackgroundColor;
+ background-image: @labelActiveBackgroundImage;
+ color: @labelActiveTextColor;
}
.ui.active.label::before {
- background-color: @labelActiveBackgroundColor;
- background-image: @labelActiveBackgroundImage;
- color: @labelActiveTextColor;
+ background-color: @labelActiveBackgroundColor;
+ background-image: @labelActiveBackgroundImage;
+ color: @labelActiveTextColor;
}
-/*-------------------
+/* -------------------
Active Hover
---------------------*/
+-------------------- */
.ui.labels a.active.label:hover,
a.ui.active.label:hover {
- background-color: @labelActiveHoverBackgroundColor;
- border-color: @labelActiveHoverBackgroundColor;
-
- background-image: @labelActiveHoverBackgroundImage;
- color: @labelActiveHoverTextColor;
+ background-color: @labelActiveHoverBackgroundColor;
+ border-color: @labelActiveHoverBackgroundColor;
+ background-image: @labelActiveHoverBackgroundImage;
+ color: @labelActiveHoverTextColor;
}
.ui.labels a.active.label:hover::before,
a.ui.active.label:hover::before {
- background-color: @labelActiveHoverBackgroundColor;
- background-image: @labelActiveHoverBackgroundImage;
- color: @labelActiveHoverTextColor;
+ background-color: @labelActiveHoverBackgroundColor;
+ background-image: @labelActiveHoverBackgroundImage;
+ color: @labelActiveHoverTextColor;
}
-
-/*-------------------
+/* -------------------
Visible
---------------------*/
+-------------------- */
.ui.labels.visible .label,
.ui.label.visible:not(.dropdown) {
- display: inline-block !important;
+ display: inline-block !important;
}
-/*-------------------
+/* -------------------
Hidden
---------------------*/
+-------------------- */
.ui.labels.hidden .label,
.ui.label.hidden {
- display: none !important;
+ display: none !important;
}
-
/*******************************
Variations
*******************************/
-
& when (@variationLabelBasic) {
- /*-------------------
- Basic
- --------------------*/
-
- .ui.basic.labels .label,
- .ui.basic.label {
- background: @basicBackground;
- border: @basicBorder;
- color: @basicColor;
- box-shadow: @basicBoxShadow;
- padding-top: @basicVerticalPadding;
- padding-bottom: @basicVerticalPadding;
- padding-right: @basicHorizontalPadding;
- }
- .ui.basic.labels:not(.tag):not(.image):not(.ribbon) .label,
- .ui.basic.label:not(.tag):not(.image):not(.ribbon) {
- padding-left: @basicHorizontalPadding;
- }
- & when (@variationLabelImage) {
- .ui.basic.image.label {
- padding-left: @basicImageLabelPadding;
- }
- }
-
- /* Link */
- .ui.basic.labels a.label:hover,
- a.ui.basic.label:hover {
- text-decoration: none;
- background: @basicHoverBackground;
- color: @basicHoverColor;
- box-shadow: @basicHoverBoxShadow;
- }
- & when (@variationLabelPointing) {
- /* Pointing */
- .ui.basic.pointing.label::before {
- border-color: inherit;
- }
- }
+ /* -------------------
+ Basic
+ -------------------- */
+
+ .ui.basic.labels .label,
+ .ui.basic.label {
+ background: @basicBackground;
+ border: @basicBorder;
+ color: @basicColor;
+ box-shadow: @basicBoxShadow;
+ padding-top: @basicVerticalPadding;
+ padding-bottom: @basicVerticalPadding;
+ padding-right: @basicHorizontalPadding;
+ }
+ .ui.basic.labels:not(.tag):not(.image):not(.ribbon) .label,
+ .ui.basic.label:not(.tag):not(.image):not(.ribbon) {
+ padding-left: @basicHorizontalPadding;
+ }
+ & when (@variationLabelImage) {
+ .ui.basic.image.label {
+ padding-left: @basicImageLabelPadding;
+ }
+ }
+
+ /* Link */
+ .ui.basic.labels a.label:hover,
+ a.ui.basic.label:hover {
+ text-decoration: none;
+ background: @basicHoverBackground;
+ color: @basicHoverColor;
+ box-shadow: @basicHoverBoxShadow;
+ }
+ & when (@variationLabelPointing) {
+ /* Pointing */
+ .ui.basic.pointing.label::before {
+ border-color: inherit;
+ }
+ }
}
& when (@variationLabelFluid) {
- /*-------------------
- Fluid
- --------------------*/
-
- .ui.label.fluid,
- .ui.fluid.labels > .label {
- width: 100%;
- box-sizing: border-box;
- }
+ /* -------------------
+ Fluid
+ -------------------- */
+
+ .ui.label.fluid,
+ .ui.fluid.labels > .label {
+ width: 100%;
+ box-sizing: border-box;
+ }
+}
+
+& when (@variationLabelCentered) {
+ .ui.centered.labels .label,
+ .ui.centered.label {
+ text-align: center;
+ }
}
& when (@variationLabelInverted) {
- /*-------------------
- Inverted
- --------------------*/
-
- .ui.inverted.labels .label,
- .ui.inverted.label {
- color: @invertedTextColor;
- background-color: @invertedBackgroundColor;
- }
- .ui.inverted.corner.label {
- border-color: @invertedBackgroundColor;
- }
- .ui.inverted.corner.label:hover {
- border-color: @backgroundColor;
- transition: none;
- }
- .ui.inverted.basic.labels .label,
- .ui.inverted.basic.label,
- .ui.inverted.basic.label:hover {
- border-color: @basicInvertedBorderColor;
- background: @black;
- }
- .ui.inverted.basic.label:hover {
- color: @linkColor;
- }
+ /* -------------------
+ Inverted
+ -------------------- */
+
+ .ui.inverted.labels .label,
+ .ui.inverted.label {
+ color: @invertedTextColor;
+ background-color: @invertedBackgroundColor;
+ }
+ .ui.inverted.corner.label {
+ border-color: @invertedBackgroundColor;
+ }
+ .ui.inverted.corner.label:hover {
+ border-color: @backgroundColor;
+ transition: none;
+ }
+ .ui.inverted.basic.labels .label,
+ .ui.inverted.basic.label,
+ .ui.inverted.basic.label:hover {
+ border-color: @basicInvertedBorderColor;
+ background: @black;
+ }
+ .ui.inverted.basic.label:hover {
+ color: @linkColor;
+ }
}
-/*-------------------
+/* -------------------
Colors
---------------------*/
+-------------------- */
& when not (@variationLabelColors = false) {
- each(@variationLabelColors, {
- @color: @value;
- @isDark: @colors[@@color][isDark];
- @_labelColor: @colors[@@color][color];
- @_labelInvertedColor: @colors[@@color][light];
- @_labelTextColor: @colors[@@color][text];
- @_labelHover: @colors[@@color][hover];
- @_labelInvertedHover: @colors[@@color][lightHover];
- @_labelHoverTextColor: @colors[@@color][hoverText];
- @_labelRibbonShadow: @colors[@@color][ribbon];
- @_labelInvertedRibbonShadow: @colors[@@color][invertedRibbon];
-
- .ui.@{color}.labels .label,
- .ui.ui.ui.@{color}.label {
- background-color: @_labelColor;
- border-color: @_labelColor;
- color: @_labelTextColor;
- }
- /* Link */
- .ui.@{color}.labels a.label:hover,
- a.ui.ui.ui.@{color}.label:hover {
- background-color: @_labelHover;
- border-color: @_labelHover;
- color: @_labelHoverTextColor;
- }
- & when (@variationLabelRibbon) {
- /* Ribbon */
- .ui.ui.ui.@{color}.ribbon.label {
- border-color: @_labelRibbonShadow;
- }
- }
- & when (@variationLabelBasic) {
- /* Basic */
- .ui.basic.labels .@{color}.label,
- .ui.ui.ui.basic.@{color}.label {
- background: @basicBackground;
- border-color: @_labelColor;
- color: @_labelColor;
- }
- .ui.basic.labels a.@{color}.label:hover,
- a.ui.ui.ui.basic.@{color}.label:hover {
- background: @basicBackground;
- border-color: @_labelHover;
- color: @_labelHover;
- }
- }
- & when (@variationLabelInverted) {
- /* Inverted */
- .ui.inverted.labels .@{color}.label,
- .ui.ui.ui.inverted.@{color}.label {
- background-color: @_labelInvertedColor;
- border-color: @_labelInvertedColor;
- color: @black;
- }
- /* Inverted Link */
- .ui.inverted.labels a.@{color}.label:hover,
- a.ui.ui.ui.inverted.@{color}.label:hover {
- background-color: @_labelInvertedHover;
- border-color: @_labelInvertedHover;
- & when not (@isDark) {
- color: @black;
- }
- & when (@isDark) {
- color: @_labelTextColor;
+ each(@variationLabelColors, {
+ @color: @value;
+ @isDark: @colors[@@color][isDark];
+ @_labelColor: @colors[@@color][color];
+ @_labelInvertedColor: @colors[@@color][light];
+ @_labelTextColor: @colors[@@color][text];
+ @_labelHover: @colors[@@color][hover];
+ @_labelInvertedHover: @colors[@@color][lightHover];
+ @_labelHoverTextColor: @colors[@@color][hoverText];
+ @_labelRibbonShadow: @colors[@@color][ribbon];
+ @_labelInvertedRibbonShadow: @colors[@@color][invertedRibbon];
+
+ .ui.@{color}.labels .label,
+ .ui.ui.ui.@{color}.label {
+ background-color: @_labelColor;
+ border-color: @_labelColor;
+ color: @_labelTextColor;
}
- }
- & when (@variationLabelRibbon) {
- /* Inverted Ribbon */
- .ui.ui.ui.inverted.@{color}.ribbon.label {
- border-color: @_labelInvertedRibbonShadow;
+ /* Link */
+ .ui.@{color}.labels a.label:hover,
+ a.ui.ui.ui.@{color}.label:hover {
+ background-color: @_labelHover;
+ border-color: @_labelHover;
+ color: @_labelHoverTextColor;
}
- }
- & when (@variationLabelBasic) {
- /* Inverted Basic */
- .ui.inverted.basic.labels .@{color}.label,
- .ui.ui.ui.inverted.basic.@{color}.label {
- background-color: @invertedBackground;
- border-color: @_labelInvertedColor;
- & when not (@isDark) {
- color: @_labelInvertedColor;
- }
- & when (@isDark) {
- color: @invertedTextColor;
- }
+ & when (@variationLabelRibbon) {
+ /* Ribbon */
+ .ui.ui.ui.@{color}.ribbon.label {
+ border-color: @_labelRibbonShadow;
+ }
}
- .ui.inverted.basic.labels a.@{color}.label:hover,
- a.ui.ui.ui.inverted.basic.@{color}.label:hover {
- border-color: @_labelInvertedHover;
- background-color: @invertedBackground;
- & when not (@isDark) {
- color: @_labelInvertedHover;
- }
+ & when (@variationLabelBasic) {
+ /* Basic */
+ .ui.basic.labels .@{color}.label,
+ .ui.ui.ui.basic.@{color}.label {
+ background: @basicBackground;
+ border-color: @_labelColor;
+ color: @_labelColor;
+ }
+ .ui.basic.labels a.@{color}.label:hover,
+ a.ui.ui.ui.basic.@{color}.label:hover {
+ background: @basicBackground;
+ border-color: @_labelHover;
+ color: @_labelHover;
+ }
}
- & when (@variationLabelTag) {
- /* Inverted Basic Tags */
- .ui.inverted.basic.tag.labels .@{color}.label,
- .ui.ui.ui.inverted.@{color}.basic.tag.label {
- border: @invertedBorderSize solid @_labelInvertedColor;
- }
- .ui.inverted.basic.tag.labels .@{color}.label::before,
- .ui.ui.ui.inverted.@{color}.basic.tag.label::before {
- border-color: inherit;
- border-width: @invertedBorderSize 0 0 @invertedBorderSize;
- border-style: inherit;
- background-color: @invertedBackground;
- right: e(%("calc(100%% + %d)", @invertedBorderSize));
- }
+ & when (@variationLabelInverted) {
+ /* Inverted */
+ .ui.inverted.labels .@{color}.label,
+ .ui.ui.ui.inverted.@{color}.label {
+ background-color: @_labelInvertedColor;
+ border-color: @_labelInvertedColor;
+ color: @black;
+ }
+ /* Inverted Link */
+ .ui.inverted.labels a.@{color}.label:hover,
+ a.ui.ui.ui.inverted.@{color}.label:hover {
+ background-color: @_labelInvertedHover;
+ border-color: @_labelInvertedHover;
+ & when not (@isDark) {
+ color: @black;
+ }
+ & when (@isDark) {
+ color: @_labelTextColor;
+ }
+ }
+ & when (@variationLabelRibbon) {
+ /* Inverted Ribbon */
+ .ui.ui.ui.inverted.@{color}.ribbon.label {
+ border-color: @_labelInvertedRibbonShadow;
+ }
+ }
+ & when (@variationLabelBasic) {
+ /* Inverted Basic */
+ .ui.inverted.basic.labels .@{color}.label,
+ .ui.ui.ui.inverted.basic.@{color}.label {
+ background-color: @invertedBackground;
+ border-color: @_labelInvertedColor;
+ & when not (@isDark) {
+ color: @_labelInvertedColor;
+ }
+ & when (@isDark) {
+ color: @invertedTextColor;
+ }
+ }
+ .ui.inverted.basic.labels a.@{color}.label:hover,
+ a.ui.ui.ui.inverted.basic.@{color}.label:hover {
+ border-color: @_labelInvertedHover;
+ background-color: @invertedBackground;
+ & when not (@isDark) {
+ color: @_labelInvertedHover;
+ }
+ }
+ & when (@variationLabelTag) {
+ /* Inverted Basic Tags */
+ .ui.inverted.basic.tag.labels .@{color}.label,
+ .ui.ui.ui.inverted.@{color}.basic.tag.label {
+ border: @invertedBorderSize solid @_labelInvertedColor;
+ }
+ .ui.inverted.basic.tag.labels .@{color}.label::before,
+ .ui.ui.ui.inverted.@{color}.basic.tag.label::before {
+ border-color: inherit;
+ border-width: @invertedBorderSize 0 0 @invertedBorderSize;
+ border-style: inherit;
+ background-color: @invertedBackground;
+ right: e(%("calc(100%% + %d)", @invertedBorderSize));
+ }
+ }
+ }
}
- }
- }
- })
+ });
}
-/*-------------------
+/* -------------------
Horizontal
---------------------*/
+-------------------- */
.ui.horizontal.labels .label,
.ui.horizontal.label {
- margin: 0 @horizontalLabelMargin 0 0;
-
- padding: @horizontalLabelVerticalPadding @horizontalPadding;
- min-width: @horizontalLabelMinWidth;
- text-align: center;
+ margin: 0 @horizontalLabelMargin 0 0;
+ padding: @horizontalLabelVerticalPadding @horizontalPadding;
+ min-width: @horizontalLabelMinWidth;
+ text-align: center;
}
& when (@variationLabelCircular) {
- /*-------------------
- Circular
- --------------------*/
+ /* -------------------
+ Circular
+ -------------------- */
+
+ .ui.circular.labels .label,
+ .ui.circular.label {
+ min-width: @circularMinSize;
+ min-height: @circularMinSize;
+ padding: @circularPadding !important;
+ line-height: 1em;
+ text-align: center;
+ border-radius: @circularRadius;
+ }
+ .ui.empty.circular.labels .label,
+ .ui.empty.circular.label {
+ min-width: 0;
+ min-height: 0;
+ overflow: hidden;
+ width: @emptyCircleSize;
+ height: @emptyCircleSize;
+ vertical-align: baseline;
+ }
+}
- .ui.circular.labels .label,
- .ui.circular.label {
- min-width: @circularMinSize;
- min-height: @circularMinSize;
+& when (@variationLabelPointing) {
+ /* -------------------
+ Pointing
+ -------------------- */
- padding: @circularPadding !important;
+ .ui.pointing.label {
+ position: relative;
+ }
- line-height: 1em;
- text-align: center;
- border-radius: @circularRadius;
- }
- .ui.empty.circular.labels .label,
- .ui.empty.circular.label {
- min-width: 0;
- min-height: 0;
- overflow: hidden;
- width: @emptyCircleSize;
- height: @emptyCircleSize;
- vertical-align: baseline;
- }
-}
+ .ui.attached.pointing.label {
+ position: absolute;
+ }
-& when (@variationLabelPointing) {
- /*-------------------
- Pointing
- --------------------*/
-
- .ui.pointing.label {
- position: relative;
- }
-
- .ui.attached.pointing.label {
- position: absolute;
- }
-
- .ui.pointing.label::before {
- background-color: inherit;
- background-image: inherit;
- border-width: 0;
- border-style: solid;
- border-color: @pointingBorderColor;
- }
- /* Arrow */
- .ui.pointing.label::before {
- position: absolute;
- content: '';
- transform: rotate(45deg);
- background-image: none;
-
- z-index: @pointingTriangleZIndex;
- width: @pointingTriangleSize;
- height: @pointingTriangleSize;
- transition: @pointingTriangleTransition;
- }
-
- /*--- Above ---*/
- .ui.pointing.label,
- .ui[class*="pointing above"].label {
- margin-top: @pointingVerticalDistance;
- }
- .ui.pointing.label::before,
- .ui[class*="pointing above"].label::before {
- border-width: @borderWidth 0 0 @borderWidth;
- transform: translateX(-50%) translateY(-50%) rotate(45deg);
- top: 0;
- left: 50%;
- }
- /*--- Below ---*/
- .ui[class*="bottom pointing"].label,
- .ui[class*="pointing below"].label {
- margin-top: 0;
- margin-bottom: @pointingVerticalDistance;
- }
- .ui[class*="bottom pointing"].label::before,
- .ui[class*="pointing below"].label::before {
- border-width: 0 @borderWidth @borderWidth 0;
- top: auto;
- right: auto;
- transform: translateX(-50%) translateY(-50%) rotate(45deg);
- top: 100%;
- left: 50%;
- }
- /*--- Left ---*/
- .ui[class*="left pointing"].label {
- margin-top: 0;
- margin-left: @pointingHorizontalDistance;
- }
- .ui[class*="left pointing"].label::before {
- border-width: 0 0 @borderWidth @borderWidth;
- transform: translateX(-50%) translateY(-50%) rotate(45deg);
- bottom: auto;
- right: auto;
- top: 50%;
- left: 0;
- }
- /*--- Right ---*/
- .ui[class*="right pointing"].label {
- margin-top: 0;
- margin-right: @pointingHorizontalDistance;
- }
- .ui[class*="right pointing"].label::before {
- border-width: @borderWidth @borderWidth 0 0;
- transform: translateX(50%) translateY(-50%) rotate(45deg);
- top: 50%;
- right: 0;
- bottom: auto;
- left: auto;
- }
- & when (@variationLabelBasic) {
- /* Basic Pointing */
-
- /*--- Above ---*/
- .ui.basic.pointing.label::before,
- .ui.basic[class*="pointing above"].label::before {
- margin-top: @basicPointingTriangleOffset;
- }
- /*--- Below ---*/
- .ui.basic[class*="bottom pointing"].label::before,
- .ui.basic[class*="pointing below"].label::before {
- bottom: auto;
- top: 100%;
- margin-top: -@basicPointingTriangleOffset;
- }
- /*--- Left ---*/
- .ui.basic[class*="left pointing"].label::before {
- top: 50%;
- left: @basicPointingTriangleOffset;
- }
- /*--- Right ---*/
- .ui.basic[class*="right pointing"].label::before {
- top: 50%;
- right: @basicPointingTriangleOffset;
- }
- }
+ .ui.pointing.label::before {
+ background-color: inherit;
+ background-image: inherit;
+ border-width: 0;
+ border-style: solid;
+ border-color: @pointingBorderColor;
+ }
+
+ /* Arrow */
+ .ui.pointing.label::before {
+ position: absolute;
+ content: "";
+ transform: rotate(45deg);
+ background-image: none;
+ z-index: @pointingTriangleZIndex;
+ width: @pointingTriangleSize;
+ height: @pointingTriangleSize;
+ transition: @pointingTriangleTransition;
+ }
+
+ /* --- Above --- */
+ .ui.pointing.label,
+ .ui[class*="pointing above"].label {
+ margin-top: @pointingVerticalDistance;
+ }
+ .ui.pointing.label::before,
+ .ui[class*="pointing above"].label::before {
+ border-width: @borderWidth 0 0 @borderWidth;
+ transform: translateX(-50%) translateY(-50%) rotate(45deg);
+ top: 0;
+ left: 50%;
+ }
+
+ /* --- Below --- */
+ .ui[class*="bottom pointing"].label,
+ .ui[class*="pointing below"].label {
+ margin-top: 0;
+ margin-bottom: @pointingVerticalDistance;
+ }
+ .ui[class*="bottom pointing"].label::before,
+ .ui[class*="pointing below"].label::before {
+ border-width: 0 @borderWidth @borderWidth 0;
+ right: auto;
+ transform: translateX(-50%) translateY(-50%) rotate(45deg);
+ top: 100%;
+ left: 50%;
+ }
+
+ /* --- Left --- */
+ .ui[class*="left pointing"].label {
+ margin-top: 0;
+ margin-left: @pointingHorizontalDistance;
+ }
+ .ui[class*="left pointing"].label::before {
+ border-width: 0 0 @borderWidth @borderWidth;
+ transform: translateX(-50%) translateY(-50%) rotate(45deg);
+ bottom: auto;
+ right: auto;
+ top: 50%;
+ left: 0;
+ }
+
+ /* --- Right --- */
+ .ui[class*="right pointing"].label {
+ margin-top: 0;
+ margin-right: @pointingHorizontalDistance;
+ }
+ .ui[class*="right pointing"].label::before {
+ border-width: @borderWidth @borderWidth 0 0;
+ transform: translateX(50%) translateY(-50%) rotate(45deg);
+ top: 50%;
+ right: 0;
+ bottom: auto;
+ left: auto;
+ }
+ & when (@variationLabelBasic) {
+ /* Basic Pointing */
+
+ /* --- Above --- */
+ .ui.basic.pointing.label::before,
+ .ui.basic[class*="pointing above"].label::before {
+ margin-top: @basicPointingTriangleOffset;
+ }
+
+ /* --- Below --- */
+ .ui.basic[class*="bottom pointing"].label::before,
+ .ui.basic[class*="pointing below"].label::before {
+ bottom: auto;
+ top: 100%;
+ margin-top: -@basicPointingTriangleOffset;
+ }
+
+ /* --- Left --- */
+ .ui.basic[class*="left pointing"].label::before {
+ top: 50%;
+ left: @basicPointingTriangleOffset;
+ }
+
+ /* --- Right --- */
+ .ui.basic[class*="right pointing"].label::before {
+ top: 50%;
+ right: @basicPointingTriangleOffset;
+ }
+ }
}
& when (@variationLabelFloating) {
- /*------------------
- Floating Label
- -------------------*/
-
- .ui.floating.label {
- position: absolute;
- z-index: @floatingZIndex;
- top: @floatingTopOffset;
- right: 0;
- white-space: nowrap;
- transform: translateX(50%);
- }
- .ui.right.aligned.floating.label {
- transform: translateX(@floatingAlignOffset);
- }
- .ui.left.floating.label {
- left:0;
- right:auto;
- transform: translateX(-50%);
- }
- .ui.left.aligned.floating.label {
- transform: translateX(-@floatingAlignOffset);
- }
- .ui.bottom.floating.label {
- top: auto;
- bottom: @floatingBottomOffset;
- }
+ /* ------------------
+ Floating Label
+ ------------------- */
+
+ .ui.floating.label {
+ position: absolute;
+ z-index: @floatingZIndex;
+ top: @floatingTopOffset;
+ right: 0;
+ white-space: nowrap;
+ transform: translateX(50%);
+ }
+ .ui.right.aligned.floating.label {
+ transform: translateX(@floatingAlignOffset);
+ }
+ .ui.left.floating.label {
+ left: 0;
+ right: auto;
+ transform: translateX(-50%);
+ }
+ .ui.left.aligned.floating.label {
+ transform: translateX(-@floatingAlignOffset);
+ }
+ .ui.bottom.floating.label {
+ top: auto;
+ bottom: @floatingBottomOffset;
+ }
}
-/*-------------------
+/* -------------------
Sizes
---------------------*/
+-------------------- */
.ui.labels .label,
.ui.label {
- font-size: @medium;
+ font-size: @medium;
}
& when not (@variationLabelSizes = false) {
- each(@variationLabelSizes, {
- @s: @@value;
- .ui.@{value}.labels .label,
- .ui.@{value}.label {
- font-size: @s;
- }
- })
+ each(@variationLabelSizes, {
+ @s: @@value;
+ .ui.@{value}.labels .label,
+ .ui.@{value}.label {
+ font-size: @s;
+ }
+ });
}
.loadUIOverrides();
diff --git a/definitions/elements/list.less b/definitions/elements/list.less
index 0450786..f52f829 100644
--- a/definitions/elements/list.less
+++ b/definitions/elements/list.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - List
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,10 +12,10 @@
Theme
*******************************/
-@type : 'element';
-@element : 'list';
+@type: "element";
+@element: "list";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
List
@@ -24,23 +24,23 @@
ul.ui.list,
ol.ui.list,
.ui.list {
- list-style-type: @listStyleType;
- margin: @margin;
- padding: @verticalPadding @horizontalPadding;
+ list-style-type: @listStyleType;
+ margin: @margin;
+ padding: @verticalPadding @horizontalPadding;
}
ul.ui.list:first-child,
ol.ui.list:first-child,
.ui.list:first-child {
- margin-top: 0;
- padding-top: 0;
+ margin-top: 0;
+ padding-top: 0;
}
ul.ui.list:last-child,
ol.ui.list:last-child,
.ui.list:last-child {
- margin-bottom: 0;
- padding-bottom: 0;
+ margin-bottom: 0;
+ padding-bottom: 0;
}
/*******************************
@@ -52,219 +52,218 @@ ul.ui.list li,
ol.ui.list li,
.ui.list > .item,
.ui.list .list > .item {
- display: list-item;
- table-layout: fixed;
- list-style-type: @listStyleType;
- list-style-position: @listStylePosition;
-
- padding: @itemPadding;
- line-height: @itemLineHeight;
+ display: list-item;
+ table-layout: fixed;
+ list-style-type: @listStyleType;
+ list-style-position: @listStylePosition;
+ padding: @itemPadding;
+ line-height: @itemLineHeight;
}
ul.ui.list > li:first-child::after,
ol.ui.list > li:first-child::after,
.ui.list > .list > .item::after,
.ui.list > .item::after {
- content: '';
- display: block;
- height: 0;
- clear: both;
- visibility: hidden;
+ content: "";
+ display: block;
+ height: 0;
+ clear: both;
+ visibility: hidden;
}
ul.ui.list li:first-child,
ol.ui.list li:first-child,
.ui.list .list > .item:first-child,
.ui.list > .item:first-child {
- padding-top: 0;
+ padding-top: 0;
}
ul.ui.list li:last-child,
ol.ui.list li:last-child,
.ui.list .list > .item:last-child,
.ui.list > .item:last-child {
- padding-bottom: 0;
+ padding-bottom: 0;
}
/* Child List */
ul.ui.list ul,
ol.ui.list ol,
.ui.list .list:not(.icon) {
- clear: both;
- margin: 0;
- padding: @childListPadding;
+ clear: both;
+ margin: 0;
+ padding: @childListPadding;
}
/* Child Item */
ul.ui.list ul li,
ol.ui.list ol li,
.ui.list .list > .item {
- padding: @childItemPadding;
- line-height: @childItemLineHeight;
+ padding: @childItemPadding;
+ line-height: @childItemLineHeight;
}
& when (@variationListIcon) {
- /* Icon */
- .ui.list .list > .item > i.icon,
- .ui.list > .item > i.icon {
- display: table-cell;
- min-width: 1.55em;
- margin: 0;
- padding-top: @iconOffset;
- transition: @iconTransition;
- &:not(.loading) {
- padding-right: @iconDistance;
- vertical-align: @iconContentVerticalAlign;
- }
- }
- .ui.list .list > .item > i.icon:only-child,
- .ui.list > .item > i.icon:only-child {
- display: inline-block;
- min-width: auto;
- vertical-align: @iconVerticalAlign;
- }
+ /* Icon */
+ .ui.list .list > .item > i.icon,
+ .ui.list > .item > i.icon {
+ display: table-cell;
+ min-width: 1.55em;
+ margin: 0;
+ padding-top: @iconOffset;
+ transition: @iconTransition;
+ &:not(.loading) {
+ padding-right: @iconDistance;
+ vertical-align: @iconContentVerticalAlign;
+ }
+ }
+ .ui.list .list > .item > i.icon:only-child,
+ .ui.list > .item > i.icon:only-child {
+ display: inline-block;
+ min-width: auto;
+ vertical-align: @iconVerticalAlign;
+ }
}
& when (@variationListImage) {
- /* Image */
- .ui.list .list > .item > .image,
- .ui.list > .item > .image {
- display: table-cell;
- background-color: transparent;
- margin: 0;
- vertical-align: @imageAlign;
- }
- .ui.list .list > .item > .image:not(:only-child):not(img),
- .ui.list > .item > .image:not(:only-child):not(img) {
- padding-right: @imageDistance;
- }
- .ui.list .list > .item > .image img,
- .ui.list > .item > .image img {
- vertical-align: @imageAlign;
- }
-
- .ui.list .list > .item > img.image,
- .ui.list .list > .item > .image:only-child,
- .ui.list > .item > img.image,
- .ui.list > .item > .image:only-child {
- display: inline-block;
- }
+ /* Image */
+ .ui.list .list > .item > .image,
+ .ui.list > .item > .image {
+ display: table-cell;
+ background-color: transparent;
+ margin: 0;
+ vertical-align: @imageAlign;
+ }
+ .ui.list .list > .item > .image:not(:only-child):not(img),
+ .ui.list > .item > .image:not(:only-child):not(img) {
+ padding-right: @imageDistance;
+ }
+ .ui.list .list > .item > .image img,
+ .ui.list > .item > .image img {
+ vertical-align: @imageAlign;
+ }
+
+ .ui.list .list > .item > img.image,
+ .ui.list .list > .item > .image:only-child,
+ .ui.list > .item > img.image,
+ .ui.list > .item > .image:only-child {
+ display: inline-block;
+ }
}
/* Content */
.ui.list .list > .item > .content,
.ui.list > .item > .content {
- line-height: @contentLineHeight;
- color: @contentColor;
+ line-height: @contentLineHeight;
+ color: @contentColor;
}
& when (@variationListImage) or (@variationListIcon) {
- .ui.list .list > .item > .image + .content,
- .ui.list .list > .item > i.icon + .content,
- .ui.list > .item > .image + .content,
- .ui.list > .item > i.icon + .content {
- display: table-cell;
- width: 100%;
- padding: 0 0 0 @contentDistance;
- vertical-align: @contentVerticalAlign;
- }
+ .ui.list .list > .item > .image + .content,
+ .ui.list .list > .item > i.icon + .content,
+ .ui.list > .item > .image + .content,
+ .ui.list > .item > i.icon + .content {
+ display: table-cell;
+ width: 100%;
+ padding: 0 0 0 @contentDistance;
+ vertical-align: @contentVerticalAlign;
+ }
}
& when (@variationListIcon) {
- .ui.list .list > .item > i.loading.icon + .content,
- .ui.list > .item > i.loading.icon + .content {
- padding-left: e(%("calc(%d + %d)", @iconDistance, @contentDistance));
- }
+ .ui.list .list > .item > i.loading.icon + .content,
+ .ui.list > .item > i.loading.icon + .content {
+ padding-left: e(%("calc(%d + %d)", @iconDistance, @contentDistance));
+ }
}
& when (@variationListImage) {
- .ui.list .list > .item > img.image + .content,
- .ui.list > .item > img.image + .content {
- display: inline-block;
- width: auto;
- }
+ .ui.list .list > .item > img.image + .content,
+ .ui.list > .item > img.image + .content {
+ display: inline-block;
+ width: auto;
+ }
}
.ui.list .list > .item > .content > .list,
.ui.list > .item > .content > .list {
- margin-left: 0;
- padding-left: 0;
+ margin-left: 0;
+ padding-left: 0;
}
& when (@variationListHeader) {
- /* Header */
- .ui.list .list > .item .header,
- .ui.list > .item .header {
- display: block;
- margin: 0;
- font-family: @itemHeaderFontFamily;
- font-weight: @itemHeaderFontWeight;
- color: @itemHeaderColor;
- }
+ /* Header */
+ .ui.list .list > .item .header,
+ .ui.list > .item .header {
+ display: block;
+ margin: 0;
+ font-family: @itemHeaderFontFamily;
+ font-weight: @itemHeaderFontWeight;
+ color: @itemHeaderColor;
+ }
}
& when (@variationListDescription) {
- /* Description */
- .ui.list .list > .item .description,
- .ui.list > .item .description {
- display: block;
- color: @itemDescriptionColor;
- }
+ /* Description */
+ .ui.list .list > .item .description,
+ .ui.list > .item .description {
+ display: block;
+ color: @itemDescriptionColor;
+ }
}
/* Child Link */
.ui.list > .item a,
.ui.list .list > .item a {
- cursor: pointer;
+ cursor: pointer;
}
/* Linking Item */
.ui.list .list > a.item,
.ui.list > a.item {
- cursor: pointer;
- color: @itemLinkColor;
+ cursor: pointer;
+ color: @itemLinkColor;
}
.ui.list .list > a.item:hover,
.ui.list > a.item:hover {
- color: @itemLinkHoverColor;
+ color: @itemLinkHoverColor;
}
& when (@variationListIcon) {
- /* Linked Item Icons */
- .ui.list .list > a.item > i.icons,
- .ui.list > a.item > i.icons,
- .ui.list .list > a.item > i.icon,
- .ui.list > a.item > i.icon {
- color: @itemLinkIconColor;
- }
+ /* Linked Item Icons */
+ .ui.list .list > a.item > i.icons,
+ .ui.list > a.item > i.icons,
+ .ui.list .list > a.item > i.icon,
+ .ui.list > a.item > i.icon {
+ color: @itemLinkIconColor;
+ }
}
& when (@variationListHeader) {
- /* Header Link */
- .ui.list .list > .item a.header,
- .ui.list > .item a.header {
- cursor: pointer;
- color: @itemHeaderLinkColor !important;
- }
- .ui.list .list > .item > a.header:hover,
- .ui.list > .item > a.header:hover {
- color: @itemHeaderLinkHoverColor !important;
- }
+ /* Header Link */
+ .ui.list .list > .item a.header,
+ .ui.list > .item a.header {
+ cursor: pointer;
+ color: @itemHeaderLinkColor !important;
+ }
+ .ui.list .list > .item > a.header:hover,
+ .ui.list > .item > a.header:hover {
+ color: @itemHeaderLinkHoverColor !important;
+ }
}
& when (@variationListFloated) {
- /* Floated Content */
- .ui[class*="left floated"].list {
- float: left;
- }
- .ui[class*="right floated"].list {
- float: right;
- }
-
- .ui.list .list > .item [class*="left floated"],
- .ui.list > .item [class*="left floated"] {
- float: left;
- margin: @leftFloatMargin;
- }
- .ui.list .list > .item [class*="right floated"],
- .ui.list > .item [class*="right floated"] {
- float: right;
- margin: @rightFloatMargin;
- }
+ /* Floated Content */
+ .ui[class*="left floated"].list {
+ float: left;
+ }
+ .ui[class*="right floated"].list {
+ float: right;
+ }
+
+ .ui.list .list > .item [class*="left floated"],
+ .ui.list > .item [class*="left floated"] {
+ float: left;
+ margin: @leftFloatMargin;
+ }
+ .ui.list .list > .item [class*="right floated"],
+ .ui.list > .item [class*="right floated"] {
+ float: right;
+ margin: @rightFloatMargin;
+ }
}
/*******************************
@@ -273,94 +272,91 @@ ol.ui.list ol li,
.ui.menu .ui.list > .item,
.ui.menu .ui.list .list > .item {
- display: list-item;
- table-layout: fixed;
- background-color: transparent;
-
- list-style-type: @listStyleType;
- list-style-position: @listStylePosition;
-
- padding: @itemVerticalPadding @itemHorizontalPadding;
- line-height: @itemLineHeight;
+ display: list-item;
+ table-layout: fixed;
+ background-color: transparent;
+ list-style-type: @listStyleType;
+ list-style-position: @listStylePosition;
+ padding: @itemVerticalPadding @itemHorizontalPadding;
+ line-height: @itemLineHeight;
}
.ui.menu .ui.list .list > .item::before,
.ui.menu .ui.list > .item::before {
- border: none;
- background: none;
+ border: none;
+ background: none;
}
.ui.menu .ui.list .list > .item:first-child,
.ui.menu .ui.list > .item:first-child {
- padding-top: 0;
+ padding-top: 0;
}
.ui.menu .ui.list .list > .item:last-child,
.ui.menu .ui.list > .item:last-child {
- padding-bottom: 0;
+ padding-bottom: 0;
}
-
/*******************************
Types
*******************************/
& when (@variationListHorizontal) {
- /*-------------------
- Horizontal
- --------------------*/
-
- .ui.horizontal.list {
- display: inline-block;
- font-size: 0;
- }
- .ui.horizontal.list > .item {
- display: inline-block;
- margin-right: @horizontalSpacing;
- font-size: 1rem;
- }
- .ui.horizontal.list:not(.celled) > .item:last-child {
- margin-right: 0;
- padding-right: 0;
- }
- .ui.horizontal.list .list:not(.icon) {
- padding-left: 0;
- padding-bottom: 0;
- }
- .ui.horizontal.list > .item > .image,
- .ui.horizontal.list .list > .item > .image,
- .ui.horizontal.list > .item > i.icon,
- .ui.horizontal.list .list > .item > i.icon,
- .ui.horizontal.list > .item > .content,
- .ui.horizontal.list .list > .item > .content {
- vertical-align: @horizontalVerticalAlign;
- }
-
- /* Padding on all elements */
- .ui.horizontal.list > .item:first-child,
- .ui.horizontal.list > .item:last-child {
- padding-top: @itemVerticalPadding;
- padding-bottom: @itemVerticalPadding;
- }
- & when (@variationListIcon) {
- /* Horizontal List */
- .ui.horizontal.list > .item > i.icon ,
- .ui.horizontal.list .item > i.icons > i.icon {
- margin: 0;
- padding: 0 @horizontalIconDistance 0 0;
- }
- }
- & when (@variationListImage) or (@variationListIcon) {
- .ui.horizontal.list > .item > .image + .content,
+ /* -------------------
+ Horizontal
+ -------------------- */
+
+ .ui.horizontal.list {
+ display: inline-block;
+ font-size: 0;
+ }
+ .ui.horizontal.list > .item {
+ display: inline-block;
+ margin-right: @horizontalSpacing;
+ font-size: 1rem;
+ }
+ .ui.horizontal.list:not(.celled) > .item:last-child {
+ margin-right: 0;
+ padding-right: 0;
+ }
+ .ui.horizontal.list .list:not(.icon) {
+ padding-left: 0;
+ padding-bottom: 0;
+ }
+ .ui.horizontal.list > .item > .image,
+ .ui.horizontal.list .list > .item > .image,
.ui.horizontal.list > .item > i.icon,
- .ui.horizontal.list > .item > i.icon + .content {
- float: none;
- display: inline-block;
- width: auto;
+ .ui.horizontal.list .list > .item > i.icon,
+ .ui.horizontal.list > .item > .content,
+ .ui.horizontal.list .list > .item > .content {
+ vertical-align: @horizontalVerticalAlign;
+ }
+
+ /* Padding on all elements */
+ .ui.horizontal.list > .item:first-child,
+ .ui.horizontal.list > .item:last-child {
+ padding-top: @itemVerticalPadding;
+ padding-bottom: @itemVerticalPadding;
}
- }
- & when (@variationListImage) {
- .ui.horizontal.list > .item > .image {
- display: inline-block;
+ & when (@variationListIcon) {
+ /* Horizontal List */
+ .ui.horizontal.list > .item > i.icon,
+ .ui.horizontal.list .item > i.icons > i.icon {
+ margin: 0;
+ padding: 0 @horizontalIconDistance 0 0;
+ }
+ }
+ & when (@variationListImage) or (@variationListIcon) {
+ .ui.horizontal.list > .item > .image + .content,
+ .ui.horizontal.list > .item > i.icon,
+ .ui.horizontal.list > .item > i.icon + .content {
+ float: none;
+ display: inline-block;
+ width: auto;
+ }
+ }
+ & when (@variationListImage) {
+ .ui.horizontal.list > .item > .image {
+ display: inline-block;
+ }
}
- }
}
/*******************************
@@ -368,33 +364,33 @@ ol.ui.list ol li,
*******************************/
& when (@variationListDisabled) {
- /*-------------------
- Disabled
- --------------------*/
-
- .ui.list .list > .disabled.item,
- .ui.list > .disabled.item {
- pointer-events: none;
- color: @disabledColor !important;
- }
- & when (@variationListInverted) {
- .ui.inverted.list .list > .disabled.item,
- .ui.inverted.list > .disabled.item {
- color: @invertedDisabledColor !important;
- }
- }
+ /* -------------------
+ Disabled
+ -------------------- */
+
+ .ui.list .list > .disabled.item,
+ .ui.list > .disabled.item {
+ pointer-events: none;
+ color: @disabledColor !important;
+ }
+ & when (@variationListInverted) {
+ .ui.inverted.list .list > .disabled.item,
+ .ui.inverted.list > .disabled.item {
+ color: @invertedDisabledColor !important;
+ }
+ }
}
-/*-------------------
+/* -------------------
Hover
---------------------*/
+-------------------- */
& when (@variationListIcon) {
- .ui.list .list > a.item:hover > .icons,
- .ui.list > a.item:hover > .icons,
- .ui.list .list > a.item:hover > i.icon,
- .ui.list > a.item:hover > i.icon {
- color: @itemLinkIconHoverColor;
- }
+ .ui.list .list > a.item:hover > .icons,
+ .ui.list > a.item:hover > .icons,
+ .ui.list .list > a.item:hover > i.icon,
+ .ui.list > a.item:hover > i.icon {
+ color: @itemLinkIconHoverColor;
+ }
}
/*******************************
@@ -402,629 +398,629 @@ ol.ui.list ol li,
*******************************/
& when (@variationListInverted) {
- /*-------------------
- Inverted
- --------------------*/
- & when (@variationListIcon) {
- .ui.inverted.list .list > a.item > i.icon,
- .ui.inverted.list > a.item > i.icon {
- color: @invertedIconLinkColor;
- }
- }
- & when (@variationListHeader) {
- .ui.inverted.list .list > .item .header,
- .ui.inverted.list > .item .header {
- color: @invertedHeaderColor;
- }
- }
- & when (@variationListDescription) {
- .ui.inverted.list .list > .item .description,
- .ui.inverted.list > .item .description {
- color: @invertedDescriptionColor;
- }
- }
- .ui.inverted.list .list > .item > .content,
- .ui.inverted.list > .item > .content {
- color: @invertedContentColor;
- }
- /* Item Link */
- .ui.inverted.list .list > a.item,
- .ui.inverted.list > a.item {
- cursor: pointer;
- color: @invertedItemLinkColor;
- }
- .ui.inverted.list .list > a.item:hover,
- .ui.inverted.list > a.item:hover {
- color: @invertedItemLinkHoverColor;
- }
-
-
- /* Linking Content */
- .ui.inverted.list .item a:not(.ui) {
- color: @invertedItemLinkColor !important;
- }
- .ui.inverted.list .item a:not(.ui):hover {
- color: @invertedItemLinkHoverColor !important;
- }
+ /* -------------------
+ Inverted
+ -------------------- */
+ & when (@variationListIcon) {
+ .ui.inverted.list .list > a.item > i.icon,
+ .ui.inverted.list > a.item > i.icon {
+ color: @invertedIconLinkColor;
+ }
+ }
+ & when (@variationListHeader) {
+ .ui.inverted.list .list > .item .header,
+ .ui.inverted.list > .item .header {
+ color: @invertedHeaderColor;
+ }
+ }
+ & when (@variationListDescription) {
+ .ui.inverted.list .list > .item .description,
+ .ui.inverted.list > .item .description {
+ color: @invertedDescriptionColor;
+ }
+ }
+ .ui.inverted.list .list > .item > .content,
+ .ui.inverted.list > .item > .content {
+ color: @invertedContentColor;
+ }
+
+ /* Item Link */
+ .ui.inverted.list .list > a.item,
+ .ui.inverted.list > a.item {
+ cursor: pointer;
+ color: @invertedItemLinkColor;
+ }
+ .ui.inverted.list .list > a.item:hover,
+ .ui.inverted.list > a.item:hover {
+ color: @invertedItemLinkHoverColor;
+ }
+
+ /* Linking Content */
+ .ui.inverted.list .item a:not(.ui) {
+ color: @invertedItemLinkColor !important;
+ }
+ .ui.inverted.list .item a:not(.ui):hover {
+ color: @invertedItemLinkHoverColor !important;
+ }
}
& when (@variationListAligned) {
- /*-------------------
- Aligned
- --------------------*/
-
- .ui.list[class*="top aligned"] .image,
- .ui.list[class*="top aligned"] .content,
- .ui.list [class*="top aligned"] {
- vertical-align: top !important;
- }
- .ui.list[class*="middle aligned"] .image,
- .ui.list[class*="middle aligned"] .content,
- .ui.list [class*="middle aligned"] {
- vertical-align: middle !important;
- }
- .ui.list[class*="bottom aligned"] .image,
- .ui.list[class*="bottom aligned"] .content,
- .ui.list [class*="bottom aligned"] {
- vertical-align: bottom !important;
- }
+ /* -------------------
+ Aligned
+ -------------------- */
+
+ .ui.list[class*="top aligned"] .image,
+ .ui.list[class*="top aligned"] .content,
+ .ui.list [class*="top aligned"] {
+ vertical-align: top !important;
+ }
+ .ui.list[class*="middle aligned"] .image,
+ .ui.list[class*="middle aligned"] .content,
+ .ui.list [class*="middle aligned"] {
+ vertical-align: middle !important;
+ }
+ .ui.list[class*="bottom aligned"] .image,
+ .ui.list[class*="bottom aligned"] .content,
+ .ui.list [class*="bottom aligned"] {
+ vertical-align: bottom !important;
+ }
}
& when (@variationListLink) {
- /*-------------------
- Link
- --------------------*/
-
- .ui.link.list .item,
- .ui.link.list a.item,
- .ui.link.list .item a:not(.ui) {
- color: @linkListItemColor;
- transition: @linkListTransition;
- }
- .ui.link.list.list a.item:hover,
- .ui.link.list.list .item a:not(.ui):hover {
- color: @linkListItemHoverColor;
- }
- .ui.link.list.list a.item:active,
- .ui.link.list.list .item a:not(.ui):active {
- color: @linkListItemDownColor;
- }
- .ui.link.list.list .active.item,
- .ui.link.list.list .active.item a:not(.ui) {
- color: @linkListItemActiveColor;
- }
- & when (@variationListInverted) {
- /* Inverted */
- .ui.inverted.link.list .item,
- .ui.inverted.link.list a.item,
- .ui.inverted.link.list .item a:not(.ui) {
- color: @invertedLinkListItemColor;
- }
- .ui.inverted.link.list.list a.item:hover,
- .ui.inverted.link.list.list .item a:not(.ui):hover {
- color: @invertedLinkListItemHoverColor;
- }
- .ui.inverted.link.list.list a.item:active,
- .ui.inverted.link.list.list .item a:not(.ui):active {
- color: @invertedLinkListItemDownColor;
- }
- .ui.inverted.link.list.list a.active.item,
- .ui.inverted.link.list.list .active.item a:not(.ui) {
- color: @invertedLinkListItemActiveColor;
- }
- }
+ /* -------------------
+ Link
+ -------------------- */
+
+ .ui.link.list .item,
+ .ui.link.list a.item,
+ .ui.link.list .item a:not(.ui) {
+ color: @linkListItemColor;
+ transition: @linkListTransition;
+ }
+ .ui.link.list.list a.item:hover,
+ .ui.link.list.list .item a:not(.ui):hover {
+ color: @linkListItemHoverColor;
+ }
+ .ui.link.list.list a.item:active,
+ .ui.link.list.list .item a:not(.ui):active {
+ color: @linkListItemDownColor;
+ }
+ .ui.link.list.list .active.item,
+ .ui.link.list.list .active.item a:not(.ui) {
+ color: @linkListItemActiveColor;
+ }
+ & when (@variationListInverted) {
+ /* Inverted */
+ .ui.inverted.link.list .item,
+ .ui.inverted.link.list a.item,
+ .ui.inverted.link.list .item a:not(.ui) {
+ color: @invertedLinkListItemColor;
+ }
+ .ui.inverted.link.list.list a.item:hover,
+ .ui.inverted.link.list.list .item a:not(.ui):hover {
+ color: @invertedLinkListItemHoverColor;
+ }
+ .ui.inverted.link.list.list a.item:active,
+ .ui.inverted.link.list.list .item a:not(.ui):active {
+ color: @invertedLinkListItemDownColor;
+ }
+ .ui.inverted.link.list.list a.active.item,
+ .ui.inverted.link.list.list .active.item a:not(.ui) {
+ color: @invertedLinkListItemActiveColor;
+ }
+ }
}
& when (@variationListSelection) {
- /*-------------------
- Selection
- --------------------*/
+ /* -------------------
+ Selection
+ -------------------- */
+
+ .ui.selection.list .list > .item,
+ .ui.selection.list > .item {
+ cursor: pointer;
+ background: @selectionListBackground;
+ padding: @selectionListItemVerticalPadding @selectionListItemHorizontalPadding;
+ margin: @selectionListItemMargin;
+ color: @selectionListColor;
+ border-radius: @selectionListItemBorderRadius;
+ transition: @selectionListTransition;
+ }
+ .ui.selection.list .list > .item:last-child,
+ .ui.selection.list > .item:last-child {
+ margin-bottom: 0;
+ }
+ .ui.selection.list .list > .item:hover,
+ .ui.selection.list > .item:hover {
+ background: @selectionListHoverBackground;
+ color: @selectionListHoverColor;
+ }
+ .ui.selection.list .list > .item:active,
+ .ui.selection.list > .item:active {
+ background: @selectionListDownBackground;
+ color: @selectionListDownColor;
+ }
+ .ui.selection.list .list > .item.active,
+ .ui.selection.list > .item.active {
+ background: @selectionListActiveBackground;
+ color: @selectionListActiveColor;
+ }
- .ui.selection.list .list > .item,
- .ui.selection.list > .item {
- cursor: pointer;
- background: @selectionListBackground;
- padding: @selectionListItemVerticalPadding @selectionListItemHorizontalPadding;
- margin: @selectionListItemMargin;
- color: @selectionListColor;
- border-radius: @selectionListItemBorderRadius;
- transition: @selectionListTransition;
- }
- .ui.selection.list .list > .item:last-child,
- .ui.selection.list > .item:last-child {
- margin-bottom: 0;
- }
- .ui.selection.list .list > .item:hover,
- .ui.selection.list > .item:hover {
- background: @selectionListHoverBackground;
- color: @selectionListHoverColor;
- }
- .ui.selection.list .list > .item:active,
- .ui.selection.list > .item:active {
- background: @selectionListDownBackground;
- color: @selectionListDownColor;
- }
- .ui.selection.list .list > .item.active,
- .ui.selection.list > .item.active {
- background: @selectionListActiveBackground;
- color: @selectionListActiveColor;
- }
-
- & when (@variationListInverted) {
- /* Inverted */
- .ui.inverted.selection.list > .item {
- background: @invertedSelectionListBackground;
- color: @invertedSelectionListColor;
- }
- .ui.inverted.selection.list > .item:hover {
- background: @invertedSelectionListHoverBackground;
- color: @invertedSelectionListHoverColor;
- }
- .ui.inverted.selection.list > .item:active {
- background: @invertedSelectionListDownBackground;
- color: @invertedSelectionListDownColor;
- }
- .ui.inverted.selection.list > .item.active {
- background: @invertedSelectionListActiveBackground;
- color: @invertedSelectionListActiveColor;
- }
- }
-
- & when (@variationListCelled) or (@variationListDivided) {
- /* Celled / Divided Selection List */
- .ui.celled.selection.list .list > .item,
- .ui.divided.selection.list .list > .item,
- .ui.celled.selection.list > .item,
- .ui.divided.selection.list > .item {
- border-radius: 0;
- }
- }
+ & when (@variationListInverted) {
+ /* Inverted */
+ .ui.inverted.selection.list > .item {
+ background: @invertedSelectionListBackground;
+ color: @invertedSelectionListColor;
+ }
+ .ui.inverted.selection.list > .item:hover {
+ background: @invertedSelectionListHoverBackground;
+ color: @invertedSelectionListHoverColor;
+ }
+ .ui.inverted.selection.list > .item:active {
+ background: @invertedSelectionListDownBackground;
+ color: @invertedSelectionListDownColor;
+ }
+ .ui.inverted.selection.list > .item.active {
+ background: @invertedSelectionListActiveBackground;
+ color: @invertedSelectionListActiveColor;
+ }
+ }
+
+ & when (@variationListCelled) or (@variationListDivided) {
+ /* Celled / Divided Selection List */
+ .ui.celled.selection.list .list > .item,
+ .ui.divided.selection.list .list > .item,
+ .ui.celled.selection.list > .item,
+ .ui.divided.selection.list > .item {
+ border-radius: 0;
+ }
+ }
}
& when (@variationListAnimated) {
- /*-------------------
- Animated
- --------------------*/
-
- .ui.animated.list > .item {
- transition: @animatedListTransition;
- }
- .ui.animated.list:not(.horizontal) > .item:hover {
- padding-left: @animatedListIndent;
- }
+ /* -------------------
+ Animated
+ -------------------- */
+
+ .ui.animated.list > .item {
+ transition: @animatedListTransition;
+ }
+ .ui.animated.list:not(.horizontal) > .item:hover {
+ padding-left: @animatedListIndent;
+ }
}
& when (@variationListFitted) {
- /*-------------------
- Fitted
- --------------------*/
- .ui.fitted.list:not(.selection) .list > .item,
- .ui.fitted.list:not(.selection) > .item {
- padding-left: 0;
- padding-right: 0;
- }
- .ui.fitted.selection.list .list > .item,
- .ui.fitted.selection.list > .item {
- margin-left: -@selectionListItemHorizontalPadding;
- margin-right: -@selectionListItemHorizontalPadding;
- }
+ /* -------------------
+ Fitted
+ -------------------- */
+ .ui.fitted.list:not(.selection) .list > .item,
+ .ui.fitted.list:not(.selection) > .item {
+ padding-left: 0;
+ padding-right: 0;
+ }
+ .ui.fitted.selection.list .list > .item,
+ .ui.fitted.selection.list > .item {
+ margin-left: -@selectionListItemHorizontalPadding;
+ margin-right: -@selectionListItemHorizontalPadding;
+ }
}
& when (@variationListBulleted) {
- /*-------------------
- Bulleted
- --------------------*/
-
- ul.ui.list,
- .ui.bulleted.list {
- margin-left: @bulletDistance;
- }
- ul.ui.list li,
- .ui.bulleted.list .list > .item,
- .ui.bulleted.list > .item {
- position: relative;
- }
- ul.ui.list li::before,
- .ui.bulleted.list .list > .item::before,
- .ui.bulleted.list > .item::before {
- user-select: none;
- pointer-events: none;
- position: absolute;
- top: auto;
- left: auto;
- font-weight: @normal;
- margin-left: @bulletOffset;
- content: @bulletCharacter;
- opacity: @bulletOpacity;
- color: @bulletColor;
- vertical-align: @bulletVerticalAlign;
- }
-
- ul.ui.list li::before,
- .ui.bulleted.list .list > a.item::before,
- .ui.bulleted.list > a.item::before {
- color: @bulletLinkColor;
- }
-
- ul.ui.list ul,
- .ui.bulleted.list .list:not(.icon) {
- padding-left: @bulletChildDistance;
- }
-
- & when (@variationListHorizontal) {
- /* Horizontal Bulleted */
- ul.ui.horizontal.bulleted.list,
- .ui.horizontal.bulleted.list {
- margin-left: 0;
- }
- ul.ui.horizontal.bulleted.list li,
- .ui.horizontal.bulleted.list > .item {
- margin-left: @horizontalBulletSpacing;
- }
- ul.ui.horizontal.bulleted.list li:first-child,
- .ui.horizontal.bulleted.list > .item:first-child {
- margin-left: 0;
- }
- ul.ui.horizontal.bulleted.list li::before,
- .ui.horizontal.bulleted.list > .item::before {
- color: @horizontalBulletColor;
- }
- ul.ui.horizontal.bulleted.list li:first-child::before,
- .ui.horizontal.bulleted.list > .item:first-child::before {
- display: none;
- }
- }
+ /* -------------------
+ Bulleted
+ -------------------- */
+
+ ul.ui.list,
+ .ui.bulleted.list {
+ margin-left: @bulletDistance;
+ }
+ ul.ui.list li,
+ .ui.bulleted.list .list > .item,
+ .ui.bulleted.list > .item {
+ position: relative;
+ }
+ ul.ui.list li::before,
+ .ui.bulleted.list .list > .item::before,
+ .ui.bulleted.list > .item::before {
+ user-select: none;
+ pointer-events: none;
+ position: absolute;
+ top: auto;
+ left: auto;
+ font-weight: @normal;
+ margin-left: @bulletOffset;
+ content: @bulletCharacter;
+ opacity: @bulletOpacity;
+ color: @bulletColor;
+ vertical-align: @bulletVerticalAlign;
+ }
+
+ ul.ui.list li::before,
+ .ui.bulleted.list .list > a.item::before,
+ .ui.bulleted.list > a.item::before {
+ color: @bulletLinkColor;
+ }
+
+ ul.ui.list ul,
+ .ui.bulleted.list .list:not(.icon) {
+ padding-left: @bulletChildDistance;
+ }
+
+ & when (@variationListHorizontal) {
+ /* Horizontal Bulleted */
+ ul.ui.horizontal.bulleted.list,
+ .ui.horizontal.bulleted.list {
+ margin-left: 0;
+ }
+ ul.ui.horizontal.bulleted.list li,
+ .ui.horizontal.bulleted.list > .item {
+ margin-left: @horizontalBulletSpacing;
+ }
+ ul.ui.horizontal.bulleted.list li:first-child,
+ .ui.horizontal.bulleted.list > .item:first-child {
+ margin-left: 0;
+ }
+ ul.ui.horizontal.bulleted.list li::before,
+ .ui.horizontal.bulleted.list > .item::before {
+ color: @horizontalBulletColor;
+ }
+ ul.ui.horizontal.bulleted.list li:first-child::before,
+ .ui.horizontal.bulleted.list > .item:first-child::before {
+ display: none;
+ }
+ }
}
& when (@variationListOrdered) {
- /*-------------------
- Ordered
- --------------------*/
-
- ol.ui.list,
- .ui.ordered.list,
- .ui.ordered.list .list:not(.icon),
- ol.ui.list ol {
- counter-reset: ordered;
- margin-left: @orderedCountDistance;
- list-style-type: none;
- }
- ol.ui.list li,
- .ui.ordered.list .list > .item,
- .ui.ordered.list > .item {
- list-style-type: none;
- position: relative;
- }
- ol.ui.list li::before,
- .ui.ordered.list .list > .item::before,
- .ui.ordered.list > .item::before {
- position: absolute;
- top: auto;
- left: auto;
- user-select: none;
- pointer-events: none;
- margin-left: -(@orderedCountDistance);
- counter-increment: @orderedCountName;
- content: @orderedCountContent;
- text-align: @orderedCountTextAlign;
- color: @orderedCountColor;
- vertical-align: @orderedCountVerticalAlign;
- opacity: @orderedCountOpacity;
- }
-
- & when (@variationListInverted) {
- ol.ui.inverted.list li::before,
- .ui.ordered.inverted.list .list > .item::before,
- .ui.ordered.inverted.list > .item::before {
- color: @orderedInvertedCountColor;
- }
- }
-
- /* Value */
- .ui.ordered.list .list > .item[data-value]::before,
- .ui.ordered.list > .item[data-value]::before {
- content: attr(data-value);
- }
- ol.ui.list li[value]::before {
- content: attr(value);
- }
-
- /* Child Lists */
- ol.ui.list ol,
- .ui.ordered.list .list:not(.icon) {
- margin-left: @orderedChildCountDistance;
- }
- ol.ui.list ol li::before,
- .ui.ordered.list .list > .item::before {
- margin-left: @orderedChildCountOffset;
- }
-
- & when (@variationListHorizontal) {
- /* Horizontal Ordered */
- ol.ui.horizontal.list,
- .ui.ordered.horizontal.list {
- margin-left: 0;
- }
- ol.ui.horizontal.list li::before,
- .ui.ordered.horizontal.list .list > .item::before,
- .ui.ordered.horizontal.list > .item::before {
- position: static;
- margin: 0 @horizontalOrderedCountDistance 0 0;
- }
- }
+ /* -------------------
+ Ordered
+ -------------------- */
+
+ ol.ui.list,
+ .ui.ordered.list,
+ .ui.ordered.list .list:not(.icon),
+ ol.ui.list ol {
+ counter-reset: ordered;
+ margin-left: @orderedCountDistance;
+ list-style-type: none;
+ }
+ ol.ui.list li,
+ .ui.ordered.list .list > .item,
+ .ui.ordered.list > .item {
+ list-style-type: none;
+ position: relative;
+ }
+ ol.ui.list li::before,
+ .ui.ordered.list .list > .item::before,
+ .ui.ordered.list > .item::before {
+ position: absolute;
+ top: auto;
+ left: auto;
+ user-select: none;
+ pointer-events: none;
+ margin-left: -(@orderedCountDistance);
+ counter-increment: @orderedCountName;
+ content: @orderedCountContent;
+ text-align: @orderedCountTextAlign;
+ color: @orderedCountColor;
+ vertical-align: @orderedCountVerticalAlign;
+ opacity: @orderedCountOpacity;
+ }
+
+ & when (@variationListInverted) {
+ ol.ui.inverted.list li::before,
+ .ui.ordered.inverted.list .list > .item::before,
+ .ui.ordered.inverted.list > .item::before {
+ color: @orderedInvertedCountColor;
+ }
+ }
+
+ /* Value */
+ .ui.ordered.list .list > .item[data-value]::before,
+ .ui.ordered.list > .item[data-value]::before {
+ content: attr(data-value);
+ }
+ ol.ui.list li[value]::before {
+ content: attr(value);
+ }
+
+ /* Child Lists */
+ ol.ui.list ol,
+ .ui.ordered.list .list:not(.icon) {
+ margin-left: @orderedChildCountDistance;
+ }
+ ol.ui.list ol li::before,
+ .ui.ordered.list .list > .item::before {
+ margin-left: @orderedChildCountOffset;
+ }
+
+ & when (@variationListHorizontal) {
+ /* Horizontal Ordered */
+ ol.ui.horizontal.list,
+ .ui.ordered.horizontal.list {
+ margin-left: 0;
+ }
+ ol.ui.horizontal.list li::before,
+ .ui.ordered.horizontal.list .list > .item::before,
+ .ui.ordered.horizontal.list > .item::before {
+ position: static;
+ margin: 0 @horizontalOrderedCountDistance 0 0;
+ }
+ }
}
& when (@variationListSuffixed) {
- /* Suffixed Ordered */
- ol.ui.suffixed.list li::before,
- .ui.suffixed.ordered.list .list > .item::before,
- .ui.suffixed.ordered.list > .item::before {
- content: @orderedCountContentSuffixed;
- }
+ /* Suffixed Ordered */
+ ol.ui.suffixed.list li::before,
+ .ui.suffixed.ordered.list .list > .item::before,
+ .ui.suffixed.ordered.list > .item::before {
+ content: @orderedCountContentSuffixed;
+ }
}
& when (@variationListDivided) {
- /*-------------------
- Divided
- --------------------*/
-
- .ui.divided.list > .item {
- border-top: @dividedBorder;
- }
- .ui.divided.list .list > .item {
- border-top: @dividedChildListBorder;
- }
- .ui.divided.list .item .list > .item {
- border-top: @dividedChildItemBorder;
- }
- .ui.divided.list .list > .item:first-child,
- .ui.divided.list > .item:first-child {
- border-top: none;
- }
-
- /* Sub Menu */
- .ui.divided.list:not(.horizontal) .list > .item:first-child {
- border-top-width: @dividedBorderWidth;
- }
-
- & when (@variationListBulleted) {
- /* Divided bulleted */
- .ui.divided.bulleted.list:not(.horizontal),
- .ui.divided.bulleted.list .list:not(.icon) {
- margin-left: 0;
- padding-left: 0;
- }
- .ui.divided.bulleted.list > .item:not(.horizontal) {
- padding-left: @bulletDistance;
- }
- }
-
- & when (@variationListOrdered) {
- /* Divided Ordered */
- .ui.divided.ordered.list {
- margin-left: 0;
- }
- .ui.divided.ordered.list .list > .item,
- .ui.divided.ordered.list > .item {
- padding-left: @orderedCountDistance;
- }
- .ui.divided.ordered.list .item .list:not(.icon) {
- margin-left: 0;
- margin-right: 0;
- padding-bottom: @itemVerticalPadding;
- }
- .ui.divided.ordered.list .item .list > .item {
- padding-left: @orderedChildCountDistance;
- }
- }
-
- & when (@variationListSelection) {
- /* Divided Selection */
-
- .ui.divided.selection.list .list > .item,
- .ui.divided.selection.list > .item {
- margin: 0;
- border-radius: 0;
- }
- }
-
- & when (@variationListHorizontal) {
- /* Divided horizontal */
- .ui.divided.horizontal.list {
- margin-left: 0;
- }
- .ui.divided.horizontal.list > .item {
- padding-left: @horizontalDividedSpacing;
- }
- .ui.divided.horizontal.list > .item:not(:last-child) {
- padding-right: @horizontalDividedSpacing;
- }
- .ui.divided.horizontal.list > .item {
- border-top: none;
- border-right: @dividedBorder;
- margin: 0;
- line-height: @horizontalDividedLineHeight;
- }
- .ui.horizontal.divided.list > .item:last-child {
- border-right: none;
- }
- }
-
- & when (@variationListInverted) {
- /* Inverted */
-
- .ui.divided.inverted.list > .item,
- .ui.divided.inverted.list > .list,
- .ui.divided.inverted.horizontal.list > .item {
- border-color: @dividedInvertedBorderColor;
- }
- }
+ /* -------------------
+ Divided
+ -------------------- */
+
+ .ui.divided.list > .item {
+ border-top: @dividedBorder;
+ }
+ .ui.divided.list .list > .item {
+ border-top: @dividedChildListBorder;
+ }
+ .ui.divided.list .item .list > .item {
+ border-top: @dividedChildItemBorder;
+ }
+ .ui.divided.list .list > .item:first-child,
+ .ui.divided.list > .item:first-child {
+ border-top: none;
+ }
+
+ /* Sub Menu */
+ .ui.divided.list:not(.horizontal) .list > .item:first-child {
+ border-top-width: @dividedBorderWidth;
+ }
+
+ & when (@variationListBulleted) {
+ /* Divided bulleted */
+ .ui.divided.bulleted.list:not(.horizontal),
+ .ui.divided.bulleted.list .list:not(.icon) {
+ margin-left: 0;
+ padding-left: 0;
+ }
+ .ui.divided.bulleted.list > .item:not(.horizontal) {
+ padding-left: @bulletDistance;
+ }
+ }
+
+ & when (@variationListOrdered) {
+ /* Divided Ordered */
+ .ui.divided.ordered.list {
+ margin-left: 0;
+ }
+ .ui.divided.ordered.list .list > .item,
+ .ui.divided.ordered.list > .item {
+ padding-left: @orderedCountDistance;
+ }
+ .ui.divided.ordered.list .item .list:not(.icon) {
+ margin-left: 0;
+ margin-right: 0;
+ padding-bottom: @itemVerticalPadding;
+ }
+ .ui.divided.ordered.list .item .list > .item {
+ padding-left: @orderedChildCountDistance;
+ }
+ }
+
+ & when (@variationListSelection) {
+ /* Divided Selection */
+
+ .ui.divided.selection.list .list > .item,
+ .ui.divided.selection.list > .item {
+ margin: 0;
+ border-radius: 0;
+ }
+ }
+
+ & when (@variationListHorizontal) {
+ /* Divided horizontal */
+ .ui.divided.horizontal.list {
+ margin-left: 0;
+ }
+ .ui.divided.horizontal.list > .item {
+ padding-left: @horizontalDividedSpacing;
+ }
+ .ui.divided.horizontal.list > .item:not(:last-child) {
+ padding-right: @horizontalDividedSpacing;
+ }
+ .ui.divided.horizontal.list > .item {
+ border-top: none;
+ border-right: @dividedBorder;
+ margin: 0;
+ line-height: @horizontalDividedLineHeight;
+ }
+ .ui.horizontal.divided.list > .item:last-child {
+ border-right: none;
+ }
+ }
+
+ & when (@variationListInverted) {
+ /* Inverted */
+
+ .ui.divided.inverted.list > .item,
+ .ui.divided.inverted.list > .list,
+ .ui.divided.inverted.horizontal.list > .item {
+ border-color: @dividedInvertedBorderColor;
+ }
+ }
}
& when (@variationListCelled) {
- /*-------------------
- Celled
- --------------------*/
-
- .ui.celled.list > .item,
- .ui.celled.list > .list {
- border-top: @celledBorder;
- padding-left: @celledHorizontalPadding;
- padding-right: @celledHorizontalPadding;
- }
- .ui.celled.list > .item:last-child {
- border-bottom: @celledBorder;
- }
-
- /* Padding on all elements */
- .ui.celled.list > .item:first-child,
- .ui.celled.list > .item:last-child {
- padding-top: @itemVerticalPadding;
- padding-bottom: @itemVerticalPadding;
- }
-
- /* Sub Menu */
- .ui.celled.list .item .list > .item {
- border-width: 0;
- }
- .ui.celled.list .list > .item:first-child {
- border-top-width: 0;
- }
-
- & when (@variationListBulleted) {
- /* Celled Bulleted */
- .ui.celled.bulleted.list {
- margin-left: 0;
- }
- .ui.celled.bulleted.list .list > .item,
- .ui.celled.bulleted.list > .item {
- padding-left: (@bulletDistance);
- }
- .ui.celled.bulleted.list .item .list:not(.icon) {
- margin-left: -(@bulletDistance);
- margin-right: -(@bulletDistance);
- padding-bottom: @itemVerticalPadding;
- }
- }
-
- & when (@variationListOrdered) {
- /* Celled Ordered */
- .ui.celled.ordered.list {
- margin-left: 0;
- }
- .ui.celled.ordered.list .list > .item,
- .ui.celled.ordered.list > .item {
- padding-left: @orderedCountDistance;
- }
- .ui.celled.ordered.list .item .list:not(.icon) {
- margin-left: 0;
- margin-right: 0;
- padding-bottom: @itemVerticalPadding;
- }
- .ui.celled.ordered.list .list > .item {
- padding-left: @orderedChildCountDistance;
- }
- }
-
- & when (@variationListHorizontal) {
- /* Celled Horizontal */
- .ui.horizontal.celled.list {
- margin-left: 0;
- }
- .ui.horizontal.celled.list .list > .item,
- .ui.horizontal.celled.list > .item {
- border-top: none;
- border-left: @celledBorder;
- margin: 0;
- padding-left: @horizontalCelledSpacing;
- padding-right: @horizontalCelledSpacing;
-
- line-height: @horizontalCelledLineHeight;
- }
- .ui.horizontal.celled.list .list > .item:last-child,
- .ui.horizontal.celled.list > .item:last-child {
- border-bottom: none;
- border-right: @celledBorder;
- }
- }
-
- & when (@variationListInverted) {
- /* Inverted */
- .ui.celled.inverted.list > .item,
- .ui.celled.inverted.list > .list {
- border-color: @celledInvertedBorder;
- }
- .ui.celled.inverted.horizontal.list .list > .item,
- .ui.celled.inverted.horizontal.list > .item {
- border-color: @celledInvertedBorder;
+ /* -------------------
+ Celled
+ -------------------- */
+
+ .ui.celled.list > .item,
+ .ui.celled.list > .list {
+ border-top: @celledBorder;
+ padding-left: @celledHorizontalPadding;
+ padding-right: @celledHorizontalPadding;
}
+ .ui.celled.list > .item:last-child {
+ border-bottom: @celledBorder;
}
-}
-& when (@variationListRelaxed) {
- /*-------------------
- Relaxed
- --------------------*/
+ /* Padding on all elements */
+ .ui.celled.list > .item:first-child,
+ .ui.celled.list > .item:last-child {
+ padding-top: @itemVerticalPadding;
+ padding-bottom: @itemVerticalPadding;
+ }
- .ui.relaxed.list:not(.horizontal) > .item:not(:first-child) {
- padding-top: @relaxedItemVerticalPadding;
- }
- .ui.relaxed.list:not(.horizontal) > .item:not(:last-child) {
- padding-bottom: @relaxedItemVerticalPadding;
- }
+ /* Sub Menu */
+ .ui.celled.list .item .list > .item {
+ border-width: 0;
+ }
+ .ui.celled.list .list > .item:first-child {
+ border-top-width: 0;
+ }
- & when (@variationListHorizontal) {
- .ui.horizontal.relaxed.list .list > .item:not(:first-child),
- .ui.horizontal.relaxed.list > .item:not(:first-child) {
- padding-left: @relaxedHorizontalPadding;
+ & when (@variationListBulleted) {
+ /* Celled Bulleted */
+ .ui.celled.bulleted.list {
+ margin-left: 0;
+ }
+ .ui.celled.bulleted.list .list > .item,
+ .ui.celled.bulleted.list > .item {
+ padding-left: (@bulletDistance);
+ }
+ .ui.celled.bulleted.list .item .list:not(.icon) {
+ margin-left: -(@bulletDistance);
+ margin-right: -(@bulletDistance);
+ padding-bottom: @itemVerticalPadding;
+ }
}
- .ui.horizontal.relaxed.list .list > .item:not(:last-child),
- .ui.horizontal.relaxed.list > .item:not(:last-child) {
- padding-right: @relaxedHorizontalPadding;
+
+ & when (@variationListOrdered) {
+ /* Celled Ordered */
+ .ui.celled.ordered.list {
+ margin-left: 0;
+ }
+ .ui.celled.ordered.list .list > .item,
+ .ui.celled.ordered.list > .item {
+ padding-left: @orderedCountDistance;
+ }
+ .ui.celled.ordered.list .item .list:not(.icon) {
+ margin-left: 0;
+ margin-right: 0;
+ padding-bottom: @itemVerticalPadding;
+ }
+ .ui.celled.ordered.list .list > .item {
+ padding-left: @orderedChildCountDistance;
+ }
}
- }
- & when (@variationListVeryRelaxed) {
- /* Very Relaxed */
- .ui[class*="very relaxed"].list:not(.horizontal) > .item:not(:first-child) {
- padding-top: @veryRelaxedItemVerticalPadding;
+
+ & when (@variationListHorizontal) {
+ /* Celled Horizontal */
+ .ui.horizontal.celled.list {
+ margin-left: 0;
+ }
+ .ui.horizontal.celled.list .list > .item,
+ .ui.horizontal.celled.list > .item {
+ border-top: none;
+ border-left: @celledBorder;
+ margin: 0;
+ padding-left: @horizontalCelledSpacing;
+ padding-right: @horizontalCelledSpacing;
+ line-height: @horizontalCelledLineHeight;
+ }
+ .ui.horizontal.celled.list .list > .item:last-child,
+ .ui.horizontal.celled.list > .item:last-child {
+ border-bottom: none;
+ border-right: @celledBorder;
+ }
}
- .ui[class*="very relaxed"].list:not(.horizontal) > .item:not(:last-child) {
- padding-bottom: @veryRelaxedItemVerticalPadding;
+
+ & when (@variationListInverted) {
+ /* Inverted */
+ .ui.celled.inverted.list > .item,
+ .ui.celled.inverted.list > .list {
+ border-color: @celledInvertedBorder;
+ }
+ .ui.celled.inverted.horizontal.list .list > .item,
+ .ui.celled.inverted.horizontal.list > .item {
+ border-color: @celledInvertedBorder;
+ }
+ }
+}
+
+& when (@variationListRelaxed) {
+ /* -------------------
+ Relaxed
+ -------------------- */
+
+ .ui.relaxed.list:not(.horizontal) > .item:not(:first-child) {
+ padding-top: @relaxedItemVerticalPadding;
+ }
+ .ui.relaxed.list:not(.horizontal) > .item:not(:last-child) {
+ padding-bottom: @relaxedItemVerticalPadding;
}
& when (@variationListHorizontal) {
- .ui.horizontal[class*="very relaxed"].list .list > .item:not(:first-child),
- .ui.horizontal[class*="very relaxed"].list > .item:not(:first-child) {
- padding-left: @veryRelaxedHorizontalPadding;
- }
- .ui.horizontal[class*="very relaxed"].list .list > .item:not(:last-child),
- .ui.horizontal[class*="very relaxed"].list > .item:not(:last-child) {
- padding-right: @veryRelaxedHorizontalPadding;
- }
- }
- }
+ .ui.horizontal.relaxed.list .list > .item:not(:first-child),
+ .ui.horizontal.relaxed.list > .item:not(:first-child) {
+ padding-left: @relaxedHorizontalPadding;
+ }
+ .ui.horizontal.relaxed.list .list > .item:not(:last-child),
+ .ui.horizontal.relaxed.list > .item:not(:last-child) {
+ padding-right: @relaxedHorizontalPadding;
+ }
+ }
+ & when (@variationListVeryRelaxed) {
+ /* Very Relaxed */
+ .ui[class*="very relaxed"].list:not(.horizontal) > .item:not(:first-child) {
+ padding-top: @veryRelaxedItemVerticalPadding;
+ }
+ .ui[class*="very relaxed"].list:not(.horizontal) > .item:not(:last-child) {
+ padding-bottom: @veryRelaxedItemVerticalPadding;
+ }
+
+ & when (@variationListHorizontal) {
+ .ui.horizontal[class*="very relaxed"].list .list > .item:not(:first-child),
+ .ui.horizontal[class*="very relaxed"].list > .item:not(:first-child) {
+ padding-left: @veryRelaxedHorizontalPadding;
+ }
+ .ui.horizontal[class*="very relaxed"].list .list > .item:not(:last-child),
+ .ui.horizontal[class*="very relaxed"].list > .item:not(:last-child) {
+ padding-right: @veryRelaxedHorizontalPadding;
+ }
+ }
+ }
}
-/*-------------------
+
+/* -------------------
Sizes
---------------------*/
+-------------------- */
.ui.list {
- font-size: @relativeMedium;
+ font-size: @relativeMedium;
}
& when not (@variationListSizes = false) {
- each(@variationListSizes, {
- @rs: @{value}ListSize;
- @s: @@value;
- .ui.@{value}.list {
- font-size: @@rs;
- }
- & when (@variationListHorizontal) {
- .ui.@{value}.horizontal.list .list > .item,
- .ui.@{value}.horizontal.list > .item {
- font-size: @s;
- }
- }
- })
+ each(@variationListSizes, {
+ @rs: @{value}ListSize;
+ @s: @@value;
+ .ui.@{value}.list {
+ font-size: @@rs;
+ }
+ & when (@variationListHorizontal) {
+ .ui.@{value}.horizontal.list .list > .item,
+ .ui.@{value}.horizontal.list > .item {
+ font-size: @s;
+ }
+ }
+ });
}
.loadUIOverrides();
diff --git a/definitions/elements/loader.less b/definitions/elements/loader.less
index beb8151..eef2db5 100644
--- a/definitions/elements/loader.less
+++ b/definitions/elements/loader.less
@@ -1,115 +1,112 @@
/*!
* # Fomantic-UI - Loader
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
+
/*******************************
Theme
*******************************/
-@type : 'element';
-@element : 'loader';
+@type: "element";
+@element: "loader";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Loader
*******************************/
-
/* Standard Size */
.ui.loader {
- display: none;
- position: absolute;
- top: @loaderTopOffset;
- left: @loaderLeftOffset;
- margin: 0;
- text-align: center;
- z-index: 1000;
- transform: translateX(-50%) translateY(-50%);
+ display: none;
+ position: absolute;
+ top: @loaderTopOffset;
+ left: @loaderLeftOffset;
+ margin: 0;
+ text-align: center;
+ z-index: 1000;
+ transform: translateX(-50%) translateY(-50%);
}
/* Static Shape */
.ui.loader::before {
- position: absolute;
- content: '';
- top: 0;
- left: 50%;
- width: 100%;
- height: 100%;
-
- border-radius: @circularRadius;
- border: @loaderLineWidth solid @loaderFillColor;
+ position: absolute;
+ content: "";
+ top: 0;
+ left: 50%;
+ width: 100%;
+ height: 100%;
+ border-radius: @circularRadius;
+ border: @loaderLineWidth solid @loaderFillColor;
}
/* Active Shape */
.ui.loader::after {
- position: absolute;
- content: '';
- top: 0;
- left: 50%;
- width: 100%;
- height: 100%;
-
- animation: loader @loaderSpeed infinite linear;
- border: @loaderLineWidth solid @shapeBorderColor;
- border-radius: @circularRadius;
-
- box-shadow: 0 0 0 1px transparent;
+ position: absolute;
+ content: "";
+ top: 0;
+ left: 50%;
+ width: 100%;
+ height: 100%;
+ animation: loader @loaderSpeed infinite linear;
+ border: @loaderLineWidth solid @shapeBorderColor;
+ border-radius: @circularRadius;
+ box-shadow: 0 0 0 1px transparent;
}
& when (@variationLoaderSpeeds) {
- /* Speeds */
-
- .ui.fast.loading.loading::after,
- .ui.fast.loading.loading .input > i.icon::after,
- .ui.fast.loading.loading > i.icon::after,
- .ui.fast.loader::after {
- animation-duration: @loaderSpeedFast;
- }
-
- .ui.slow.loading.loading::after,
- .ui.slow.loading.loading .input > i.icon::after,
- .ui.slow.loading.loading > i.icon::after,
- .ui.slow.loader::after {
- animation-duration: @loaderSpeedSlow;
- }
+ /* Speeds */
+
+ .ui.fast.loading.loading::after,
+ .ui.fast.loading.loading .input > i.icon::after,
+ .ui.fast.loading.loading > i.icon::after,
+ .ui.fast.loader::after {
+ animation-duration: @loaderSpeedFast;
+ }
+
+ .ui.slow.loading.loading::after,
+ .ui.slow.loading.loading .input > i.icon::after,
+ .ui.slow.loading.loading > i.icon::after,
+ .ui.slow.loader::after {
+ animation-duration: @loaderSpeedSlow;
+ }
}
/* Active Animation */
@keyframes loader {
- 100% {
- transform: rotate(360deg);
- }
+ 100% {
+ transform: rotate(360deg);
+ }
}
-/*-------------------
+/* -------------------
Coupling
---------------------*/
+-------------------- */
/* Show inside active dimmer */
.ui.dimmer > .loader {
- display: block;
+ display: block;
}
/* Black Dimmer */
.ui.dimmer > .ui.loader {
- color: @invertedLoaderTextColor;
+ color: @invertedLoaderTextColor;
}
.ui.dimmer > .ui.loader:not(.elastic)::before {
- border-color: @invertedLoaderFillColor;
+ border-color: @invertedLoaderFillColor;
}
/* White Dimmer (Inverted) */
.ui.inverted.dimmer > .ui.loader {
- color: @loaderTextColor;
+ color: @loaderTextColor;
}
.ui.inverted.dimmer > .ui.loader:not(.elastic)::before {
- border-color: @loaderFillColor;
+ border-color: @loaderFillColor;
}
/*******************************
@@ -117,121 +114,119 @@
*******************************/
& when (@variationLoaderText) {
- /*-------------------
- Text
- --------------------*/
-
- .ui.ui.ui.ui.text.loader {
- width: auto;
- height: auto;
- text-align: center;
- font-style: normal;
- }
+ /* -------------------
+ Text
+ -------------------- */
+
+ .ui.ui.ui.ui.text.loader {
+ width: auto;
+ height: auto;
+ text-align: center;
+ font-style: normal;
+ }
}
-
/*******************************
States
*******************************/
& when (@variationLoaderIndeterminate) {
- .ui.indeterminate.loader::after {
- animation-direction: @indeterminateDirection;
- animation-duration: @indeterminateSpeed;
- }
+ .ui.indeterminate.loader::after {
+ animation-direction: @indeterminateDirection;
+ animation-duration: @indeterminateSpeed;
+ }
}
.ui.loader.active,
.ui.loader.visible {
- display: block;
+ display: block;
}
.ui.loader.disabled,
.ui.loader.hidden {
- display: none;
+ display: none;
}
/*******************************
Variations
*******************************/
-
-/*-------------------
+/* -------------------
Sizes
---------------------*/
+-------------------- */
.ui.loader {
- width: @medium;
- height: @medium;
- font-size: @mediumFontSize;
+ width: @medium;
+ height: @medium;
+ font-size: @mediumFontSize;
}
.ui.loader::before,
.ui.loader::after {
- width: @medium;
- height: @medium;
- margin: @mediumOffset;
+ width: @medium;
+ height: @medium;
+ margin: @mediumOffset;
}
& when (@variationLoaderText) {
- .ui.text.loader {
- min-width: @medium;
- padding-top: (@medium + @textDistance);
- }
+ .ui.text.loader {
+ min-width: @medium;
+ padding-top: (@medium + @textDistance);
+ }
}
& when not (@variationLoaderSizes = false) {
- each(@variationLoaderSizes, {
- @o: @{value}Offset;
- @f: @{value}FontSize;
- @s: @@value;
- .ui.@{value}.loader {
- width: @s;
- height: @s;
- font-size: @@f;
- }
- .ui.@{value}.loader::before,
- .ui.@{value}.loader::after {
- width: @s;
- height: @s;
- margin: @@o;
- }
- & when (@variationLoaderText) {
- .ui.@{value}.text.loader {
- min-width: @s;
- padding-top: (@s + @textDistance);
- }
- }
- })
+ each(@variationLoaderSizes, {
+ @o: @{value}Offset;
+ @f: @{value}FontSize;
+ @s: @@value;
+ .ui.@{value}.loader {
+ width: @s;
+ height: @s;
+ font-size: @@f;
+ }
+ .ui.@{value}.loader::before,
+ .ui.@{value}.loader::after {
+ width: @s;
+ height: @s;
+ margin: @@o;
+ }
+ & when (@variationLoaderText) {
+ .ui.@{value}.text.loader {
+ min-width: @s;
+ padding-top: (@s + @textDistance);
+ }
+ }
+ });
}
-/*-------------------
+/* -------------------
Colors
---------------------*/
+-------------------- */
& when not (@variationLoaderColors = false) {
- each(@variationLoaderColors, {
- @color: @value;
- @c: @colors[@@color][color];
- @l: @colors[@@color][light];
-
- .ui.@{color}.elastic.loader.loader::before,
- .ui.@{color}.basic.elastic.loading.button::before,
- .ui.@{color}.basic.elastic.loading.button::after,
- .ui.@{color}.elastic.loading.loading.loading:not(.segment):not(.segments):not(.card)::before,
- .ui.@{color}.elastic.loading.loading.loading .input > i.icon::before,
- .ui.@{color}.elastic.loading.loading.loading.loading > i.icon::before,
- .ui.@{color}.loading.loading.loading.loading:not(.usual):not(.button)::after,
- .ui.@{color}.loading.loading.loading.loading .input > i.icon::after,
- .ui.@{color}.loading.loading.loading.loading > i.icon::after,
- .ui.@{color}.loader.loader.loader::after {
- color: @c;
- }
- .ui.inverted.@{color}.elastic.loader::before,
- .ui.inverted.@{color}.elastic.loading.loading.loading:not(.segment):not(.segments):not(.card)::before,
- .ui.inverted.@{color}.elastic.loading.loading.loading .input > i.icon::before,
- .ui.inverted.@{color}.elastic.loading.loading.loading > i.icon::before,
- .ui.inverted.@{color}.loading.loading.loading.loading:not(.usual)::after,
- .ui.inverted.@{color}.loading.loading.loading.loading .input > i.icon::after,
- .ui.inverted.@{color}.loading.loading.loading.loading > i.icon::after,
- .ui.inverted.@{color}.loader.loader.loader::after {
- color: @l;
- }
- })
+ each(@variationLoaderColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+ @l: @colors[@@color][light];
+
+ .ui.@{color}.elastic.loader.loader::before,
+ .ui.@{color}.basic.elastic.loading.button::before,
+ .ui.@{color}.basic.elastic.loading.button::after,
+ .ui.@{color}.elastic.loading.loading.loading:not(.segment):not(.segments):not(.card)::before,
+ .ui.@{color}.elastic.loading.loading.loading .input > i.icon::before,
+ .ui.@{color}.elastic.loading.loading.loading.loading > i.icon::before,
+ .ui.@{color}.loading.loading.loading.loading:not(.usual):not(.button)::after,
+ .ui.@{color}.loading.loading.loading.loading .input > i.icon::after,
+ .ui.@{color}.loading.loading.loading.loading > i.icon::after,
+ .ui.@{color}.loader.loader.loader::after {
+ color: @c;
+ }
+ .ui.inverted.@{color}.elastic.loader::before,
+ .ui.inverted.@{color}.elastic.loading.loading.loading:not(.segment):not(.segments):not(.card)::before,
+ .ui.inverted.@{color}.elastic.loading.loading.loading .input > i.icon::before,
+ .ui.inverted.@{color}.elastic.loading.loading.loading > i.icon::before,
+ .ui.inverted.@{color}.loading.loading.loading.loading:not(.usual)::after,
+ .ui.inverted.@{color}.loading.loading.loading.loading .input > i.icon::after,
+ .ui.inverted.@{color}.loading.loading.loading.loading > i.icon::after,
+ .ui.inverted.@{color}.loader.loader.loader::after {
+ color: @l;
+ }
+ });
}
.ui.elastic.loader.loader::before,
@@ -242,180 +237,190 @@
.ui.loading.loading.loading.loading .input > i.icon::after,
.ui.loading.loading.loading.loading > i.icon::after,
.ui.loader.loader.loader::after {
- border-color: currentColor;
+ border-color: currentColor;
}
.ui.elastic.loading.loading.loading.loading.button:not(.inverted):not(.basic)::before {
- color: @invertedLoaderLineColor;
+ color: @invertedLoaderLineColor;
}
.ui.elastic.basic.loading.button::before,
.ui.elastic.basic.loading.button::after {
- color: @loaderLineColor;
+ color: @loaderLineColor;
}
.ui.double.loading.loading.loading.loading.button::after {
- border-bottom-color: currentColor;
+ border-bottom-color: currentColor;
}
& when (@variationLoaderInline) {
- /*-------------------
- Inline
- --------------------*/
-
- .ui.inline.loader {
- position: relative;
- vertical-align: @inlineVerticalAlign;
- margin: @inlineMargin;
- left: 0;
- top: 0;
- transform: none;
- }
+ /* -------------------
+ Inline
+ -------------------- */
+
+ .ui.inline.loader {
+ position: relative;
+ vertical-align: @inlineVerticalAlign;
+ margin: @inlineMargin;
+ left: 0;
+ top: 0;
+ transform: none;
+ }
- .ui.inline.loader.active,
- .ui.inline.loader.visible {
- display: inline-block;
- }
+ .ui.inline.loader.active,
+ .ui.inline.loader.visible {
+ display: inline-block;
+ }
- /* Centered Inline */
- .ui.centered.inline.loader.active,
- .ui.centered.inline.loader.visible {
- display: block;
- margin-left: auto;
- margin-right: auto;
- }
+ /* Centered Inline */
+ .ui.centered.inline.loader.active,
+ .ui.centered.inline.loader.visible {
+ display: block;
+ margin-left: auto;
+ margin-right: auto;
+ }
}
.ui.loading.loading.loading.loading.loading.loading::after,
.ui.loading.loading.loading.loading.loading.loading .input > i.icon::after,
.ui.loading.loading.loading.loading.loading.loading > i.icon::after,
.ui.loader.loader.loader.loader.loader::after {
- border-left-color:transparent;
- border-right-color:transparent;
+ border-left-color: transparent;
+ border-right-color: transparent;
}
.ui.loading.loading.loading.loading.loading.loading.loading:not(.double)::after,
.ui.loading.loading.loading.loading.loading.loading.loading:not(.double) .input > i.icon::after,
.ui.loading.loading.loading.loading.loading.loading.loading:not(.double) > i.icon::after,
.ui.loader.loader.loader.loader.loader.loader:not(.double)::after {
- border-bottom-color: transparent;
+ border-bottom-color: transparent;
}
.ui.loading.loading.loading.loading.loading.loading.card::after,
.ui.loading.loading.loading.loading.loading.loading.segments::after,
.ui.loading.loading.loading.loading.loading.loading.segment::after,
.ui.loading.loading.loading.loading.loading.loading.form::after {
- border-left-color:@loaderFillColor;
- border-right-color:@loaderFillColor;
+ border-left-color: @loaderFillColor;
+ border-right-color: @loaderFillColor;
}
.ui.loading.loading.loading.loading.loading.loading.card:not(.double)::after,
.ui.loading.loading.loading.loading.loading.loading.segments:not(.double)::after,
.ui.loading.loading.loading.loading.loading.loading.segment:not(.double)::after,
.ui.loading.loading.loading.loading.loading.loading.form:not(.double)::after {
- border-bottom-color: @loaderFillColor;
+ border-bottom-color: @loaderFillColor;
}
& when (@variationLoaderElastic) {
- /*-------------------
- Elastic
- --------------------*/
+ /* -------------------
+ Elastic
+ -------------------- */
- .ui.dimmer > .ui.elastic.loader {
- color: @invertedLoaderLineColor;
- }
- .ui.inverted.dimmer > .ui.elastic.loader {
- color: @loaderLineColor;
- }
- .ui.elastic.loading.loading:not(.form):not(.segment):not(.segments):not(.card)::after,
- .ui.elastic.loading.loading .input > i.icon::after,
- .ui.elastic.loading.loading > i.icon::after,
- .ui.elastic.loader.loader::after {
- animation: loader 1s infinite cubic-bezier(.27, 1.05, .92, .61);
- animation-delay: 0.3s;
- }
- .ui.elastic.loading.loading.loading:not(.form):not(.segment):not(.segments):not(.card)::before,
- .ui.elastic.loading.loading.loading .input > i.icon::before,
- .ui.elastic.loading.loading.loading > i.icon::before,
- .ui.elastic.loader.loader::before {
- animation: elastic-loader 1s infinite cubic-bezier(.27, 1.05, .92, .61);
- -moz-animation: currentcolor-elastic-loader 1s infinite cubic-bezier(.27, 1.05, .92, .61);
- border-right-color: transparent;
- }
- & when (@variationLoaderInline) {
- .ui.elastic.inline.loader:empty {
- animation: loader 8s infinite linear;
+ .ui.dimmer > .ui.elastic.loader {
+ color: @invertedLoaderLineColor;
}
- }
- & when (@variationLoaderSpeeds) {
- .ui.slow.elastic.loading.loading:not(.form):not(.segment):not(.segments):not(.card)::after,
- .ui.slow.elastic.loading.loading .input > i.icon::after,
- .ui.slow.elastic.loading.loading > i.icon::after,
- .ui.slow.elastic.loader.loader::after {
- animation-duration: 1.5s;
- animation-delay: 0.45s;
+ .ui.inverted.dimmer > .ui.elastic.loader {
+ color: @loaderLineColor;
}
- .ui.slow.elastic.loading.loading.loading:not(.form):not(.segment):not(.segments):not(.card)::before,
- .ui.slow.elastic.loading.loading.loading .input > i.icon::before,
- .ui.slow.elastic.loading.loading.loading > i.icon::before,
- .ui.slow.elastic.loader.loader::before {
- animation-duration: 1.5s;
+ .ui.elastic.loading.loading:not(.form):not(.segment):not(.segments):not(.card)::after,
+ .ui.elastic.loading.loading .input > i.icon::after,
+ .ui.elastic.loading.loading > i.icon::after,
+ .ui.elastic.loader.loader::after {
+ animation: loader 1s infinite cubic-bezier(0.27, 1.05, 0.92, 0.61);
+ animation-delay: 0.3s;
}
- .ui.fast.elastic.loading.loading:not(.form):not(.segment):not(.segments):not(.card)::after,
- .ui.fast.elastic.loading.loading .input > i.icon::after,
- .ui.fast.elastic.loading.loading > i.icon::after,
- .ui.fast.elastic.loader.loader::after {
- animation-duration: 0.66s;
- animation-delay: 0.20s;
+ .ui.elastic.loading.loading.loading:not(.form):not(.segment):not(.segments):not(.card)::before,
+ .ui.elastic.loading.loading.loading .input > i.icon::before,
+ .ui.elastic.loading.loading.loading > i.icon::before,
+ .ui.elastic.loader.loader::before {
+ animation: elastic-loader 1s infinite cubic-bezier(0.27, 1.05, 0.92, 0.61);
+ // https://github.com/fomantic/Fomantic-UI/pull/363
+ // stylelint-disable-next-line property-no-vendor-prefix
+ -moz-animation: currentcolor-elastic-loader 1s infinite cubic-bezier(0.27, 1.05, 0.92, 0.61);
+ border-right-color: transparent;
}
- .ui.fast.elastic.loading.loading.loading:not(.form):not(.segment):not(.segments):not(.card)::before,
- .ui.fast.elastic.loading.loading.loading .input > i.icon::before,
- .ui.fast.elastic.loading.loading.loading > i.icon::before,
- .ui.fast.elastic.loader.loader::before {
- animation-duration: 0.66s;
+ & when (@variationLoaderInline) {
+ .ui.elastic.inline.loader:empty {
+ animation: loader 8s infinite linear;
+ }
}
- }
- @keyframes elastic-loader {
- 0%, 1% {
- border-left-color: transparent;
- border-bottom-color: transparent
+ & when (@variationLoaderSpeeds) {
+ .ui.slow.elastic.loading.loading:not(.form):not(.segment):not(.segments):not(.card)::after,
+ .ui.slow.elastic.loading.loading .input > i.icon::after,
+ .ui.slow.elastic.loading.loading > i.icon::after,
+ .ui.slow.elastic.loader.loader::after {
+ animation-duration: 1.5s;
+ animation-delay: 0.45s;
+ }
+ .ui.slow.elastic.loading.loading.loading:not(.form):not(.segment):not(.segments):not(.card)::before,
+ .ui.slow.elastic.loading.loading.loading .input > i.icon::before,
+ .ui.slow.elastic.loading.loading.loading > i.icon::before,
+ .ui.slow.elastic.loader.loader::before {
+ animation-duration: 1.5s;
+ }
+ .ui.fast.elastic.loading.loading:not(.form):not(.segment):not(.segments):not(.card)::after,
+ .ui.fast.elastic.loading.loading .input > i.icon::after,
+ .ui.fast.elastic.loading.loading > i.icon::after,
+ .ui.fast.elastic.loader.loader::after {
+ animation-duration: 0.66s;
+ animation-delay: 0.2s;
+ }
+ .ui.fast.elastic.loading.loading.loading:not(.form):not(.segment):not(.segments):not(.card)::before,
+ .ui.fast.elastic.loading.loading.loading .input > i.icon::before,
+ .ui.fast.elastic.loading.loading.loading > i.icon::before,
+ .ui.fast.elastic.loader.loader::before {
+ animation-duration: 0.66s;
+ }
}
- 1.1%, 50% {
- border-left-color: inherit;
+ @keyframes elastic-loader {
+ 0%,
+ 1% {
+ border-left-color: transparent;
+ border-bottom-color: transparent;
+ }
+ 1.1%,
+ 50% {
+ border-left-color: inherit;
+ }
+ 10%,
+ 35.1% {
+ border-bottom-color: transparent;
+ }
+ 10.1%,
+ 35% {
+ border-bottom-color: inherit;
+ }
+ 50.1% {
+ border-left-color: transparent;
+ }
+ 100% {
+ border-left-color: transparent;
+ border-bottom-color: transparent;
+ transform: rotate(360deg);
+ }
}
- 10%, 35.1%{
- border-bottom-color: transparent;
- }
- 10.1%, 35%{
- border-bottom-color: inherit;
- }
- 50.1%{
- border-left-color: transparent;
- }
- 100% {
- border-left-color: transparent;
- border-bottom-color: transparent;
- transform: rotate(360deg);
- }
- }
- @keyframes currentcolor-elastic-loader {
- 0%, 1% {
- border-left-color: transparent;
- border-bottom-color: transparent
- }
- 1.1%, 50% {
- border-left-color: currentColor;
- }
- 10%, 35.1%{
- border-bottom-color: transparent;
- }
- 10.1%, 35%{
- border-bottom-color: currentColor;
- }
- 50.1%{
- border-left-color: transparent;
- }
- 100% {
- border-left-color: transparent;
- border-bottom-color: transparent;
- transform: rotate(360deg);
+ @keyframes currentcolor-elastic-loader {
+ 0%,
+ 1% {
+ border-left-color: transparent;
+ border-bottom-color: transparent;
+ }
+ 1.1%,
+ 50% {
+ border-left-color: currentColor;
+ }
+ 10%,
+ 35.1% {
+ border-bottom-color: transparent;
+ }
+ 10.1%,
+ 35% {
+ border-bottom-color: currentColor;
+ }
+ 50.1% {
+ border-left-color: transparent;
+ }
+ 100% {
+ border-left-color: transparent;
+ border-bottom-color: transparent;
+ transform: rotate(360deg);
+ }
}
- }
}
.loadUIOverrides();
diff --git a/definitions/elements/placeholder.less b/definitions/elements/placeholder.less
index ea95a66..5695579 100644
--- a/definitions/elements/placeholder.less
+++ b/definitions/elements/placeholder.less
@@ -1,59 +1,60 @@
/*!
* # Fomantic-UI - Loader
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
+
/*******************************
Theme
*******************************/
-@type : 'element';
-@element : 'placeholder';
+@type: "element";
+@element: "placeholder";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
-/*-------------------
+/* -------------------
Content
---------------------*/
+-------------------- */
.ui.placeholder {
- position: static;
- overflow: hidden;
- animation: placeholderShimmer @placeholderLoadingAnimationDuration linear;
- animation-iteration-count: infinite;
- background-color: @white;
- background-image: @placeholderLoadingGradient;
- background-size: @placeholderLoadingGradientWidth 100%;
- max-width: @placeholderMaxWidth;
+ position: static;
+ overflow: hidden;
+ animation: placeholderShimmer @placeholderLoadingAnimationDuration linear;
+ animation-iteration-count: infinite;
+ background-color: @white;
+ background-image: @placeholderLoadingGradient;
+ background-size: @placeholderLoadingGradientWidth 100%;
+ max-width: @placeholderMaxWidth;
}
-@keyframes placeholderShimmer{
- 0% {
- background-position: -@placeholderLoadingGradientWidth 0
- }
- 100% {
- background-position: @placeholderLoadingGradientWidth 0
- }
+@keyframes placeholderShimmer {
+ 0% {
+ background-position: -@placeholderLoadingGradientWidth 0;
+ }
+ 100% {
+ background-position: @placeholderLoadingGradientWidth 0;
+ }
}
.ui.placeholder + .ui.placeholder {
- margin-top: @consecutivePlaceholderSpacing;
+ margin-top: @consecutivePlaceholderSpacing;
}
.ui.placeholder + .ui.placeholder {
- animation-delay: @placeholderAnimationInterval;
+ animation-delay: @placeholderAnimationInterval;
}
.ui.placeholder + .ui.placeholder + .ui.placeholder {
- animation-delay: (@placeholderAnimationInterval * 2);
+ animation-delay: (@placeholderAnimationInterval * 2);
}
.ui.placeholder + .ui.placeholder + .ui.placeholder + .ui.placeholder {
- animation-delay: (@placeholderAnimationInterval * 3);
+ animation-delay: (@placeholderAnimationInterval * 3);
}
.ui.placeholder + .ui.placeholder + .ui.placeholder + .ui.placeholder + .ui.placeholder {
- animation-delay: (@placeholderAnimationInterval * 4);
+ animation-delay: (@placeholderAnimationInterval * 4);
}
.ui.placeholder,
@@ -61,188 +62,190 @@
.ui.placeholder .image.header::after,
.ui.placeholder .line,
.ui.placeholder .line::after {
- background-color: @white;
+ background-color: @white;
}
.ui.placeholder.hidden {
- display:none;
+ display: none;
}
& when (@variationPlaceholderImage) {
- /* Image */
- .ui.placeholder .image:not(.header):not(.ui):not(.icon) {
- height: @placeholderImageHeight;
- }
- .ui.placeholder .square.image:not(.header) {
- height: 0;
- overflow: hidden;
- /* 1/1 aspect ratio */
- padding-top: 100%;
- }
- .ui.placeholder .rectangular.image:not(.header) {
- height: 0;
- overflow: hidden;
- /* 4/3 aspect ratio */
- padding-top: 75%;
- }
+ /* Image */
+ .ui.placeholder .image:not(.header):not(.ui):not(.icon) {
+ height: @placeholderImageHeight;
+ }
+ .ui.placeholder .square.image:not(.header) {
+ height: 0;
+ overflow: hidden;
+
+ /* 1/1 aspect ratio */
+ padding-top: 100%;
+ }
+ .ui.placeholder .rectangular.image:not(.header) {
+ height: 0;
+ overflow: hidden;
+
+ /* 4/3 aspect ratio */
+ padding-top: 75%;
+ }
}
& when (@variationPlaceholderLine) or (@variationPlaceholderHeader) {
- /* Lines */
- .ui.placeholder .line {
- position: relative;
- height: @placeholderLineMargin;
- }
- .ui.placeholder .line::before,
- .ui.placeholder .line::after {
- top: 100%;
- position: absolute;
- content: '';
- background-color: inherit;
- }
- .ui.placeholder .line::before {
- left: 0;
- }
- .ui.placeholder .line::after {
- right: 0;
- }
-
- /* Any Lines */
- .ui.placeholder .line {
- margin-bottom: @placeholderLineHeight;
- }
- .ui.placeholder .line::before,
- .ui.placeholder .line::after {
- height: @placeholderLineHeight;
- }
- .ui.placeholder .line:not(:first-child) {
- margin-top: @placeholderLineHeight;
- }
-
- /* Line Outdent */
- .ui.placeholder .line:nth-child(1)::after {
- width: @placeholderLineOneOutdent;
- }
- .ui.placeholder .line:nth-child(2)::after {
- width: @placeholderLineTwoOutdent;
- }
- .ui.placeholder .line:nth-child(3)::after {
- width: @placeholderLineThreeOutdent;
- }
- .ui.placeholder .line:nth-child(4)::after {
- width: @placeholderLineFourOutdent;
- }
- .ui.placeholder .line:nth-child(5)::after {
- width: @placeholderLineFiveOutdent;
- }
+ /* Lines */
+ .ui.placeholder .line {
+ position: relative;
+ height: @placeholderLineMargin;
+ }
+ .ui.placeholder .line::before,
+ .ui.placeholder .line::after {
+ top: 100%;
+ position: absolute;
+ content: "";
+ background-color: inherit;
+ }
+ .ui.placeholder .line::before {
+ left: 0;
+ }
+ .ui.placeholder .line::after {
+ right: 0;
+ }
+
+ /* Any Lines */
+ .ui.placeholder .line {
+ margin-bottom: @placeholderLineHeight;
+ }
+ .ui.placeholder .line::before,
+ .ui.placeholder .line::after {
+ height: @placeholderLineHeight;
+ }
+ .ui.placeholder .line:not(:first-child) {
+ margin-top: @placeholderLineHeight;
+ }
+
+ /* Line Outdent */
+ .ui.placeholder .line:nth-child(1)::after {
+ width: @placeholderLineOneOutdent;
+ }
+ .ui.placeholder .line:nth-child(2)::after {
+ width: @placeholderLineTwoOutdent;
+ }
+ .ui.placeholder .line:nth-child(3)::after {
+ width: @placeholderLineThreeOutdent;
+ }
+ .ui.placeholder .line:nth-child(4)::after {
+ width: @placeholderLineFourOutdent;
+ }
+ .ui.placeholder .line:nth-child(5)::after {
+ width: @placeholderLineFiveOutdent;
+ }
}
& when (@variationPlaceholderHeader) {
- /* Header Image + 2 Lines */
- .ui.placeholder .header {
- position: relative;
- overflow: hidden;
- }
- /* Header Line 1 & 2*/
- .ui.placeholder .header .line {
- margin-bottom: @placeholderHeaderLineHeight;
- }
- .ui.placeholder .header .line::before,
- .ui.placeholder .header .line::after {
- height: @placeholderHeaderLineHeight;
- }
- .ui.placeholder .header .line:not(:first-child) {
- margin-top: @placeholderHeaderLineHeight;
- }
- .ui.placeholder .header .line::after {
- width: @placeholderHeaderLineOneOutdent;
- }
- .ui.placeholder .header .line:nth-child(2)::after {
- width: @placeholderHeaderLineTwoOutdent;
- }
-
- & when (@variationPlaceholderImage) {
- /* Image Header */
- .ui.placeholder .image.header .line {
- margin-left: @placeholderImageWidth;
- }
- .ui.placeholder .image.header .line::before {
- width: @placeholderImageTextIndent;
- }
- .ui.placeholder .image.header::after {
- display: block;
- height: @placeholderLineMargin;
- content: '';
- margin-left: @placeholderImageWidth;
- }
- }
+ /* Header Image + 2 Lines */
+ .ui.placeholder .header {
+ position: relative;
+ overflow: hidden;
+ }
+
+ /* Header Line 1 & 2 */
+ .ui.placeholder .header .line {
+ margin-bottom: @placeholderHeaderLineHeight;
+ }
+ .ui.placeholder .header .line::before,
+ .ui.placeholder .header .line::after {
+ height: @placeholderHeaderLineHeight;
+ }
+ .ui.placeholder .header .line:not(:first-child) {
+ margin-top: @placeholderHeaderLineHeight;
+ }
+ .ui.placeholder .header .line::after {
+ width: @placeholderHeaderLineOneOutdent;
+ }
+ .ui.placeholder .header .line:nth-child(2)::after {
+ width: @placeholderHeaderLineTwoOutdent;
+ }
+
+ & when (@variationPlaceholderImage) {
+ /* Image Header */
+ .ui.placeholder .image.header .line {
+ margin-left: @placeholderImageWidth;
+ }
+ .ui.placeholder .image.header .line::before {
+ width: @placeholderImageTextIndent;
+ }
+ .ui.placeholder .image.header::after {
+ display: block;
+ height: @placeholderLineMargin;
+ content: "";
+ margin-left: @placeholderImageWidth;
+ }
+ }
}
/* Spacing */
.ui.placeholder .image .line:first-child,
.ui.placeholder .paragraph .line:first-child,
.ui.placeholder .header .line:first-child {
- height: 0.01px;
+ height: 0.01px;
}
.ui.placeholder .image:not(:first-child)::before,
.ui.placeholder .paragraph:not(:first-child)::before,
.ui.placeholder .header:not(:first-child)::before {
- height: @placeholderSpacing;
- content: '';
- display: block;
+ height: @placeholderSpacing;
+ content: "";
+ display: block;
}
& when (@variationPlaceholderInverted) {
- /* Inverted Content Loader */
- .ui.inverted.placeholder {
- background-image: @placeholderInvertedLoadingGradient;
- }
- .ui.inverted.placeholder,
- .ui.inverted.placeholder > ::before,
- .ui.inverted.placeholder .image.header::after,
- .ui.inverted.placeholder .line,
- .ui.inverted.placeholder .line::after {
- background-color: @black;
- }
+ /* Inverted Content Loader */
+ .ui.inverted.placeholder {
+ background-image: @placeholderInvertedLoadingGradient;
+ }
+ .ui.inverted.placeholder,
+ .ui.inverted.placeholder > ::before,
+ .ui.inverted.placeholder .image.header::after,
+ .ui.inverted.placeholder .line,
+ .ui.inverted.placeholder .line::after {
+ background-color: @black;
+ }
}
/*******************************
Variations
*******************************/
-
-/*-------------------
+/* -------------------
Sizes
---------------------*/
+-------------------- */
& when (@variationPlaceholderLengths) {
- .ui.placeholder .full.line.line.line::after {
- width: @placeholderFullLineOutdent;
- }
- .ui.placeholder .very.long.line.line.line::after {
- width: @placeholderVeryLongLineOutdent;
- }
- .ui.placeholder .long.line.line.line::after {
- width: @placeholderLongLineOutdent;
- }
- .ui.placeholder .medium.line.line.line::after {
- width: @placeholderMediumLineOutdent;
- }
- .ui.placeholder .short.line.line.line::after {
- width: @placeholderShortLineOutdent;
- }
- .ui.placeholder .very.short.line.line.line::after {
- width: @placeholderVeryShortLineOutdent;
- }
+ .ui.placeholder .full.line.line.line::after {
+ width: @placeholderFullLineOutdent;
+ }
+ .ui.placeholder .very.long.line.line.line::after {
+ width: @placeholderVeryLongLineOutdent;
+ }
+ .ui.placeholder .long.line.line.line::after {
+ width: @placeholderLongLineOutdent;
+ }
+ .ui.placeholder .medium.line.line.line::after {
+ width: @placeholderMediumLineOutdent;
+ }
+ .ui.placeholder .short.line.line.line::after {
+ width: @placeholderShortLineOutdent;
+ }
+ .ui.placeholder .very.short.line.line.line::after {
+ width: @placeholderVeryShortLineOutdent;
+ }
}
& when (@variationPlaceholderFluid) {
- /*-------------------
- Fluid
- --------------------*/
+ /* -------------------
+ Fluid
+ -------------------- */
- .ui.fluid.placeholder {
- max-width: none;
- }
+ .ui.fluid.placeholder {
+ max-width: none;
+ }
}
.loadUIOverrides();
diff --git a/definitions/elements/rail.less b/definitions/elements/rail.less
index d7ffc51..b81ecb0 100644
--- a/definitions/elements/rail.less
+++ b/definitions/elements/rail.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Rail
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,34 +12,34 @@
Theme
*******************************/
-@type : 'element';
-@element : 'rail';
+@type: "element";
+@element: "rail";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Rails
*******************************/
.ui.rail {
- position: absolute;
- top: 0;
- width: @width;
- height: @height;
+ position: absolute;
+ top: 0;
+ width: @width;
+ height: @height;
}
.ui.left.rail {
- left: auto;
- right: 100%;
- padding: 0 @splitDistance 0 0;
- margin: 0 @splitDistance 0 0;
+ left: auto;
+ right: 100%;
+ padding: 0 @splitDistance 0 0;
+ margin: 0 @splitDistance 0 0;
}
.ui.right.rail {
- left: 100%;
- right: auto;
- padding: 0 0 0 @splitDistance;
- margin: 0 0 0 @splitDistance;
+ left: 100%;
+ right: auto;
+ padding: 0 0 0 @splitDistance;
+ margin: 0 0 0 @splitDistance;
}
/*******************************
@@ -47,101 +47,101 @@
*******************************/
& when (@variationRailInternal) {
- /*--------------
- Internal
- ---------------*/
-
- .ui.left.internal.rail {
- left: 0;
- right: auto;
- padding: 0 0 0 @splitDistance;
- margin: 0 0 0 @splitDistance;
- }
+ /* --------------
+ Internal
+ --------------- */
+
+ .ui.left.internal.rail {
+ left: 0;
+ right: auto;
+ padding: 0 0 0 @splitDistance;
+ margin: 0 0 0 @splitDistance;
+ }
- .ui.right.internal.rail {
- left: auto;
- right: 0;
- padding: 0 @splitDistance 0 0;
- margin: 0 @splitDistance 0 0;
- }
+ .ui.right.internal.rail {
+ left: auto;
+ right: 0;
+ padding: 0 @splitDistance 0 0;
+ margin: 0 @splitDistance 0 0;
+ }
}
& when (@variationRailDividing) {
- /*--------------
- Dividing
- ---------------*/
-
- .ui.dividing.rail {
- width: @dividingWidth;
- }
- .ui.left.dividing.rail {
- padding: 0 @splitDividingDistance 0 0;
- margin: 0 @splitDividingDistance 0 0;
- border-right: @dividingBorder;
- }
- .ui.right.dividing.rail {
- border-left: @dividingBorder;
- padding: 0 0 0 @splitDividingDistance;
- margin: 0 0 0 @splitDividingDistance;
- }
+ /* --------------
+ Dividing
+ --------------- */
+
+ .ui.dividing.rail {
+ width: @dividingWidth;
+ }
+ .ui.left.dividing.rail {
+ padding: 0 @splitDividingDistance 0 0;
+ margin: 0 @splitDividingDistance 0 0;
+ border-right: @dividingBorder;
+ }
+ .ui.right.dividing.rail {
+ border-left: @dividingBorder;
+ padding: 0 0 0 @splitDividingDistance;
+ margin: 0 0 0 @splitDividingDistance;
+ }
}
& when (@variationRailDistance) {
- /*--------------
- Distance
- ---------------*/
-
- .ui.close.rail {
- width: @closeWidth;
- }
- .ui.close.left.rail {
- padding: 0 @splitCloseDistance 0 0;
- margin: 0 @splitCloseDistance 0 0;
- }
- .ui.close.right.rail {
- padding: 0 0 0 @splitCloseDistance;
- margin: 0 0 0 @splitCloseDistance;
- }
-
- .ui.very.close.rail {
- width: @veryCloseWidth;
- }
- .ui.very.close.left.rail {
- padding: 0 @splitVeryCloseDistance 0 0;
- margin: 0 @splitVeryCloseDistance 0 0;
- }
- .ui.very.close.right.rail {
- padding: 0 0 0 @splitVeryCloseDistance;
- margin: 0 0 0 @splitVeryCloseDistance;
- }
+ /* --------------
+ Distance
+ --------------- */
+
+ .ui.close.rail {
+ width: @closeWidth;
+ }
+ .ui.close.left.rail {
+ padding: 0 @splitCloseDistance 0 0;
+ margin: 0 @splitCloseDistance 0 0;
+ }
+ .ui.close.right.rail {
+ padding: 0 0 0 @splitCloseDistance;
+ margin: 0 0 0 @splitCloseDistance;
+ }
+
+ .ui.very.close.rail {
+ width: @veryCloseWidth;
+ }
+ .ui.very.close.left.rail {
+ padding: 0 @splitVeryCloseDistance 0 0;
+ margin: 0 @splitVeryCloseDistance 0 0;
+ }
+ .ui.very.close.right.rail {
+ padding: 0 0 0 @splitVeryCloseDistance;
+ margin: 0 0 0 @splitVeryCloseDistance;
+ }
}
& when (@variationRailAttached) {
- /*--------------
- Attached
- ---------------*/
-
- .ui.attached.left.rail,
- .ui.attached.right.rail {
- padding: 0;
- margin: 0;
- }
+ /* --------------
+ Attached
+ --------------- */
+
+ .ui.attached.left.rail,
+ .ui.attached.right.rail {
+ padding: 0;
+ margin: 0;
+ }
}
-/*--------------
+/* --------------
Sizing
----------------*/
+--------------- */
.ui.rail {
- font-size: @medium;
+ font-size: @medium;
}
& when not (@variationRailSizes = false) {
- each(@variationRailSizes, {
- @s: @@value;
- .ui.@{value}.rail {
- font-size: @s;
- }
- })
+ each(@variationRailSizes, {
+ @s: @@value;
+ .ui.@{value}.rail {
+ font-size: @s;
+ }
+ });
}
.loadUIOverrides();
diff --git a/definitions/elements/reveal.less b/definitions/elements/reveal.less
index 839668e..366cad0 100644
--- a/definitions/elements/reveal.less
+++ b/definitions/elements/reveal.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Reveal
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,212 +12,208 @@
Theme
*******************************/
-@type : 'element';
-@element : 'reveal';
+@type: "element";
+@element: "reveal";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Reveal
*******************************/
-.ui.reveal {
- display: inherit;
- position: relative !important;
- font-size: 0;
+.ui.reveal {
+ display: inherit;
+ position: relative !important;
+ font-size: 0;
}
.ui.reveal > .visible.content {
- position: absolute !important;
- top: 0 !important;
- left: 0 !important;
- z-index: @topZIndex !important;
- transition: @transition;
+ position: absolute !important;
+ top: 0 !important;
+ left: 0 !important;
+ z-index: @topZIndex !important;
+ transition: @transition;
}
.ui.reveal > .hidden.content {
- position: relative !important;
- z-index: @bottomZIndex !important;
+ position: relative !important;
+ z-index: @bottomZIndex !important;
}
/* Make sure hovered element is on top of other reveal */
.ui.active.reveal .visible.content,
.ui.reveal:hover .visible.content {
- z-index: @activeZIndex !important;
+ z-index: @activeZIndex !important;
}
-
/*******************************
Types
*******************************/
& when (@variationRevealSlide) {
- /*--------------
- Slide
- ---------------*/
+ /* --------------
+ Slide
+ --------------- */
+
+ .ui.slide.reveal {
+ position: relative !important;
+ overflow: hidden !important;
+ white-space: nowrap;
+ }
- .ui.slide.reveal {
- position: relative !important;
- overflow: hidden !important;
- white-space: nowrap;
- }
+ .ui.slide.reveal > .content {
+ display: block;
+ width: 100%;
+ white-space: normal;
+ float: left;
+ margin: 0;
+ transition: @slideTransition;
+ }
- .ui.slide.reveal > .content {
- display: block;
- width: 100%;
- white-space: normal;
- float: left;
+ .ui.slide.reveal > .visible.content {
+ position: relative !important;
+ }
+ .ui.slide.reveal > .hidden.content {
+ position: absolute !important;
+ left: 0 !important;
+ width: 100% !important;
+ transform: translateX(100%) !important;
+ }
+ .ui.slide.active.reveal > .visible.content,
+ .ui.slide.reveal:hover > .visible.content {
+ transform: translateX(-100%) !important;
+ }
+ .ui.slide.active.reveal > .hidden.content,
+ .ui.slide.reveal:hover > .hidden.content {
+ transform: translateX(0) !important;
+ }
- margin: 0;
- transition: @slideTransition;
- }
+ .ui.slide.right.reveal > .visible.content {
+ transform: translateX(0) !important;
+ }
+ .ui.slide.right.reveal > .hidden.content {
+ transform: translateX(-100%) !important;
+ }
+ .ui.slide.right.active.reveal > .visible.content,
+ .ui.slide.right.reveal:hover > .visible.content {
+ transform: translateX(100%) !important;
+ }
+ .ui.slide.right.active.reveal > .hidden.content,
+ .ui.slide.right.reveal:hover > .hidden.content {
+ transform: translateX(0) !important;
+ }
- .ui.slide.reveal > .visible.content {
- position: relative !important;
- }
- .ui.slide.reveal > .hidden.content {
- position: absolute !important;
- left: 0 !important;
- width: 100% !important;
- transform: translateX(100%) !important;
- }
- .ui.slide.active.reveal > .visible.content,
- .ui.slide.reveal:hover > .visible.content {
- transform: translateX(-100%) !important;
- }
- .ui.slide.active.reveal > .hidden.content,
- .ui.slide.reveal:hover > .hidden.content {
- transform: translateX(0%) !important;
- }
-
- .ui.slide.right.reveal > .visible.content {
- transform: translateX(0%) !important;
- }
- .ui.slide.right.reveal > .hidden.content {
- transform: translateX(-100%) !important;
- }
- .ui.slide.right.active.reveal > .visible.content,
- .ui.slide.right.reveal:hover > .visible.content {
- transform: translateX(100%) !important;
- }
- .ui.slide.right.active.reveal > .hidden.content,
- .ui.slide.right.reveal:hover > .hidden.content {
- transform: translateX(0%) !important;
- }
-
- .ui.slide.up.reveal > .hidden.content {
- transform: translateY(100%) !important;
- }
- .ui.slide.up.active.reveal > .visible.content,
- .ui.slide.up.reveal:hover > .visible.content {
- transform: translateY(-100%) !important;
- }
- .ui.slide.up.active.reveal > .hidden.content,
- .ui.slide.up.reveal:hover > .hidden.content {
- transform: translateY(0%) !important;
- }
-
- .ui.slide.down.reveal > .hidden.content {
- transform: translateY(-100%) !important;
- }
- .ui.slide.down.active.reveal > .visible.content,
- .ui.slide.down.reveal:hover > .visible.content {
- transform: translateY(100%) !important;
- }
- .ui.slide.down.active.reveal > .hidden.content,
- .ui.slide.down.reveal:hover > .hidden.content {
- transform: translateY(0%) !important;
- }
+ .ui.slide.up.reveal > .hidden.content {
+ transform: translateY(100%) !important;
+ }
+ .ui.slide.up.active.reveal > .visible.content,
+ .ui.slide.up.reveal:hover > .visible.content {
+ transform: translateY(-100%) !important;
+ }
+ .ui.slide.up.active.reveal > .hidden.content,
+ .ui.slide.up.reveal:hover > .hidden.content {
+ transform: translateY(0) !important;
+ }
+
+ .ui.slide.down.reveal > .hidden.content {
+ transform: translateY(-100%) !important;
+ }
+ .ui.slide.down.active.reveal > .visible.content,
+ .ui.slide.down.reveal:hover > .visible.content {
+ transform: translateY(100%) !important;
+ }
+ .ui.slide.down.active.reveal > .hidden.content,
+ .ui.slide.down.reveal:hover > .hidden.content {
+ transform: translateY(0) !important;
+ }
}
& when (@variationRevealFade) {
- /*--------------
- Fade
- ---------------*/
-
- .ui.fade.reveal > .visible.content {
- opacity: 1;
- }
- .ui.fade.active.reveal > .visible.content,
- .ui.fade.reveal:hover > .visible.content {
- opacity: 0;
- }
+ /* --------------
+ Fade
+ --------------- */
+
+ .ui.fade.reveal > .visible.content {
+ opacity: 1;
+ }
+ .ui.fade.active.reveal > .visible.content,
+ .ui.fade.reveal:hover > .visible.content {
+ opacity: 0;
+ }
}
& when (@variationRevealMove) {
- /*--------------
- Move
- ---------------*/
+ /* --------------
+ Move
+ --------------- */
+
+ .ui.move.reveal {
+ position: relative !important;
+ overflow: hidden !important;
+ white-space: nowrap;
+ }
- .ui.move.reveal {
- position: relative !important;
- overflow: hidden !important;
- white-space: nowrap;
- }
+ .ui.move.reveal > .content {
+ display: block;
+ float: left;
+ white-space: normal;
+ margin: 0;
+ transition: @moveTransition;
+ }
- .ui.move.reveal > .content {
- display: block;
- float: left;
- white-space: normal;
+ .ui.move.reveal > .visible.content {
+ position: relative !important;
+ }
+ .ui.move.reveal > .hidden.content {
+ position: absolute !important;
+ left: 0 !important;
+ width: 100% !important;
+ }
+ .ui.move.active.reveal > .visible.content,
+ .ui.move.reveal:hover > .visible.content {
+ transform: translateX(-100%) !important;
+ }
+ .ui.move.right.active.reveal > .visible.content,
+ .ui.move.right.reveal:hover > .visible.content {
+ transform: translateX(100%) !important;
+ }
+ .ui.move.up.active.reveal > .visible.content,
+ .ui.move.up.reveal:hover > .visible.content {
+ transform: translateY(-100%) !important;
+ }
+ .ui.move.down.active.reveal > .visible.content,
+ .ui.move.down.reveal:hover > .visible.content {
+ transform: translateY(100%) !important;
+ }
+}
- margin: 0;
- transition: @moveTransition;
- }
+& when (@variationRevealRotate) {
+ /* --------------
+ Rotate
+ --------------- */
- .ui.move.reveal > .visible.content {
- position: relative !important;
- }
- .ui.move.reveal > .hidden.content {
- position: absolute !important;
- left: 0 !important;
- width: 100% !important;
- }
- .ui.move.active.reveal > .visible.content,
- .ui.move.reveal:hover > .visible.content {
- transform: translateX(-100%) !important;
- }
- .ui.move.right.active.reveal > .visible.content,
- .ui.move.right.reveal:hover > .visible.content {
- transform: translateX(100%) !important;
- }
- .ui.move.up.active.reveal > .visible.content,
- .ui.move.up.reveal:hover > .visible.content {
- transform: translateY(-100%) !important;
- }
- .ui.move.down.active.reveal > .visible.content,
- .ui.move.down.reveal:hover > .visible.content {
- transform: translateY(100%) !important;
- }
-}
+ .ui.rotate.reveal > .visible.content {
+ transition-duration: @transitionDuration;
+ transform: rotate(0);
+ }
+ .ui.rotate.reveal > .visible.content,
+ .ui.rotate.right.reveal > .visible.content {
+ transform-origin: bottom right;
+ }
+ .ui.rotate.active.reveal > .visible.content,
+ .ui.rotate.reveal:hover > .visible.content,
+ .ui.rotate.right.active.reveal > .visible.content,
+ .ui.rotate.right.reveal:hover > .visible.content {
+ transform: rotate(@rotateDegrees);
+ }
-& when (@variationRevealRotate) {
- /*--------------
- Rotate
- ---------------*/
-
- .ui.rotate.reveal > .visible.content {
- transition-duration: @transitionDuration;
- transform: rotate(0deg);
- }
-
- .ui.rotate.reveal > .visible.content,
- .ui.rotate.right.reveal > .visible.content {
- transform-origin: bottom right;
- }
- .ui.rotate.active.reveal > .visible.content,
- .ui.rotate.reveal:hover > .visible.content,
- .ui.rotate.right.active.reveal > .visible.content,
- .ui.rotate.right.reveal:hover > .visible.content {
- transform: rotate(@rotateDegrees);
- }
-
- .ui.rotate.left.reveal > .visible.content {
- transform-origin: bottom left;
- }
- .ui.rotate.left.active.reveal > .visible.content,
- .ui.rotate.left.reveal:hover > .visible.content {
- transform: rotate(-@rotateDegrees);
- }
+ .ui.rotate.left.reveal > .visible.content {
+ transform-origin: bottom left;
+ }
+ .ui.rotate.left.active.reveal > .visible.content,
+ .ui.rotate.left.reveal:hover > .visible.content {
+ transform: rotate(-@rotateDegrees);
+ }
}
/*******************************
@@ -225,65 +221,63 @@
*******************************/
& when (@variationRevealDisabled) {
- .ui.disabled.reveal:hover > .visible.visible.content {
- position: static !important;
- display: block !important;
- opacity: 1 !important;
- top: 0 !important;
- left: 0 !important;
- right: auto !important;
- bottom: auto !important;
- transform: none !important;
- }
- .ui.disabled.reveal:hover > .hidden.hidden.content {
- display: none !important;
- }
+ .ui.disabled.reveal:hover > .visible.visible.content {
+ position: static !important;
+ display: block !important;
+ opacity: 1 !important;
+ top: 0 !important;
+ left: 0 !important;
+ right: auto !important;
+ bottom: auto !important;
+ transform: none !important;
+ }
+ .ui.disabled.reveal:hover > .hidden.hidden.content {
+ display: none !important;
+ }
}
-
/*******************************
Coupling
*******************************/
.ui.reveal > .ui.ribbon.label {
- z-index: @overlayZIndex;
+ z-index: @overlayZIndex;
}
/*******************************
Variations
*******************************/
-/*--------------
+/* --------------
Visible
----------------*/
+--------------- */
.ui.visible.reveal {
- overflow: visible;
+ overflow: visible;
}
-/*--------------
+/* --------------
Instant
----------------*/
+--------------- */
.ui.instant.reveal > .content {
- transition-delay: 0s !important;
+ transition-delay: 0s !important;
}
-
-/*--------------
+/* --------------
Sizing
----------------*/
+--------------- */
.ui.reveal > .content {
- font-size: @medium;
+ font-size: @medium;
}
& when not (@variationRevealSizes = false) {
- each(@variationRevealSizes, {
- @s: @@value;
- .ui.@{value}.reveal > .content {
- font-size: @s;
- }
- })
+ each(@variationRevealSizes, {
+ @s: @@value;
+ .ui.@{value}.reveal > .content {
+ font-size: @s;
+ }
+ });
}
.loadUIOverrides();
diff --git a/definitions/elements/segment.less b/definitions/elements/segment.less
index e61da3b..fcd9c30 100644
--- a/definitions/elements/segment.less
+++ b/definitions/elements/segment.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Segment
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,109 +12,107 @@
Theme
*******************************/
-@type : 'element';
-@element : 'segment';
+@type: "element";
+@element: "segment";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Segment
*******************************/
.ui.segment {
- position: relative;
- background: @background;
- box-shadow: @boxShadow;
- margin: @margin;
- padding: @padding;
- border-radius: @borderRadius;
- border: @border;
+ position: relative;
+ background: @background;
+ box-shadow: @boxShadow;
+ margin: @margin;
+ padding: @padding;
+ border-radius: @borderRadius;
+ border: @border;
}
.ui.segment:first-child {
- margin-top: 0;
+ margin-top: 0;
}
.ui.segment:last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
& when (@variationSegmentVertical) {
- /* Vertical */
- .ui.vertical.segment {
- margin: 0;
- padding-left: 0;
- padding-right: 0;
-
- background: none transparent;
- border-radius: 0;
- box-shadow: none;
- border: none;
- border-top: @borderWidth solid @borderColor;
- }
- .ui.vertical.segment:first-child {
- border-top: none;
- }
+ /* Vertical */
+ .ui.vertical.segment {
+ margin: 0;
+ padding-left: 0;
+ padding-right: 0;
+ background: none transparent;
+ border-radius: 0;
+ box-shadow: none;
+ border: none;
+ border-top: @borderWidth solid @borderColor;
+ }
+ .ui.vertical.segment:first-child {
+ border-top: none;
+ }
}
-
-/*-------------------
+/* -------------------
Loose Coupling
---------------------*/
+-------------------- */
& when (@variationSegmentInverted) {
- /* Header */
- .ui.inverted.segments .segment > .ui.header .sub.header,
- .ui.inverted.segments .segment > .ui.header,
- .ui.inverted.segment > .ui.header .sub.header,
- .ui.inverted.segment > .ui.header {
- color: @white;
- }
+ /* Header */
+ .ui.inverted.segments .segment > .ui.header .sub.header,
+ .ui.inverted.segments .segment > .ui.header,
+ .ui.inverted.segment > .ui.header .sub.header,
+ .ui.inverted.segment > .ui.header {
+ color: @white;
+ }
}
& when (@variationSegmentAttached) {
- /* Label */
- .ui[class*="bottom attached"].segment > [class*="top attached"].label {
- border-top-left-radius: 0;
- border-top-right-radius: 0;
- }
- .ui[class*="top attached"].segment > [class*="bottom attached"].label {
- border-bottom-left-radius: 0;
- border-bottom-right-radius: 0;
- }
- .ui.attached.segment:not(.top):not(.bottom) > [class*="top attached"].label {
- border-top-left-radius: 0;
- border-top-right-radius: 0;
- }
- .ui.attached.segment:not(.top):not(.bottom) > [class*="bottom attached"].label {
- border-bottom-left-radius: 0;
- border-bottom-right-radius: 0;
- }
+ /* Label */
+ .ui[class*="bottom attached"].segment > [class*="top attached"].label {
+ border-top-left-radius: 0;
+ border-top-right-radius: 0;
+ }
+ .ui[class*="top attached"].segment > [class*="bottom attached"].label {
+ border-bottom-left-radius: 0;
+ border-bottom-right-radius: 0;
+ }
+ .ui.attached.segment:not(.top):not(.bottom) > [class*="top attached"].label {
+ border-top-left-radius: 0;
+ border-top-right-radius: 0;
+ }
+ .ui.attached.segment:not(.top):not(.bottom) > [class*="bottom attached"].label {
+ border-bottom-left-radius: 0;
+ border-bottom-right-radius: 0;
+ }
}
/* Grid */
.ui.page.grid.segment,
.ui.grid > .row > .ui.segment.column,
.ui.grid > .ui.segment.column {
- padding-top: @pageGridMargin;
- padding-bottom: @pageGridMargin;
+ padding-top: @pageGridMargin;
+ padding-bottom: @pageGridMargin;
}
.ui.grid.segment {
- margin: @margin;
- border-radius: @borderRadius;
+ margin: @margin;
+ border-radius: @borderRadius;
}
/* Table */
.ui.basic.table.segment {
- background: @background;
- border: @border;
- box-shadow: @boxShadow;
+ background: @background;
+ border: @border;
+ box-shadow: @boxShadow;
}
.ui[class*="very basic"].table.segment {
- padding: @padding;
+ padding: @padding;
}
/* Tab */
.ui.segment.tab:last-child {
- margin-bottom: @verticalMargin;
+ margin-bottom: @verticalMargin;
}
/*******************************
@@ -122,796 +120,791 @@
*******************************/
& when (@variationSegmentPlaceholder) {
- /*-------------------
- Placeholder
- --------------------*/
-
- .ui.placeholder.segment {
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: stretch;
- max-width: initial;
- animation: none;
- overflow: visible;
- padding: @placeholderPadding;
- min-height: @placeholderMinHeight;
- background: @placeholderBackground;
- border-color: @placeholderBorderColor;
- box-shadow: @placeholderBoxShadow;
- &.tab {
- display: none;
- &.active {
+ /* -------------------
+ Placeholder
+ -------------------- */
+
+ .ui.placeholder.segment {
display: flex;
- }
- }
- }
-
- .ui.placeholder.segment .button,
- .ui.placeholder.segment textarea {
- display: block;
- }
- .ui.placeholder.segment .field,
- .ui.placeholder.segment textarea,
- .ui.placeholder.segment > .ui.input,
- .ui.placeholder.segment .button {
- max-width: @placeholderContentMaxWidth;
- margin-left: auto;
- margin-right: auto;
- }
- .ui.placeholder.segment .column .button,
- .ui.placeholder.segment .column .field,
- .ui.placeholder.segment .column textarea,
- .ui.placeholder.segment .column > .ui.input {
- max-width: @placeholderContentMaxWidth;
- margin-left: auto;
- margin-right: auto;
- }
-
- .ui.placeholder.segment > .inline {
- align-self: center;
- }
- .ui.placeholder.segment > .inline > .button {
- display: inline-block;
- width: auto;
- margin: @placeholderContentInlineButtonMargin;
- }
- .ui.placeholder.segment > .inline > .button:last-child {
- margin-right: 0;
- }
+ flex-direction: column;
+ justify-content: center;
+ align-items: stretch;
+ max-width: initial;
+ animation: none;
+ overflow: visible;
+ padding: @placeholderPadding;
+ min-height: @placeholderMinHeight;
+ background: @placeholderBackground;
+ border-color: @placeholderBorderColor;
+ box-shadow: @placeholderBoxShadow;
+ &.tab {
+ display: none;
+ &.active {
+ display: flex;
+ }
+ }
+ }
+
+ .ui.placeholder.segment .button,
+ .ui.placeholder.segment textarea {
+ display: block;
+ }
+ .ui.placeholder.segment .field,
+ .ui.placeholder.segment textarea,
+ .ui.placeholder.segment > .ui.input,
+ .ui.placeholder.segment .button {
+ max-width: @placeholderContentMaxWidth;
+ margin-left: auto;
+ margin-right: auto;
+ }
+ .ui.placeholder.segment .column .button,
+ .ui.placeholder.segment .column .field,
+ .ui.placeholder.segment .column textarea,
+ .ui.placeholder.segment .column > .ui.input {
+ max-width: @placeholderContentMaxWidth;
+ margin-left: auto;
+ margin-right: auto;
+ }
+
+ .ui.placeholder.segment > .inline {
+ align-self: center;
+ }
+ .ui.placeholder.segment > .inline > .button {
+ display: inline-block;
+ width: auto;
+ margin: @placeholderContentInlineButtonMargin;
+ }
+ .ui.placeholder.segment > .inline > .button:last-child {
+ margin-right: 0;
+ }
}
& when (@variationSegmentPiled) {
- /*-------------------
- Piled
- --------------------*/
-
- .ui.piled.segments,
- .ui.piled.segment {
- margin: @piledMargin 0;
- box-shadow: @piledBoxShadow;
- z-index: @piledZIndex;
- }
- .ui.piled.segment:first-child {
- margin-top: 0;
- }
- .ui.piled.segment:last-child {
- margin-bottom: 0;
- }
- .ui.piled.segments::after,
- .ui.piled.segments::before,
- .ui.piled.segment::after,
- .ui.piled.segment::before {
- background-color: @white;
- visibility: visible;
- content: '';
- display: block;
- height: 100%;
- left: 0;
- position: absolute;
- width: 100%;
- border: @piledBorder;
- box-shadow: @piledBoxShadow;
- }
- .ui.piled.segments::before,
- .ui.piled.segment::before {
- transform: rotate(-@piledDegrees);
- top: 0;
- z-index: -2;
- }
- .ui.piled.segments::after,
- .ui.piled.segment::after {
- transform: rotate(@piledDegrees);
- top: 0;
- z-index: -1;
- }
- & when (@variationSegmentAttached) {
- /* Piled Attached */
- .ui[class*="top attached"].piled.segment {
- margin-top: @piledMargin;
- margin-bottom: 0;
- }
- .ui.piled.segment[class*="top attached"]:first-child {
- margin-top: 0;
- }
- .ui.piled.segment[class*="bottom attached"] {
- margin-top: 0;
- margin-bottom: @piledMargin;
- }
- .ui.piled.segment[class*="bottom attached"]:last-child {
- margin-bottom: 0;
- }
- }
+ /* -------------------
+ Piled
+ -------------------- */
+
+ .ui.piled.segments,
+ .ui.piled.segment {
+ margin: @piledMargin 0;
+ box-shadow: @piledBoxShadow;
+ z-index: @piledZIndex;
+ }
+ .ui.piled.segment:first-child {
+ margin-top: 0;
+ }
+ .ui.piled.segment:last-child {
+ margin-bottom: 0;
+ }
+ .ui.piled.segments::after,
+ .ui.piled.segments::before,
+ .ui.piled.segment::after,
+ .ui.piled.segment::before {
+ background-color: @white;
+ visibility: visible;
+ content: "";
+ display: block;
+ height: 100%;
+ left: 0;
+ position: absolute;
+ width: 100%;
+ border: @piledBorder;
+ box-shadow: @piledBoxShadow;
+ }
+ .ui.piled.segments::before,
+ .ui.piled.segment::before {
+ transform: rotate(-@piledDegrees);
+ top: 0;
+ z-index: -2;
+ }
+ .ui.piled.segments::after,
+ .ui.piled.segment::after {
+ transform: rotate(@piledDegrees);
+ top: 0;
+ z-index: -1;
+ }
+ & when (@variationSegmentAttached) {
+ /* Piled Attached */
+ .ui[class*="top attached"].piled.segment {
+ margin-top: @piledMargin;
+ margin-bottom: 0;
+ }
+ .ui.piled.segment[class*="top attached"]:first-child {
+ margin-top: 0;
+ }
+ .ui.piled.segment[class*="bottom attached"] {
+ margin-top: 0;
+ margin-bottom: @piledMargin;
+ }
+ .ui.piled.segment[class*="bottom attached"]:last-child {
+ margin-bottom: 0;
+ }
+ }
}
& when (@variationSegmentStacked) {
- /*-------------------
- Stacked
- --------------------*/
-
- .ui.stacked.segment {
- padding-bottom: @stackedPadding;
- }
- .ui.stacked.segments::before,
- .ui.stacked.segments::after,
- .ui.stacked.segment::before,
- .ui.stacked.segment::after {
- content: '';
- position: absolute;
- bottom: -(@stackedHeight / 2);
- left: 0;
-
- border-top: 1px solid @borderColor;
- background: @stackedPageBackground;
-
- width: 100%;
- height: @stackedHeight;
- visibility: visible;
- }
- .ui.stacked.segments::before,
- .ui.stacked.segment::before {
- display: none;
- }
-
- /* Add additional page */
- .ui.tall.stacked.segments::before,
- .ui.tall.stacked.segment::before {
- display: block;
- bottom: 0;
- }
- & when (@variationSegmentInverted) {
- /* Inverted */
- .ui.stacked.inverted.segments::before,
- .ui.stacked.inverted.segments::after,
- .ui.stacked.inverted.segment::before,
- .ui.stacked.inverted.segment::after {
- background-color: @subtleTransparentBlack;
- border-top: 1px solid @selectedBorderColor;
- }
- }
+ /* -------------------
+ Stacked
+ -------------------- */
+
+ .ui.stacked.segment {
+ padding-bottom: @stackedPadding;
+ }
+ .ui.stacked.segments::before,
+ .ui.stacked.segments::after,
+ .ui.stacked.segment::before,
+ .ui.stacked.segment::after {
+ content: "";
+ position: absolute;
+ bottom: -(@stackedHeight / 2);
+ left: 0;
+ border-top: 1px solid @borderColor;
+ background: @stackedPageBackground;
+ width: 100%;
+ height: @stackedHeight;
+ visibility: visible;
+ }
+ .ui.stacked.segments::before,
+ .ui.stacked.segment::before {
+ display: none;
+ }
+
+ /* Add additional page */
+ .ui.tall.stacked.segments::before,
+ .ui.tall.stacked.segment::before {
+ display: block;
+ bottom: 0;
+ }
+ & when (@variationSegmentInverted) {
+ /* Inverted */
+ .ui.stacked.inverted.segments::before,
+ .ui.stacked.inverted.segments::after,
+ .ui.stacked.inverted.segment::before,
+ .ui.stacked.inverted.segment::after {
+ background-color: @subtleTransparentBlack;
+ border-top: 1px solid @selectedBorderColor;
+ }
+ }
}
& when (@variationSegmentPadded) {
- /*-------------------
- Padded
- --------------------*/
+ /* -------------------
+ Padded
+ -------------------- */
- .ui.padded.segment {
- padding: @paddedSegmentPadding;
- }
- & when (@variationSegmentVeryPadded) {
- .ui[class*="very padded"].segment {
- padding: @veryPaddedSegmentPadding;
+ .ui.padded.segment {
+ padding: @paddedSegmentPadding;
+ }
+ & when (@variationSegmentVeryPadded) {
+ .ui[class*="very padded"].segment {
+ padding: @veryPaddedSegmentPadding;
+ }
}
- }
- & when (@variationSegmentVertical) {
- /* Padded vertical */
- .ui.padded.segment.vertical.segment,
- .ui[class*="very padded"].vertical.segment {
- padding-left: 0;
- padding-right: 0;
+ & when (@variationSegmentVertical) {
+ /* Padded vertical */
+ .ui.padded.segment.vertical.segment,
+ .ui[class*="very padded"].vertical.segment {
+ padding-left: 0;
+ padding-right: 0;
+ }
}
- }
}
& when (@variationSegmentCompact) {
- /*-------------------
- Compact
- --------------------*/
+ /* -------------------
+ Compact
+ -------------------- */
- .ui.compact.segment {
- display: table;
- }
+ .ui.compact.segment {
+ display: table;
+ }
- /* Compact Group */
- .ui.compact.segments {
- display: inline-flex;
- }
- .ui.compact.segments .segment,
- .ui.segments .compact.segment {
- display: block;
- flex: 0 1 auto;
- }
+ /* Compact Group */
+ .ui.compact.segments {
+ display: inline-flex;
+ }
+ .ui.compact.segments .segment,
+ .ui.segments .compact.segment {
+ display: block;
+ flex: 0 1 auto;
+ }
}
& when (@variationSegmentCircular) {
- /*-------------------
- Circular
- --------------------*/
+ /* -------------------
+ Circular
+ -------------------- */
- .ui.circular.segment {
- display: table-cell;
- padding: @circularPadding;
- text-align: center;
- vertical-align: middle;
- border-radius: 500em;
- }
+ .ui.circular.segment {
+ display: table-cell;
+ padding: @circularPadding;
+ text-align: center;
+ vertical-align: middle;
+ border-radius: 500em;
+ }
}
& when (@variationSegmentRaised) {
- /*-------------------
- Raised
- --------------------*/
+ /* -------------------
+ Raised
+ -------------------- */
- .ui.raised.raised.segments,
- .ui.raised.raised.segment {
- box-shadow: @raisedBoxShadow;
- }
+ .ui.raised.raised.segments,
+ .ui.raised.raised.segment {
+ box-shadow: @raisedBoxShadow;
+ }
}
& when (@variationSegmentGroups) {
- /*******************************
- Groups
- *******************************/
-
- /* Group */
- .ui.segments {
- flex-direction: column;
- position: relative;
- margin: @groupedMargin;
- border: @groupedBorder;
- box-shadow: @groupedBoxShadow;
- border-radius: @groupedBorderRadius;
- }
- .ui.segments:first-child {
- margin-top: 0;
- }
- .ui.segments:last-child {
- margin-bottom: 0;
- }
-
-
- /* Nested Segment */
- .ui.segments > .segment {
- top: 0;
- bottom: 0;
- border-radius: 0;
- margin: @groupedSegmentMargin;
- width: @groupedSegmentWidth;
- box-shadow: @groupedSegmentBoxShadow;
- border: @groupedSegmentBorder;
- border-top: @groupedSegmentDivider;
- }
-
- .ui.segments:not(.horizontal) > .segment:first-child {
- top: @attachedTopOffset;
- bottom: 0;
- border-top: none;
- margin-top: 0;
- margin-bottom: 0;
- border-radius: @borderRadius @borderRadius 0 0;
- }
-
- /* Bottom */
- .ui.segments:not(.horizontal) > .segment:last-child {
- top: @attachedBottomOffset;
- bottom: 0;
- margin-top: 0;
- margin-bottom: 0;
- box-shadow: @attachedBottomBoxShadow;
- border-radius: 0 0 @borderRadius @borderRadius;
- }
-
- /* Only */
- .ui.segments:not(.horizontal) > .segment:only-child {
- border-radius: @borderRadius;
- }
-
-
- /* Nested Group */
- .ui.segments > .ui.segments {
- border-top: @groupedSegmentDivider;
- margin: @nestedGroupMargin;
- }
- .ui.segments > .segments:first-child {
- border-top: none;
- }
- .ui.segments > .segment + .segments:not(.horizontal) {
- margin-top: 0;
- }
+ /*******************************
+ Groups
+ *******************************/
+
+ /* Group */
+ .ui.segments {
+ flex-direction: column;
+ position: relative;
+ margin: @groupedMargin;
+ border: @groupedBorder;
+ box-shadow: @groupedBoxShadow;
+ border-radius: @groupedBorderRadius;
+ }
+ .ui.segments:first-child {
+ margin-top: 0;
+ }
+ .ui.segments:last-child {
+ margin-bottom: 0;
+ }
+
+ /* Nested Segment */
+ .ui.segments > .segment {
+ top: 0;
+ bottom: 0;
+ border-radius: 0;
+ margin: @groupedSegmentMargin;
+ width: @groupedSegmentWidth;
+ box-shadow: @groupedSegmentBoxShadow;
+ border: @groupedSegmentBorder;
+ border-top: @groupedSegmentDivider;
+ }
+
+ .ui.segments:not(.horizontal) > .segment:first-child {
+ top: @attachedTopOffset;
+ bottom: 0;
+ border-top: none;
+ margin-top: 0;
+ margin-bottom: 0;
+ border-radius: @borderRadius @borderRadius 0 0;
+ }
+
+ /* Bottom */
+ .ui.segments:not(.horizontal) > .segment:last-child {
+ top: @attachedBottomOffset;
+ bottom: 0;
+ margin-top: 0;
+ margin-bottom: 0;
+ box-shadow: @attachedBottomBoxShadow;
+ border-radius: 0 0 @borderRadius @borderRadius;
+ }
+
+ /* Only */
+ .ui.segments:not(.horizontal) > .segment:only-child {
+ border-radius: @borderRadius;
+ }
+
+ /* Nested Group */
+ .ui.segments > .ui.segments {
+ border-top: @groupedSegmentDivider;
+ margin: @nestedGroupMargin;
+ }
+ .ui.segments > .segments:first-child {
+ border-top: none;
+ }
+ .ui.segments > .segment + .segments:not(.horizontal) {
+ margin-top: 0;
+ }
+
+ & when (@variationSegmentHorizontal) {
+ /* Horizontal Group */
+ .ui.horizontal.segments {
+ display: flex;
+ flex-direction: row;
+ background-color: transparent;
+ padding: 0;
+ box-shadow: @groupedBoxShadow;
+ margin: @groupedMargin;
+ border-radius: @groupedBorderRadius;
+ border: @groupedBorder;
+ }
+ .ui.stackable.horizontal.segments {
+ flex-wrap: wrap;
+ }
- & when (@variationSegmentHorizontal) {
- /* Horizontal Group */
- .ui.horizontal.segments {
- display: flex;
- flex-direction: row;
- background-color: transparent;
- padding: 0;
- box-shadow: @groupedBoxShadow;
- margin: @groupedMargin;
- border-radius: @groupedBorderRadius;
- border: @groupedBorder;
- }
- .ui.stackable.horizontal.segments {
- flex-wrap: wrap;
- }
+ /* Nested Horizontal Group */
+ .ui.segments > .horizontal.segments {
+ margin: 0;
+ background-color: transparent;
+ border-radius: 0;
+ border: none;
+ box-shadow: none;
+ border-top: @groupedSegmentDivider;
+ }
- /* Nested Horizontal Group */
- .ui.segments > .horizontal.segments {
- margin: 0;
- background-color: transparent;
- border-radius: 0;
- border: none;
- box-shadow: none;
- border-top: @groupedSegmentDivider;
- }
+ /* Horizontal Segment */
+ .ui.horizontal.segments:not(.compact) > .segment:not(.compact) {
+ flex: 1 1 auto;
+ & when (@supportIE) {
+ // https://github.com/Semantic-Org/Semantic-UI/issues/2550
+ // stylelint-disable-next-line property-no-vendor-prefix
+ -ms-flex: 1 1 0;
+ }
+ }
+ .ui.horizontal.segments > .segment {
+ margin: 0;
+ min-width: 0;
+ border-radius: 0;
+ border: none;
+ box-shadow: none;
+ border-left: @borderWidth solid @borderColor;
+ }
- /* Horizontal Segment */
- .ui.horizontal.segments:not(.compact) > .segment:not(.compact) {
- flex: 1 1 auto;
- & when (@supportIE) {
- -ms-flex: 1 1 0; /* Solves #2550 MS Flex */
- }
- }
- .ui.horizontal.segments > .segment {
- margin: 0;
- min-width: 0;
- border-radius: 0;
- border: none;
- box-shadow: none;
- border-left: @borderWidth solid @borderColor;
- }
+ /* Border Fixes */
+ .ui.segments > .horizontal.segments:first-child {
+ border-top: none;
+ }
+ .ui.horizontal.segments:not(.stackable) > .segment:first-child {
+ border-left: none;
+ }
+ .ui.horizontal.segments > .segment:first-child {
+ border-radius: @borderRadius 0 0 @borderRadius;
+ }
+ .ui.horizontal.segments > .segment:last-child {
+ border-radius: 0 @borderRadius @borderRadius 0;
+ }
- /* Border Fixes */
- .ui.segments > .horizontal.segments:first-child {
- border-top: none;
- }
- .ui.horizontal.segments:not(.stackable) > .segment:first-child {
- border-left: none;
- }
- .ui.horizontal.segments > .segment:first-child {
- border-radius: @borderRadius 0 0 @borderRadius;
- }
- .ui.horizontal.segments > .segment:last-child {
- border-radius: 0 @borderRadius @borderRadius 0;
- }
- /* Equal Width */
- .ui[class*="equal width"].horizontal.segments > .segment {
- width: 100%;
+ /* Equal Width */
+ .ui[class*="equal width"].horizontal.segments > .segment {
+ width: 100%;
+ }
}
- }
}
-
/*******************************
States
*******************************/
& when (@variationSegmentDisabled) {
- /*--------------
- Disabled
- ---------------*/
+ /* --------------
+ Disabled
+ --------------- */
- .ui.disabled.segments,
- .ui.disabled.segment {
- opacity: @disabledOpacity;
- color: @disabledTextColor;
- pointer-events: none;
- user-select: none;
- }
+ .ui.disabled.segments,
+ .ui.disabled.segment {
+ opacity: @disabledOpacity;
+ color: @disabledTextColor;
+ pointer-events: none;
+ user-select: none;
+ }
}
& when (@variationSegmentLoading) {
- /*--------------
- Loading
- ---------------*/
-
- .ui.loading.segments,
- .ui.loading.segment {
- position: relative;
- cursor: default;
- pointer-events: none;
- user-select: none;
- transition: all 0s linear;
- }
- .ui.loading.segments::before,
- .ui.loading.segment::before {
- position: absolute;
- content: '';
- top: 0;
- left: 0;
- background: @loaderDimmerColor;
- width: 100%;
- height: 100%;
- border-radius: @borderRadius;
- z-index: @loaderDimmerZIndex;
- }
- .ui.loading.segments::after,
- .ui.loading.segment::after {
- position: absolute;
- content: '';
- top: 50%;
- left: 50%;
-
- margin: @loaderMargin;
- width: @loaderSize;
- height: @loaderSize;
-
- animation: loader @loaderSpeed infinite linear;
- border: @loaderLineWidth solid @loaderLineColor;
- border-radius: @circularRadius;
-
- box-shadow: 0 0 0 1px transparent;
- visibility: visible;
- z-index: @loaderLineZIndex;
- }
+ /* --------------
+ Loading
+ --------------- */
+
+ .ui.loading.segments,
+ .ui.loading.segment {
+ position: relative;
+ cursor: default;
+ pointer-events: none;
+ user-select: none;
+ transition: all 0s linear;
+ }
+ .ui.loading.segments::before,
+ .ui.loading.segment::before {
+ position: absolute;
+ content: "";
+ top: 0;
+ left: 0;
+ background: @loaderDimmerColor;
+ width: 100%;
+ height: 100%;
+ border-radius: @borderRadius;
+ z-index: @loaderDimmerZIndex;
+ }
+ .ui.loading.segments::after,
+ .ui.loading.segment::after {
+ position: absolute;
+ content: "";
+ top: 50%;
+ left: 50%;
+ margin: @loaderMargin;
+ width: @loaderSize;
+ height: @loaderSize;
+ animation: loader @loaderSpeed infinite linear;
+ border: @loaderLineWidth solid @loaderLineColor;
+ border-radius: @circularRadius;
+ box-shadow: 0 0 0 1px transparent;
+ visibility: visible;
+ z-index: @loaderLineZIndex;
+ }
}
-
-
/*******************************
Variations
*******************************/
& when (@variationSegmentBasic) {
- /*-------------------
- Basic
- --------------------*/
+ /* -------------------
+ Basic
+ -------------------- */
- .ui.basic.segment,
- .ui.segments .ui.basic.segment,
- .ui.basic.segments {
- background: @basicBackground;
- box-shadow: @basicBoxShadow;
- border: @basicBorder;
- border-radius: @basicBorderRadius;
- }
+ .ui.basic.segment,
+ .ui.segments .ui.basic.segment,
+ .ui.basic.segments {
+ background: @basicBackground;
+ box-shadow: @basicBoxShadow;
+ border: @basicBorder;
+ border-radius: @basicBorderRadius;
+ }
}
& when (@variationSegmentClearing) {
- /*-------------------
- Clearing
- --------------------*/
+ /* -------------------
+ Clearing
+ -------------------- */
- .ui.clearing.segment::after {
- content: "";
- display: block;
- clear: both;
- }
+ .ui.clearing.segment::after {
+ content: "";
+ display: block;
+ clear: both;
+ }
}
-/*-------------------
+/* -------------------
Colors
---------------------*/
+-------------------- */
& when not (@variationSegmentColors = false) {
- each(@variationSegmentColors, {
- @color: @value;
- @c: @colors[@@color][color];
- & when not (@color=primary) and not (@color=secondary) {
- .ui.@{color}.segment.segment.segment.segment.segment:not(.inverted) {
- border-top: @coloredBorderSize solid @c;
- }
- & when (@variationSegmentInverted) {
- .ui.inverted.@{color}.segment.segment.segment.segment.segment {
- background-color: @c;
- color: @white;
+ each(@variationSegmentColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+ & when not (@color=primary) and not (@color=secondary) {
+ .ui.@{color}.segment.segment.segment.segment.segment:not(.inverted) {
+ border-top: @coloredBorderSize solid @c;
+ }
+ & when (@variationSegmentInverted) {
+ .ui.inverted.@{color}.segment.segment.segment.segment.segment {
+ background-color: @c;
+ color: @white;
+ }
+ }
}
- }
- }
- })
+ });
}
& when (@variationSegmentAligned) {
- /*-------------------
- Aligned
- --------------------*/
+ /* -------------------
+ Aligned
+ -------------------- */
- .ui[class*="left aligned"].segment {
- text-align: left;
- }
- .ui[class*="right aligned"].segment {
- text-align: right;
- }
- .ui[class*="center aligned"].segment {
- text-align: center;
- }
+ .ui[class*="left aligned"].segment {
+ text-align: left;
+ }
+ .ui[class*="right aligned"].segment {
+ text-align: right;
+ }
+ .ui[class*="center aligned"].segment {
+ text-align: center;
+ }
}
& when (@variationSegmentFloating) {
- /*-------------------
- Floated
- --------------------*/
+ /* -------------------
+ Floated
+ -------------------- */
- .ui.floated.segment,
- .ui[class*="left floated"].segment {
- float: left;
- margin-right: @floatedDistance;
- }
- .ui[class*="right floated"].segment {
- float: right;
- margin-left: @floatedDistance;
- }
+ .ui.floated.segment,
+ .ui[class*="left floated"].segment {
+ float: left;
+ margin-right: @floatedDistance;
+ }
+ .ui[class*="right floated"].segment {
+ float: right;
+ margin-left: @floatedDistance;
+ }
}
& when (@variationSegmentInverted) {
- /*-------------------
- Inverted
- --------------------*/
- .ui.inverted.segments,
- .ui.inverted.segments .segment,
- .ui.inverted.segment {
- border: none;
- box-shadow: none;
- }
- .ui.inverted.segments .segment,
- .ui.inverted.segment,
- .ui.primary.inverted.segment {
- background: @invertedBackground;
- color: @invertedTextColor;
- }
-
- /* Nested */
- .ui.inverted.segment .segment {
- color: @textColor;
- }
- .ui.inverted.segment .inverted.segment {
- color: @invertedTextColor;
- }
- & when (@variationSegmentAttached) {
- /* Attached */
- .ui.ui.inverted.attached.segment {
- border-color: @solidWhiteBorderColor;
- }
- }
- & when (@variationSegmentLoading) {
- /* Loading */
- .ui.inverted.loading.segments,
- .ui.inverted.loading.segment {
- color: @invertedLoaderLineColor;
- }
- .ui.inverted.loading.segments::before,
- .ui.inverted.loading.segment::before {
- background: @loaderInvertedDimmerColor;
- }
- }
-}
-
-/*-------------------
+ /* -------------------
+ Inverted
+ -------------------- */
+ .ui.inverted.segments,
+ .ui.inverted.segments .segment,
+ .ui.inverted.segment {
+ border: none;
+ box-shadow: none;
+ }
+ .ui.inverted.segments .segment,
+ .ui.inverted.segment,
+ .ui.primary.inverted.segment {
+ background: @invertedBackground;
+ color: @invertedTextColor;
+ }
+
+ /* Nested */
+ .ui.inverted.segment .segment {
+ color: @textColor;
+ }
+ .ui.inverted.segment .inverted.segment {
+ color: @invertedTextColor;
+ }
+ & when (@variationSegmentAttached) {
+ /* Attached */
+ .ui.ui.inverted.attached.segment {
+ border-color: @solidWhiteBorderColor;
+ }
+ }
+ & when (@variationSegmentLoading) {
+ /* Loading */
+ .ui.inverted.loading.segments,
+ .ui.inverted.loading.segment {
+ color: @invertedLoaderLineColor;
+ }
+ .ui.inverted.loading.segments::before,
+ .ui.inverted.loading.segment::before {
+ background: @loaderInvertedDimmerColor;
+ }
+ }
+}
+
+/* -------------------
Emphasis
---------------------*/
+-------------------- */
& when (@variationSegmentSecondary) {
- /* Secondary */
- .ui.secondary.segment {
- background: @secondaryBackground;
- color: @secondaryColor;
- }
- & when (@variationSegmentInverted) {
- .ui.secondary.inverted.segment {
- background: @secondaryInvertedBackground;
- color: @secondaryInvertedColor;
+ /* Secondary */
+ .ui.secondary.segment {
+ background: @secondaryBackground;
+ color: @secondaryColor;
+ }
+ & when (@variationSegmentInverted) {
+ .ui.secondary.inverted.segment {
+ background: @secondaryInvertedBackground;
+ color: @secondaryInvertedColor;
+ }
}
- }
}
& when (@variationSegmentTertiary) {
- /* Tertiary */
- .ui.tertiary.segment {
- background: @tertiaryBackground;
- color: @tertiaryColor;
- }
- & when (@variationSegmentInverted) {
- .ui.tertiary.inverted.segment {
- background: @tertiaryInvertedBackground;
- color: @tertiaryInvertedColor;
+ /* Tertiary */
+ .ui.tertiary.segment {
+ background: @tertiaryBackground;
+ color: @tertiaryColor;
+ }
+ & when (@variationSegmentInverted) {
+ .ui.tertiary.inverted.segment {
+ background: @tertiaryInvertedBackground;
+ color: @tertiaryInvertedColor;
+ }
}
- }
}
& when (@variationSegmentAttached) {
- /*-------------------
- Attached
- --------------------*/
-
- /* Middle */
- .ui.attached.segment {
- top: 0;
- bottom: 0;
- border-radius: 0;
- margin: 0 @attachedHorizontalOffset;
- width: @attachedWidth;
- max-width: @attachedWidth;
- box-shadow: @attachedBoxShadow;
- &:not(.basic) {
- border: @attachedBorder;
- }
- }
- .ui.attached:not(.message):not(.text) + .ui.attached.segment:not(.top) {
- border-top: none;
- }
-
- /* Top */
- .ui.segment[class*="top attached"] {
- bottom: 0;
- margin-bottom: 0;
- top: @attachedTopOffset;
- margin-top: @verticalMargin;
- border-radius: @borderRadius @borderRadius 0 0;
- }
- .ui.segment[class*="top attached"]:first-child {
- margin-top: 0;
- }
- .ui.tab.segment[class*="top attached"]:first-child {
- margin-top: @verticalMargin;
- }
-
- /* Bottom */
- .ui.segment[class*="bottom attached"] {
- bottom: 0;
- margin-top: 0;
- top: @attachedBottomOffset;
- margin-bottom: @verticalMargin;
- box-shadow: @attachedBottomBoxShadow;
- border-radius: 0 0 @borderRadius @borderRadius;
- }
- .ui.segment[class*="bottom attached"]:last-child {
- margin-bottom: 0;
- }
- .ui.tab.segment[class*="bottom attached"]:last-child {
- margin-bottom: @verticalMargin;
- }
-}
-
-& when (@variationSegmentFitted) {
- /*--------------
- Fitted
- ---------------*/
-
- .ui.fitted.segment:not(.horizontally) {
- padding-top: 0;
- padding-bottom: 0;
- }
- .ui.fitted.segment:not(.vertically) {
- padding-left: 0;
- padding-right: 0;
- }
-}
-
-& when (@variationSegmentScrolling) {
- /*--------------
- Scrolling
- ---------------*/
- .ui.scrolling.segment {
- overflow: auto;
- }
- @media only screen and (max-width : @largestMobileScreen) {
- & when (@variationSegmentScrollingShort) {
- .ui.scrolling.segment.short {
- max-height: @scrollingMobileMaxHeight * 0.75;
- }
- }
- & when (@variationSegmentScrollingVeryShort) {
- .ui.scrolling.segment[class*="very short"] {
- max-height: @scrollingMobileMaxHeight * 0.5;
- }
+ /* -------------------
+ Attached
+ -------------------- */
+
+ /* Middle */
+ .ui.attached.segment {
+ top: 0;
+ bottom: 0;
+ border-radius: 0;
+ margin: 0 @attachedHorizontalOffset;
+ width: @attachedWidth;
+ max-width: @attachedWidth;
+ box-shadow: @attachedBoxShadow;
+ &:not(.basic) {
+ border: @attachedBorder;
+ }
}
- .ui.scrolling.segment {
- max-height: @scrollingMobileMaxHeight;
+ .ui.attached:not(.message):not(.text) + .ui.attached.segment:not(.top) {
+ border-top: none;
+ }
+
+ /* Top */
+ .ui.segment[class*="top attached"] {
+ bottom: 0;
+ margin-bottom: 0;
+ top: @attachedTopOffset;
+ margin-top: @verticalMargin;
+ border-radius: @borderRadius @borderRadius 0 0;
}
- & when (@variationSegmentScrollingLong) {
- .ui.scrolling.segment.long {
- max-height: @scrollingMobileMaxHeight * 2;
- }
+ .ui.segment[class*="top attached"]:first-child {
+ margin-top: 0;
}
- & when (@variationSegmentScrollingVeryLong) {
- .ui.scrolling.segment[class*="very long"] {
- max-height: @scrollingMobileMaxHeight * 3;
- }
+ .ui.tab.segment[class*="top attached"]:first-child {
+ margin-top: @verticalMargin;
}
- }
- @media only screen and (min-width: @tabletBreakpoint) {
- & when (@variationSegmentScrollingShort) {
- .ui.scrolling.segment.short {
- max-height: @scrollingTabletMaxHeight * 0.75;
- }
+ /* Bottom */
+ .ui.segment[class*="bottom attached"] {
+ bottom: 0;
+ margin-top: 0;
+ top: @attachedBottomOffset;
+ margin-bottom: @verticalMargin;
+ box-shadow: @attachedBottomBoxShadow;
+ border-radius: 0 0 @borderRadius @borderRadius;
}
- & when (@variationSegmentScrollingVeryShort) {
- .ui.scrolling.segment[class*="very short"] {
- max-height: @scrollingTabletMaxHeight * 0.5;
- }
+ .ui.segment[class*="bottom attached"]:last-child {
+ margin-bottom: 0;
}
- .ui.scrolling.segment {
- max-height: @scrollingTabletMaxHeight;
- }
- & when (@variationSegmentScrollingLong) {
- .ui.scrolling.segment.long {
- max-height: @scrollingTabletMaxHeight * 2;
- }
- }
- & when (@variationSegmentScrollingVeryLong) {
- .ui.scrolling.segment[class*="very long"] {
- max-height: @scrollingTabletMaxHeight * 3;
- }
- }
- }
- @media only screen and (min-width: @computerBreakpoint) {
- & when (@variationSegmentScrollingShort) {
- .ui.scrolling.segment.short {
- max-height: @scrollingComputerMaxHeight * 0.75;
- }
- }
- & when (@variationSegmentScrollingVeryShort) {
- .ui.scrolling.segment[class*="very short"] {
- max-height: @scrollingComputerMaxHeight * 0.5;
- }
+ .ui.tab.segment[class*="bottom attached"]:last-child {
+ margin-bottom: @verticalMargin;
}
- .ui.scrolling.segment {
- max-height: @scrollingComputerMaxHeight;
- }
- & when (@variationSegmentScrollingLong) {
- .ui.scrolling.segment.long {
- max-height: @scrollingComputerMaxHeight * 2;
- }
- }
- & when (@variationSegmentScrollingVeryLong) {
- .ui.scrolling.segment[class*="very long"]{
- max-height: @scrollingComputerMaxHeight * 3;
- }
- }
- }
- @media only screen and (min-width: @widescreenMonitorBreakpoint) {
- & when (@variationSegmentScrollingShort) {
- .ui.scrolling.segment.short {
- max-height: @scrollingWidescreenMaxHeight * 0.75;
- }
- }
- & when (@variationSegmentScrollingVeryShort) {
- .ui.scrolling.segment[class*="very short"] {
- max-height: @scrollingWidescreenMaxHeight * 0.5;
- }
+}
+
+& when (@variationSegmentFitted) {
+ /* --------------
+ Fitted
+ --------------- */
+
+ .ui.fitted.segment:not(.horizontally) {
+ padding-top: 0;
+ padding-bottom: 0;
+ }
+ .ui.fitted.segment:not(.vertically) {
+ padding-left: 0;
+ padding-right: 0;
}
+}
+
+& when (@variationSegmentScrolling) {
+ /* --------------
+ Scrolling
+ --------------- */
.ui.scrolling.segment {
- max-height: @scrollingWidescreenMaxHeight;
+ overflow: auto;
+ overscroll-behavior: @overscrollBehavior;
+ }
+ @media only screen and (max-width: @largestMobileScreen) {
+ & when (@variationSegmentScrollingShort) {
+ .ui.scrolling.segment.short {
+ max-height: @scrollingMobileMaxHeight * 0.75;
+ }
+ }
+ & when (@variationSegmentScrollingVeryShort) {
+ .ui.scrolling.segment[class*="very short"] {
+ max-height: @scrollingMobileMaxHeight * 0.5;
+ }
+ }
+ .ui.scrolling.segment {
+ max-height: @scrollingMobileMaxHeight;
+ }
+ & when (@variationSegmentScrollingLong) {
+ .ui.scrolling.segment.long {
+ max-height: @scrollingMobileMaxHeight * 2;
+ }
+ }
+ & when (@variationSegmentScrollingVeryLong) {
+ .ui.scrolling.segment[class*="very long"] {
+ max-height: @scrollingMobileMaxHeight * 3;
+ }
+ }
+ }
+
+ @media only screen and (min-width: @tabletBreakpoint) {
+ & when (@variationSegmentScrollingShort) {
+ .ui.scrolling.segment.short {
+ max-height: @scrollingTabletMaxHeight * 0.75;
+ }
+ }
+ & when (@variationSegmentScrollingVeryShort) {
+ .ui.scrolling.segment[class*="very short"] {
+ max-height: @scrollingTabletMaxHeight * 0.5;
+ }
+ }
+ .ui.scrolling.segment {
+ max-height: @scrollingTabletMaxHeight;
+ }
+ & when (@variationSegmentScrollingLong) {
+ .ui.scrolling.segment.long {
+ max-height: @scrollingTabletMaxHeight * 2;
+ }
+ }
+ & when (@variationSegmentScrollingVeryLong) {
+ .ui.scrolling.segment[class*="very long"] {
+ max-height: @scrollingTabletMaxHeight * 3;
+ }
+ }
}
- & when (@variationSegmentScrollingLong) {
- .ui.scrolling.segment.long {
- max-height: @scrollingWidescreenMaxHeight * 2;
- }
+ @media only screen and (min-width: @computerBreakpoint) {
+ & when (@variationSegmentScrollingShort) {
+ .ui.scrolling.segment.short {
+ max-height: @scrollingComputerMaxHeight * 0.75;
+ }
+ }
+ & when (@variationSegmentScrollingVeryShort) {
+ .ui.scrolling.segment[class*="very short"] {
+ max-height: @scrollingComputerMaxHeight * 0.5;
+ }
+ }
+ .ui.scrolling.segment {
+ max-height: @scrollingComputerMaxHeight;
+ }
+ & when (@variationSegmentScrollingLong) {
+ .ui.scrolling.segment.long {
+ max-height: @scrollingComputerMaxHeight * 2;
+ }
+ }
+ & when (@variationSegmentScrollingVeryLong) {
+ .ui.scrolling.segment[class*="very long"] {
+ max-height: @scrollingComputerMaxHeight * 3;
+ }
+ }
}
- & when (@variationSegmentScrollingVeryLong) {
- .ui.scrolling.segment[class*="very long"] {
- max-height: @scrollingWidescreenMaxHeight * 3;
- }
+ @media only screen and (min-width: @widescreenMonitorBreakpoint) {
+ & when (@variationSegmentScrollingShort) {
+ .ui.scrolling.segment.short {
+ max-height: @scrollingWidescreenMaxHeight * 0.75;
+ }
+ }
+ & when (@variationSegmentScrollingVeryShort) {
+ .ui.scrolling.segment[class*="very short"] {
+ max-height: @scrollingWidescreenMaxHeight * 0.5;
+ }
+ }
+ .ui.scrolling.segment {
+ max-height: @scrollingWidescreenMaxHeight;
+ }
+ & when (@variationSegmentScrollingLong) {
+ .ui.scrolling.segment.long {
+ max-height: @scrollingWidescreenMaxHeight * 2;
+ }
+ }
+ & when (@variationSegmentScrollingVeryLong) {
+ .ui.scrolling.segment[class*="very long"] {
+ max-height: @scrollingWidescreenMaxHeight * 3;
+ }
+ }
}
- }
}
-/*-------------------
+
+/* -------------------
Size
---------------------*/
+-------------------- */
.ui.segments .segment,
.ui.segment {
- font-size: @medium;
+ font-size: @medium;
}
& when not (@variationSegmentSizes = false) {
- each(@variationSegmentSizes, {
- @s: @@value;
- .ui.@{value}.segments .segment,
- .ui.@{value}.segment {
- font-size: @s;
- }
- })
+ each(@variationSegmentSizes, {
+ @s: @@value;
+ .ui.@{value}.segments .segment,
+ .ui.@{value}.segment {
+ font-size: @s;
+ }
+ });
}
.loadUIOverrides();
diff --git a/definitions/elements/step.less b/definitions/elements/step.less
index e074db6..3f44425 100644
--- a/definitions/elements/step.less
+++ b/definitions/elements/step.less
@@ -1,170 +1,163 @@
/*!
* # Fomantic-UI - Step
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-
/*******************************
Step
*******************************/
-/*--------------
+/* --------------
Load Theme
----------------*/
+--------------- */
-@type : 'element';
-@element : 'step';
+@type: "element";
+@element: "step";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Plural
*******************************/
.ui.steps {
- display: inline-flex;
- flex-direction: row;
- align-items: stretch;
- margin: @stepMargin;
- background: @stepsBackground;
- box-shadow: @stepsBoxShadow;
- line-height: @lineHeight;
- border-radius: @stepsBorderRadius;
- border: @stepsBorder;
+ display: inline-flex;
+ flex-direction: row;
+ align-items: stretch;
+ margin: @stepMargin;
+ background: @stepsBackground;
+ box-shadow: @stepsBoxShadow;
+ line-height: @lineHeight;
+ border-radius: @stepsBorderRadius;
+ border: @stepsBorder;
}
.ui.steps:not(.unstackable) {
- flex-wrap: wrap;
+ flex-wrap: wrap;
}
/* First Steps */
.ui.steps:first-child {
- margin-top: 0;
+ margin-top: 0;
}
/* Last Steps */
.ui.steps:last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
-
/*******************************
Singular
*******************************/
.ui.steps .step {
- position: relative;
- display: flex;
- flex: 1 0 auto;
- flex-wrap: wrap;
- flex-direction: row;
- vertical-align: middle;
- align-items: center;
- justify-content: @justifyContent;
-
- margin: @verticalMargin @horizontalMargin;
- padding: @verticalPadding @horizontalPadding;
- background: @background;
- color: @textColor;
- box-shadow: @boxShadow;
- border-radius: @borderRadius;
- border: @border;
- border-right: @divider;
- transition: @transition;
+ position: relative;
+ display: flex;
+ flex: 1 0 auto;
+ flex-flow: row wrap;
+ vertical-align: middle;
+ align-items: center;
+ justify-content: @justifyContent;
+ margin: @verticalMargin @horizontalMargin;
+ padding: @verticalPadding @horizontalPadding;
+ background: @background;
+ color: @textColor;
+ box-shadow: @boxShadow;
+ border-radius: @borderRadius;
+ border: @border;
+ border-right: @divider;
+ transition: @transition;
}
/* Arrow */
.ui.steps .step::after {
- display: none;
- position: absolute;
- z-index: 2;
- content: '';
- top: @arrowTopOffset;
- right: @arrowRightOffset;
- background-color: @arrowBackgroundColor;
- width: @arrowSize;
- height: @arrowSize;
-
- border-style: solid;
- border-color: @borderColor;
- border-width: @arrowBorderWidth;
-
- transition: @transition;
- transform: translateY(-50%) translateX(50%) rotate(-45deg);
+ display: none;
+ position: absolute;
+ z-index: 2;
+ content: "";
+ top: @arrowTopOffset;
+ right: @arrowRightOffset;
+ background-color: @arrowBackgroundColor;
+ width: @arrowSize;
+ height: @arrowSize;
+ border-style: solid;
+ border-color: @borderColor;
+ border-width: @arrowBorderWidth;
+ transition: @transition;
+ transform: translateY(-50%) translateX(50%) rotate(-45deg);
}
/* First Step */
.ui.steps .step:first-child {
- padding-left: @horizontalPadding;
- border-radius: @stepsBorderRadius 0 0 @stepsBorderRadius;
+ padding-left: @horizontalPadding;
+ border-radius: @stepsBorderRadius 0 0 @stepsBorderRadius;
}
/* Last Step */
.ui.steps .step:last-child {
- border-radius: 0 @stepsBorderRadius @stepsBorderRadius 0;
- border-right: none;
- margin-right: 0;
+ border-radius: 0 @stepsBorderRadius @stepsBorderRadius 0;
+ border-right: none;
+ margin-right: 0;
}
/* Only Step */
.ui.steps .step:only-child {
- border-radius: @stepsBorderRadius;
+ border-radius: @stepsBorderRadius;
}
-
/*******************************
Content
*******************************/
/* Title */
.ui.steps .step .title {
- font-family: @titleFontFamily;
- font-size: @titleFontSize;
- font-weight: @titleFontWeight;
+ font-family: @titleFontFamily;
+ font-size: @titleFontSize;
+ font-weight: @titleFontWeight;
}
.ui.steps .step > .title {
- width: 100%;
+ width: 100%;
}
/* Description */
.ui.steps .step .description {
- font-weight: @descriptionFontWeight;
- font-size: @descriptionFontSize;
- color: @descriptionColor;
+ font-weight: @descriptionFontWeight;
+ font-size: @descriptionFontSize;
+ color: @descriptionColor;
}
.ui.steps .step > .description {
- width: 100%;
+ width: 100%;
}
.ui.steps .step .title ~ .description {
- margin-top: @descriptionDistance;
+ margin-top: @descriptionDistance;
}
/* Icon */
.ui.steps .step > i.icon {
- line-height: 1;
- font-size: @iconSize;
- margin: 0 @iconDistance 0 0;
+ line-height: 1;
+ font-size: @iconSize;
+ margin: 0 @iconDistance 0 0;
}
.ui.steps .step > i.icon,
.ui.steps .step > i.icon ~ .content {
- display: block;
- flex: 0 1 auto;
- align-self: @iconAlign;
+ display: block;
+ flex: 0 1 auto;
+ align-self: @iconAlign;
}
/* Horizontal Icon */
.ui.steps:not(.vertical) .step > i.icon {
- width: auto;
+ width: auto;
}
/* Link */
.ui.steps .link.step,
.ui.steps a.step {
- cursor: pointer;
+ cursor: pointer;
}
/*******************************
@@ -172,140 +165,137 @@
*******************************/
& when (@variationStepOrdered) {
- /*--------------
- Ordered
- ---------------*/
-
- .ui.ordered.steps {
- counter-reset: ordered;
- }
- .ui.ordered.steps .step::before {
- display: block;
- position: static;
- text-align: center;
- content: counter(ordered);
- align-self: @iconAlign;
- margin-right: @iconDistance;
- font-size: @iconSize;
- counter-increment: ordered;
- font-family: @orderedFontFamily;
- font-weight: @orderedFontWeight;
- }
+ /* --------------
+ Ordered
+ --------------- */
- .ui.ordered.steps .step > * {
- display: block;
- align-self: @iconAlign;
- }
+ .ui.ordered.steps {
+ counter-reset: ordered;
+ }
+ .ui.ordered.steps .step::before {
+ display: block;
+ position: static;
+ text-align: center;
+ content: counter(ordered);
+ align-self: @iconAlign;
+ margin-right: @iconDistance;
+ font-size: @iconSize;
+ counter-increment: ordered;
+ font-family: @orderedFontFamily;
+ font-weight: @orderedFontWeight;
+ }
+
+ .ui.ordered.steps .step > * {
+ display: block;
+ align-self: @iconAlign;
+ }
}
& when (@variationStepVertical) {
- /*--------------
- Vertical
- ---------------*/
+ /* --------------
+ Vertical
+ --------------- */
+
+ .ui.vertical.steps {
+ display: inline-flex;
+ flex-direction: column;
+ overflow: visible;
+ }
+ .ui.vertical.steps .step {
+ justify-content: flex-start;
+ border-radius: @borderRadius;
+ padding: @verticalPadding @horizontalPadding;
+ border-right: none;
+ border-bottom: @verticalDivider;
+ }
+ .ui.vertical.steps .step:first-child {
+ padding: @verticalPadding @horizontalPadding;
+ border-radius: @stepsBorderRadius @stepsBorderRadius 0 0;
+ }
+ .ui.vertical.steps .step:last-child {
+ border-bottom: none;
+ border-radius: 0 0 @stepsBorderRadius @stepsBorderRadius;
+ }
+ .ui.vertical.steps .step:only-child {
+ border-radius: @stepsBorderRadius;
+ }
- .ui.vertical.steps {
- display: inline-flex;
- flex-direction: column;
- overflow: visible;
- }
- .ui.vertical.steps .step {
- justify-content: flex-start;
- border-radius: @borderRadius;
- padding: @verticalPadding @horizontalPadding;
- border-right: none;
- border-bottom: @verticalDivider;
- }
- .ui.vertical.steps .step:first-child {
- padding: @verticalPadding @horizontalPadding;
- border-radius: @stepsBorderRadius @stepsBorderRadius 0 0;
- }
- .ui.vertical.steps .step:last-child {
- border-bottom: none;
- border-radius: 0 0 @stepsBorderRadius @stepsBorderRadius;
- }
- .ui.vertical.steps .step:only-child {
- border-radius: @stepsBorderRadius;
- }
-
-
- /* Arrow */
- .ui.vertical.steps .step::after {
- top: @verticalArrowTopOffset;
- right: @verticalArrowRightOffset;
- border-width: @verticalArrowBorderWidth;
- display: @verticalArrowDisplay;
- }
- .ui.right.vertical.steps .step::after {
- border-width: @verticalLeftArrowBorderWidth;
- left: @verticalLeftArrowLeftOffset;
- right: @verticalLeftArrowRightOffset;
- transform: translateY(-50%) translateX(-50%) rotate(-45deg);
- }
-
- .ui.vertical.steps .active.step::after {
- display: @verticalActiveArrowDisplay;
- }
- .ui.vertical.steps .step:last-child::after {
- display: @verticalLastArrowDisplay;
- }
- .ui.vertical.steps .active.step:last-child::after {
- display: @verticalActiveLastArrowDisplay;
- }
-}
-
-
-/*---------------
+ /* Arrow */
+ .ui.vertical.steps .step::after {
+ top: @verticalArrowTopOffset;
+ right: @verticalArrowRightOffset;
+ border-width: @verticalArrowBorderWidth;
+ display: @verticalArrowDisplay;
+ }
+ .ui.right.vertical.steps .step::after {
+ border-width: @verticalLeftArrowBorderWidth;
+ left: @verticalLeftArrowLeftOffset;
+ right: @verticalLeftArrowRightOffset;
+ transform: translateY(-50%) translateX(-50%) rotate(-45deg);
+ }
+
+ .ui.vertical.steps .active.step::after {
+ display: @verticalActiveArrowDisplay;
+ }
+ .ui.vertical.steps .step:last-child::after {
+ display: @verticalLastArrowDisplay;
+ }
+ .ui.vertical.steps .active.step:last-child::after {
+ display: @verticalActiveLastArrowDisplay;
+ }
+}
+
+/* ---------------
Responsive
-----------------*/
+---------------- */
/* Mobile (Default) */
@media only screen and (max-width: (@largestMobileScreen)) {
+ .ui.steps:not(.unstackable) {
+ display: inline-flex;
+ overflow: visible;
+ flex-direction: column;
+ }
+ .ui.steps:not(.unstackable) .step {
+ width: 100% !important;
+ flex-direction: column;
+ border-radius: @borderRadius;
+ padding: @verticalPadding @horizontalPadding;
+ border-right: none;
+ border-bottom: @stepsBorder;
+ }
+ .ui.steps:not(.unstackable) .step:first-child {
+ padding: @verticalPadding @horizontalPadding;
+ border-radius: @stepsBorderRadius @stepsBorderRadius 0 0;
+ }
+ .ui.steps:not(.unstackable) .step:last-child {
+ border-radius: 0 0 @stepsBorderRadius @stepsBorderRadius;
+ border-bottom: none;
+ }
- .ui.steps:not(.unstackable) {
- display: inline-flex;
- overflow: visible;
- flex-direction: column;
- }
- .ui.steps:not(.unstackable) .step {
- width: 100% !important;
- flex-direction: column;
- border-radius: @borderRadius;
- padding: @verticalPadding @horizontalPadding;
- border-right: none;
- border-bottom: @stepsBorder;
- }
- .ui.steps:not(.unstackable) .step:first-child {
- padding: @verticalPadding @horizontalPadding;
- border-radius: @stepsBorderRadius @stepsBorderRadius 0 0;
- }
- .ui.steps:not(.unstackable) .step:last-child {
- border-radius: 0 0 @stepsBorderRadius @stepsBorderRadius;
- border-bottom: none;
- }
-
- /* Arrow */
- .ui.steps:not(.unstackable) .step::after {
- top: unset;
- bottom: -@arrowSize;
- right: 50%;
- transform: translateY(-50%) translateX(50%) rotate(45deg);
- }
- & when (@variationStepVertical) {
- .ui.vertical.steps .active.step:last-child::after {
- display: none;
+ /* Arrow */
+ .ui.steps:not(.unstackable) .step::after {
+ top: unset;
+ bottom: -@arrowSize;
+ right: 50%;
+ transform: translateY(-50%) translateX(50%) rotate(45deg);
+ }
+ & when (@variationStepVertical) {
+ .ui.vertical.steps .active.step:last-child::after {
+ display: none;
+ }
}
- }
- /* Content */
- .ui.steps:not(.unstackable) .step .content {
- text-align: center;
- }
- /* Icon */
- .ui.steps:not(.unstackable) .step > i.icon,
- .ui.ordered.steps:not(.unstackable) .step::before {
- margin: 0 0 @mobileIconDistance 0;
- }
+ /* Content */
+ .ui.steps:not(.unstackable) .step .content {
+ text-align: center;
+ }
+ /* Icon */
+ .ui.steps:not(.unstackable) .step > i.icon,
+ .ui.ordered.steps:not(.unstackable) .step::before {
+ margin: 0 0 @mobileIconDistance 0;
+ }
}
/*******************************
@@ -317,8 +307,8 @@
.ui.steps .link.step:hover,
.ui.steps a.step:hover::after,
.ui.steps a.step:hover {
- background: @hoverBackground;
- color: @hoverColor;
+ background: @hoverBackground;
+ color: @hoverColor;
}
/* Link Down */
@@ -326,38 +316,38 @@
.ui.steps .link.step:active,
.ui.steps a.step:active::after,
.ui.steps a.step:active {
- background: @downBackground;
- color: @downColor;
+ background: @downBackground;
+ color: @downColor;
}
/* Active */
.ui.steps .step.active {
- cursor: auto;
- background: @activeBackground;
+ cursor: auto;
+ background: @activeBackground;
}
.ui.steps .step.active::after {
- background: @activeBackground;
+ background: @activeBackground;
}
.ui.steps .step.active .title {
- color: @activeColor;
+ color: @activeColor;
}
.ui.ordered.steps .step.active::before,
.ui.steps .active.step i.icon {
- color: @activeIconColor;
+ color: @activeIconColor;
}
/* Active Arrow */
.ui.steps .step::after {
- display: @arrowDisplay;
+ display: @arrowDisplay;
}
.ui.steps .active.step::after {
- display: @activeArrowDisplay;
+ display: @activeArrowDisplay;
}
.ui.steps .step:last-child::after {
- display: @lastArrowDisplay;
+ display: @lastArrowDisplay;
}
.ui.steps .active.step:last-child::after {
- display: @activeLastArrowDisplay;
+ display: @activeLastArrowDisplay;
}
/* Active Hover */
@@ -365,270 +355,266 @@
.ui.steps .link.active.step:hover,
.ui.steps a.active.step:hover::after,
.ui.steps a.active.step:hover {
- cursor: pointer;
- background: @activeHoverBackground;
- color: @activeHoverColor;
+ cursor: pointer;
+ background: @activeHoverBackground;
+ color: @activeHoverColor;
}
/* Completed */
.ui.steps .step.completed > i.icon::before,
.ui.ordered.steps .step.completed::before {
- color: @completedColor;
+ color: @completedColor;
}
& when (@variationStepDisabled) {
- /* Disabled */
- .ui.steps .disabled.step {
- cursor: auto;
- background: @disabledBackground;
- pointer-events: none;
- }
- .ui.steps .disabled.step,
- .ui.steps .disabled.step .title,
- .ui.steps .disabled.step .description {
- color: @disabledColor;
- }
- .ui.steps .disabled.step::after {
- background: @disabledBackground;
- }
+ /* Disabled */
+ .ui.steps .disabled.step {
+ cursor: auto;
+ background: @disabledBackground;
+ pointer-events: none;
+ }
+ .ui.steps .disabled.step,
+ .ui.steps .disabled.step .title,
+ .ui.steps .disabled.step .description {
+ color: @disabledColor;
+ }
+ .ui.steps .disabled.step::after {
+ background: @disabledBackground;
+ }
}
-
/*******************************
Variations
*******************************/
& when (@variationStepStackable) {
- /*--------------
- Stackable
- ---------------*/
-
- /* Tablet Or Below */
- @media only screen and (max-width: @largestTabletScreen) {
+ /* --------------
+ Stackable
+ --------------- */
+
+ /* Tablet Or Below */
+ @media only screen and (max-width: @largestTabletScreen) {
+ .ui[class*="tablet stackable"].steps {
+ display: inline-flex;
+ overflow: visible;
+ flex-direction: column;
+ }
+
+ /* Steps */
+ .ui[class*="tablet stackable"].steps .step {
+ flex-direction: column;
+ border-radius: @borderRadius;
+ padding: @verticalPadding @horizontalPadding;
+ border-right: none;
+ border-bottom: @stepsBorder;
+ }
+ .ui[class*="tablet stackable"].steps .step:first-child {
+ padding: @verticalPadding @horizontalPadding;
+ border-radius: @stepsBorderRadius @stepsBorderRadius 0 0;
+ }
+ .ui[class*="tablet stackable"].steps .step:last-child {
+ border-radius: 0 0 @stepsBorderRadius @stepsBorderRadius;
+ border-bottom: none;
+ }
+
+ /* Arrow */
+ .ui[class*="tablet stackable"].steps .step::after {
+ top: unset;
+ bottom: -@arrowSize;
+ right: 50%;
+ transform: translateY(-50%) translateX(50%) rotate(45deg);
+ }
+
+ /* Content */
+ .ui[class*="tablet stackable"].steps .step .content {
+ text-align: center;
+ }
+
+ /* Icon */
+ .ui[class*="tablet stackable"].steps .step > i.icon,
+ .ui[class*="tablet stackable"].ordered.steps .step::before {
+ margin: 0 0 @mobileIconDistance 0;
+ }
+ }
+}
- .ui[class*="tablet stackable"].steps {
- display: inline-flex;
- overflow: visible;
- flex-direction: column;
+& when (@variationStepFluid) {
+ /* --------------
+ Fluid
+ --------------- */
+
+ /* Fluid */
+ .ui.fluid.steps {
+ display: flex;
+ width: 100%;
}
+}
- /* Steps */
- .ui[class*="tablet stackable"].steps .step {
- flex-direction: column;
- border-radius: @borderRadius;
- padding: @verticalPadding @horizontalPadding;
- border-right: none;
- border-bottom: @stepsBorder;
+& when (@variationStepAttached) {
+ /* --------------
+ Attached
+ --------------- */
+
+ /* Top */
+ .ui.attached.steps {
+ width: @attachedWidth !important;
+ margin: 0 @attachedHorizontalOffset @attachedVerticalOffset;
+ max-width: @attachedWidth;
+ border-radius: @stepsBorderRadius @stepsBorderRadius 0 0;
}
- .ui[class*="tablet stackable"].steps .step:first-child {
- padding: @verticalPadding @horizontalPadding;
- border-radius: @stepsBorderRadius @stepsBorderRadius 0 0;
+ .ui.attached.steps .step:first-child {
+ border-radius: @stepsBorderRadius 0 0 0;
}
- .ui[class*="tablet stackable"].steps .step:last-child {
- border-radius: 0 0 @stepsBorderRadius @stepsBorderRadius;
- border-bottom: none;
+ .ui.attached.steps .step:last-child {
+ border-radius: 0 @stepsBorderRadius 0 0;
}
- /* Arrow */
- .ui[class*="tablet stackable"].steps .step::after {
- top: unset;
- bottom: -@arrowSize;
- right: 50%;
- transform: translateY(-50%) translateX(50%) rotate(45deg);
+ /* Bottom */
+ .ui.bottom.attached.steps {
+ margin: @attachedVerticalOffset @attachedHorizontalOffset 0;
+ border-radius: 0 0 @stepsBorderRadius @stepsBorderRadius;
}
-
- /* Content */
- .ui[class*="tablet stackable"].steps .step .content {
- text-align: center;
+ .ui.bottom.attached.steps .step:first-child {
+ border-radius: 0 0 0 @stepsBorderRadius;
}
-
- /* Icon */
- .ui[class*="tablet stackable"].steps .step > i.icon,
- .ui[class*="tablet stackable"].ordered.steps .step::before {
- margin: 0 0 @mobileIconDistance 0;
+ .ui.bottom.attached.steps .step:last-child {
+ border-radius: 0 0 @stepsBorderRadius 0;
}
-
- }
}
-& when (@variationStepFluid) {
- /*--------------
- Fluid
- ---------------*/
-
- /* Fluid */
- .ui.fluid.steps {
- display: flex;
- width: 100%;
- }
-}
-
-& when (@variationStepAttached) {
- /*--------------
- Attached
- ---------------*/
-
- /* Top */
- .ui.attached.steps {
- width: @attachedWidth !important;
- margin: 0 @attachedHorizontalOffset @attachedVerticalOffset;
- max-width: @attachedWidth;
- border-radius: @stepsBorderRadius @stepsBorderRadius 0 0;
- }
- .ui.attached.steps .step:first-child {
- border-radius: @stepsBorderRadius 0 0 0;
- }
- .ui.attached.steps .step:last-child {
- border-radius: 0 @stepsBorderRadius 0 0;
- }
-
- /* Bottom */
- .ui.bottom.attached.steps {
- margin: @attachedVerticalOffset @attachedHorizontalOffset 0;
- border-radius: 0 0 @stepsBorderRadius @stepsBorderRadius;
- }
- .ui.bottom.attached.steps .step:first-child {
- border-radius: 0 0 0 @stepsBorderRadius;
- }
- .ui.bottom.attached.steps .step:last-child {
- border-radius: 0 0 @stepsBorderRadius 0;
- }
+& when (@variationStepEqualWidth) {
+ /* -------------------
+ Evenly Divided
+ -------------------- */
+
+ .ui.one.steps,
+ .ui.two.steps,
+ .ui.three.steps,
+ .ui.four.steps,
+ .ui.five.steps,
+ .ui.six.steps,
+ .ui.seven.steps,
+ .ui.eight.steps {
+ width: 100%;
+ }
+ .ui.one.steps > .step,
+ .ui.two.steps > .step,
+ .ui.three.steps > .step,
+ .ui.four.steps > .step,
+ .ui.five.steps > .step,
+ .ui.six.steps > .step,
+ .ui.seven.steps > .step,
+ .ui.eight.steps > .step {
+ flex-wrap: nowrap;
+ }
+ .ui.one.steps > .step {
+ width: 100%;
+ }
+ .ui.two.steps > .step {
+ width: 50%;
+ }
+ .ui.three.steps > .step {
+ width: 33.333%;
+ }
+ .ui.four.steps > .step {
+ width: 25%;
+ }
+ .ui.five.steps > .step {
+ width: 20%;
+ }
+ .ui.six.steps > .step {
+ width: 16.666%;
+ }
+ .ui.seven.steps > .step {
+ width: 14.285%;
+ }
+ .ui.eight.steps > .step {
+ width: 12.5%;
+ }
}
-& when (@variationStepEqualWidth) {
- /*-------------------
- Evenly Divided
- --------------------*/
-
- .ui.one.steps,
- .ui.two.steps,
- .ui.three.steps,
- .ui.four.steps,
- .ui.five.steps,
- .ui.six.steps,
- .ui.seven.steps,
- .ui.eight.steps {
- width: 100%;
- }
- .ui.one.steps > .step,
- .ui.two.steps > .step,
- .ui.three.steps > .step,
- .ui.four.steps > .step,
- .ui.five.steps > .step,
- .ui.six.steps > .step,
- .ui.seven.steps > .step,
- .ui.eight.steps > .step {
- flex-wrap: nowrap;
- }
- .ui.one.steps > .step {
- width: 100%;
- }
- .ui.two.steps > .step {
- width: 50%;
- }
- .ui.three.steps > .step {
- width: 33.333%;
- }
- .ui.four.steps > .step {
- width: 25%;
- }
- .ui.five.steps > .step {
- width: 20%;
- }
- .ui.six.steps > .step {
- width: 16.666%;
- }
- .ui.seven.steps > .step {
- width: 14.285%;
- }
- .ui.eight.steps > .step {
- width: 12.500%;
- }
-}
-
-/*-------------------
+/* -------------------
Sizes
---------------------*/
+-------------------- */
.ui.steps .step,
.ui.step {
- font-size: @medium;
+ font-size: @medium;
}
& when not (@variationStepSizes = false) {
- each(@variationStepSizes, {
- @s: @@value;
- .ui.@{value}.steps .step,
- .ui.@{value}.step {
- font-size: @s;
- }
- })
+ each(@variationStepSizes, {
+ @s: @@value;
+ .ui.@{value}.steps .step,
+ .ui.@{value}.step {
+ font-size: @s;
+ }
+ });
}
& when (@variationStepInverted) {
- /*--------------
- Inverted
- ---------------*/
-
- .ui.inverted.steps {
- border: 1px solid @solidWhiteBorderColor;
- }
-
- .ui.inverted.steps .step {
- color: @invertedTextColor;
- background: @black;
- border-color: @solidWhiteBorderColor;
- }
-
- .ui.inverted.steps .step::after {
- background-color: @black;
- border-color: @solidWhiteBorderColor;
- }
-
- .ui.inverted.steps .step .description {
- color: @invertedTextColor;
- }
-
- /* Active */
- .ui.inverted.steps .step.active,
- .ui.inverted.steps .step.active::after {
- background: @invertedActiveBackground;
- }
- .ui.inverted.ordered.steps .step.active::before,
- .ui.inverted.steps .active.step i.icon {
- color: @invertedSelectedTextColor;
- }
-
- & when (@variationStepDisabled) {
- /* Disabled */
- .ui.inverted.steps .disabled.step,
- .ui.inverted.steps .disabled.step::after {
- background: @invertedDisabledBackground;
- }
- .ui.inverted.steps .disabled.step,
- .ui.inverted.steps .disabled.step .title,
- .ui.inverted.steps .disabled.step .description {
- color: @invertedDisabledTextColor;
- }
- }
-
- /* Link Hover */
- .ui.inverted.steps .link.step:hover::after,
- .ui.inverted.steps .link.step:hover,
- .ui.inverted.steps a.step:hover::after,
- .ui.inverted.steps a.step:hover {
- background: @invertedHoverBackground;
- color: @invertedHoveredTextColor;
- }
-
- /* Link Down */
- .ui.inverted.steps .link.step:active::after,
- .ui.inverted.steps .link.step:active,
- .ui.inverted.steps a.step:active::after,
- .ui.inverted.steps a.step:active {
- background: @invertedActiveHoverBackground;
- color: @invertedPressedTextColor;
- }
-}
+ /* --------------
+ Inverted
+ --------------- */
+
+ .ui.inverted.steps {
+ border: 1px solid @solidWhiteBorderColor;
+ }
+ .ui.inverted.steps .step {
+ color: @invertedTextColor;
+ background: @black;
+ border-color: @solidWhiteBorderColor;
+ }
+
+ .ui.inverted.steps .step::after {
+ background-color: @black;
+ border-color: @solidWhiteBorderColor;
+ }
+
+ .ui.inverted.steps .step .description {
+ color: @invertedTextColor;
+ }
+
+ /* Active */
+ .ui.inverted.steps .step.active,
+ .ui.inverted.steps .step.active::after {
+ background: @invertedActiveBackground;
+ }
+ .ui.inverted.ordered.steps .step.active::before,
+ .ui.inverted.steps .active.step i.icon {
+ color: @invertedSelectedTextColor;
+ }
+
+ & when (@variationStepDisabled) {
+ /* Disabled */
+ .ui.inverted.steps .disabled.step,
+ .ui.inverted.steps .disabled.step::after {
+ background: @invertedDisabledBackground;
+ }
+ .ui.inverted.steps .disabled.step,
+ .ui.inverted.steps .disabled.step .title,
+ .ui.inverted.steps .disabled.step .description {
+ color: @invertedDisabledTextColor;
+ }
+ }
+
+ /* Link Hover */
+ .ui.inverted.steps .link.step:hover::after,
+ .ui.inverted.steps .link.step:hover,
+ .ui.inverted.steps a.step:hover::after,
+ .ui.inverted.steps a.step:hover {
+ background: @invertedHoverBackground;
+ color: @invertedHoveredTextColor;
+ }
+
+ /* Link Down */
+ .ui.inverted.steps .link.step:active::after,
+ .ui.inverted.steps .link.step:active,
+ .ui.inverted.steps a.step:active::after,
+ .ui.inverted.steps a.step:active {
+ background: @invertedActiveHoverBackground;
+ color: @invertedPressedTextColor;
+ }
+}
.loadUIOverrides();
diff --git a/definitions/elements/text.less b/definitions/elements/text.less
index f048831..d9882a9 100644
--- a/definitions/elements/text.less
+++ b/definitions/elements/text.less
@@ -1,6 +1,6 @@
/*!
* # Fomantic-UI - Text
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
@@ -8,69 +8,67 @@
*
*/
-
/*******************************
Theme
*******************************/
-@type : 'element';
-@element : 'text';
-
-@import (multiple) '../../theme.config';
+@type: "element";
+@element: "text";
+@import (multiple) "../../theme.config";
/*******************************
Text
*******************************/
span.ui.text {
- line-height: @lineHeight;
+ line-height: @lineHeight;
}
& when not (@variationTextColors = false) {
- each(@variationTextColors, {
- @color: @value;
- @c: @colors[@@color][color];
- @l: @colors[@@color][light];
+ each(@variationTextColors, {
+ @color: @value;
+ @c: @colors[@@color][color];
+ @l: @colors[@@color][light];
- span.ui.@{color}.text {
- color: @c;
- }
- & when (@variationTextInverted) {
- span.ui.inverted.@{color}.text {
- color: @l;
- }
- }
- })
+ span.ui.@{color}.text {
+ color: @c;
+ }
+ & when (@variationTextInverted) {
+ span.ui.inverted.@{color}.text {
+ color: @l;
+ }
+ }
+ });
}
& when not (@variationTextStates = false) {
- each(@variationTextStates, {
- @state: @value;
- @c: @textStates[@@state][color];
+ each(@variationTextStates, {
+ @state: @value;
+ @c: @textStates[@@state][color];
- span.ui.@{state}.text {
- color: @c;
- }
- })
+ span.ui.@{state}.text {
+ color: @c;
+ }
+ });
}
& when (@variationTextDisabled) {
- span.ui.disabled.text {
- opacity: @disabledOpacity;
- }
+ span.ui.disabled.text {
+ opacity: @disabledOpacity;
+ }
}
/* Sizes */
span.ui.medium.text {
- font-size: @medium;
+ font-size: @medium;
}
& when not (@variationTextSizes = false) {
- each(@variationTextSizes, {
- @s: @@value;
- span.ui.@{value}.text {
- font-size: @s;
- }
- })
+ each(@variationTextSizes, {
+ @s: @@value;
+ span.ui.@{value}.text {
+ font-size: @s;
+ }
+ });
}
.loadUIOverrides();
diff --git a/definitions/globals/reset.less b/definitions/globals/reset.less
index c6b4220..ec345b6 100644
--- a/definitions/globals/reset.less
+++ b/definitions/globals/reset.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Reset
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,10 +12,10 @@
Theme
*******************************/
-@type : 'global';
-@element : 'reset';
+@type: "global";
+@element: "reset";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Reset
@@ -25,16 +25,19 @@
*,
*::before,
*::after {
- box-sizing: inherit;
+ box-sizing: inherit;
}
html {
- box-sizing: border-box;
+ box-sizing: border-box;
}
/* iPad Input Shadows */
-input[type="text"], input[type="email"], input[type="search"], input[type="password"] {
- -webkit-appearance: none;
- -moz-appearance: none; /* mobile firefox too! */
+input[type="text"],
+input[type="email"],
+input[type="search"],
+input[type="password"] {
+ -webkit-appearance: none;
+ -moz-appearance: none; /* mobile firefox too! */
}
.loadUIOverrides();
diff --git a/definitions/globals/site.js b/definitions/globals/site.js
index 9cdbcf7..93e21f0 100644
--- a/definitions/globals/site.js
+++ b/definitions/globals/site.js
@@ -1,493 +1,453 @@
/*!
* # Fomantic-UI - Site
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-;(function ($, window, document, undefined) {
-
-$.isFunction = $.isFunction || function(obj) {
- return typeof obj === "function" && typeof obj.nodeType !== "number";
-};
-
-$.site = $.fn.site = function(parameters) {
- var
- time = new Date().getTime(),
- performance = [],
-
- query = arguments[0],
- methodInvoked = (typeof query == 'string'),
- queryArguments = [].slice.call(arguments, 1),
-
- settings = ( $.isPlainObject(parameters) )
- ? $.extend(true, {}, $.site.settings, parameters)
- : $.extend({}, $.site.settings),
-
- namespace = settings.namespace,
- error = settings.error,
-
- moduleNamespace = 'module-' + namespace,
-
- $document = $(document),
- $module = $document,
- element = this,
- instance = $module.data(moduleNamespace),
-
- module,
- returnedValue
- ;
- module = {
-
- initialize: function() {
- module.instantiate();
- },
-
- instantiate: function() {
- module.verbose('Storing instance of site', module);
- instance = module;
- $module
- .data(moduleNamespace, module)
- ;
- },
-
- normalize: function() {
- module.fix.console();
- module.fix.requestAnimationFrame();
- },
-
- fix: {
- console: function() {
- module.debug('Normalizing window.console');
- if (console === undefined || console.log === undefined) {
- module.verbose('Console not available, normalizing events');
- module.disable.console();
- }
- if (typeof console.group == 'undefined' || typeof console.groupEnd == 'undefined' || typeof console.groupCollapsed == 'undefined') {
- module.verbose('Console group not available, normalizing events');
- window.console.group = function() {};
- window.console.groupEnd = function() {};
- window.console.groupCollapsed = function() {};
- }
- if (typeof console.markTimeline == 'undefined') {
- module.verbose('Mark timeline not available, normalizing events');
- window.console.markTimeline = function() {};
- }
- },
- consoleClear: function() {
- module.debug('Disabling programmatic console clearing');
- window.console.clear = function() {};
- },
- requestAnimationFrame: function() {
- module.debug('Normalizing requestAnimationFrame');
- if(window.requestAnimationFrame === undefined) {
- module.debug('RequestAnimationFrame not available, normalizing event');
- window.requestAnimationFrame = window.requestAnimationFrame
- || window.mozRequestAnimationFrame
- || window.webkitRequestAnimationFrame
- || window.msRequestAnimationFrame
- || function(callback) { setTimeout(callback, 0); }
- ;
- }
- }
- },
+(function ($, window, document) {
+ 'use strict';
+
+ function isFunction(obj) {
+ return typeof obj === 'function' && typeof obj.nodeType !== 'number';
+ }
- moduleExists: function(name) {
- return ($.fn[name] !== undefined && $.fn[name].settings !== undefined);
- },
+ window = window !== undefined && window.Math === Math
+ ? window
+ : globalThis;
- enabled: {
- modules: function(modules) {
- var
- enabledModules = []
- ;
- modules = modules || settings.modules;
- $.each(modules, function(index, name) {
- if(module.moduleExists(name)) {
- enabledModules.push(name);
- }
- });
- return enabledModules;
- }
- },
-
- disabled: {
- modules: function(modules) {
+ $.fn.site = function (parameters) {
var
- disabledModules = []
- ;
- modules = modules || settings.modules;
- $.each(modules, function(index, name) {
- if(!module.moduleExists(name)) {
- disabledModules.push(name);
- }
- });
- return disabledModules;
- }
- },
-
- change: {
- setting: function(setting, value, modules, modifyExisting) {
- modules = (typeof modules === 'string')
- ? (modules === 'all')
- ? settings.modules
- : [modules]
- : modules || settings.modules
- ;
- modifyExisting = (modifyExisting !== undefined)
- ? modifyExisting
- : true
+ time = Date.now(),
+ performance = [],
+
+ query = arguments[0],
+ methodInvoked = typeof query === 'string',
+ queryArguments = [].slice.call(arguments, 1),
+
+ settings = $.isPlainObject(parameters)
+ ? $.extend(true, {}, $.site.settings, parameters)
+ : $.extend({}, $.site.settings),
+
+ namespace = settings.namespace,
+ error = settings.error,
+
+ moduleNamespace = 'module-' + namespace,
+
+ $document = $(document),
+ $module = $document,
+ element = this,
+ instance = $module.data(moduleNamespace),
+
+ module,
+ returnedValue
;
- $.each(modules, function(index, name) {
- var
- namespace = (module.moduleExists(name))
- ? $.fn[name].settings.namespace || false
- : true,
- $existingModules
- ;
- if(module.moduleExists(name)) {
- module.verbose('Changing default setting', setting, value, name);
- $.fn[name].settings[setting] = value;
- if(modifyExisting && namespace) {
- $existingModules = $(':data(module-' + namespace + ')');
- if($existingModules.length > 0) {
- module.verbose('Modifying existing settings', $existingModules);
- $existingModules[name]('setting', setting, value);
- }
+ module = {
+
+ initialize: function () {
+ module.instantiate();
+ },
+
+ instantiate: function () {
+ module.verbose('Storing instance of site', module);
+ instance = module;
+ $module
+ .data(moduleNamespace, module)
+ ;
+ },
+
+ normalize: function () {
+ // keep the function for backward compatibility
+ // eslint-disable-next-line no-useless-return
+ return;
+ },
+
+ fix: {
+ consoleClear: function () {
+ module.debug('Disabling programmatic console clearing');
+ window.console.clear = function () {};
+ },
+ },
+
+ moduleExists: function (name) {
+ return $.fn[name] !== undefined && $.fn[name].settings !== undefined;
+ },
+
+ enabled: {
+ modules: function (modules) {
+ var
+ enabledModules = []
+ ;
+ modules = modules || settings.modules;
+ $.each(modules, function (index, name) {
+ if (module.moduleExists(name)) {
+ enabledModules.push(name);
+ }
+ });
+
+ return enabledModules;
+ },
+ },
+
+ disabled: {
+ modules: function (modules) {
+ var
+ disabledModules = []
+ ;
+ modules = modules || settings.modules;
+ $.each(modules, function (index, name) {
+ if (!module.moduleExists(name)) {
+ disabledModules.push(name);
+ }
+ });
+
+ return disabledModules;
+ },
+ },
+
+ change: {
+ setting: function (setting, value, modules, modifyExisting) {
+ modules = typeof modules === 'string'
+ ? (modules === 'all'
+ ? settings.modules
+ : [modules])
+ : modules || settings.modules;
+ modifyExisting = modifyExisting !== undefined
+ ? modifyExisting
+ : true;
+ $.each(modules, function (index, name) {
+ var
+ namespace = module.moduleExists(name)
+ ? $.fn[name].settings.namespace || false
+ : true,
+ $existingModules
+ ;
+ if (module.moduleExists(name)) {
+ module.verbose('Changing default setting', setting, value, name);
+ $.fn[name].settings[setting] = value;
+ if (modifyExisting && namespace) {
+ $existingModules = $(':data(module-' + namespace + ')');
+ if ($existingModules.length > 0) {
+ module.verbose('Modifying existing settings', $existingModules);
+ $existingModules[name]('setting', setting, value);
+ }
+ }
+ }
+ });
+ },
+ settings: function (newSettings, modules, modifyExisting) {
+ modules = typeof modules === 'string'
+ ? [modules]
+ : modules || settings.modules;
+ modifyExisting = modifyExisting !== undefined
+ ? modifyExisting
+ : true;
+ $.each(modules, function (index, name) {
+ var
+ $existingModules
+ ;
+ if (module.moduleExists(name)) {
+ module.verbose('Changing default setting', newSettings, name);
+ $.extend(true, $.fn[name].settings, newSettings);
+ if (modifyExisting && namespace) {
+ $existingModules = $(':data(module-' + namespace + ')');
+ if ($existingModules.length > 0) {
+ module.verbose('Modifying existing settings', $existingModules);
+ $existingModules[name]('setting', newSettings);
+ }
+ }
+ }
+ });
+ },
+ },
+
+ enable: {
+ console: function () {
+ module.console(true);
+ },
+ debug: function (modules, modifyExisting) {
+ modules = modules || settings.modules;
+ module.debug('Enabling debug for modules', modules);
+ module.change.setting('debug', true, modules, modifyExisting);
+ },
+ verbose: function (modules, modifyExisting) {
+ modules = modules || settings.modules;
+ module.debug('Enabling verbose debug for modules', modules);
+ module.change.setting('verbose', true, modules, modifyExisting);
+ },
+ },
+ disable: {
+ console: function () {
+ module.console(false);
+ },
+ debug: function (modules, modifyExisting) {
+ modules = modules || settings.modules;
+ module.debug('Disabling debug for modules', modules);
+ module.change.setting('debug', false, modules, modifyExisting);
+ },
+ verbose: function (modules, modifyExisting) {
+ modules = modules || settings.modules;
+ module.debug('Disabling verbose debug for modules', modules);
+ module.change.setting('verbose', false, modules, modifyExisting);
+ },
+ },
+
+ console: function (enable) {
+ if (enable) {
+ if (instance.cache.console === undefined) {
+ module.error(error.console);
+
+ return;
+ }
+ module.debug('Restoring console function');
+ window.console = instance.cache.console;
+ } else {
+ module.debug('Disabling console function');
+ instance.cache.console = window.console;
+ window.console = {
+ clear: function () {},
+ error: function () {},
+ group: function () {},
+ groupCollapsed: function () {},
+ groupEnd: function () {},
+ info: function () {},
+ log: function () {},
+ table: function () {},
+ warn: function () {},
+ };
+ }
+ },
+
+ destroy: function () {
+ module.verbose('Destroying previous site for', $module);
+ $module
+ .removeData(moduleNamespace)
+ ;
+ },
+
+ cache: {},
+
+ setting: function (name, value) {
+ if ($.isPlainObject(name)) {
+ $.extend(true, settings, name);
+ } else if (value !== undefined) {
+ settings[name] = value;
+ } else {
+ return settings[name];
+ }
+ },
+ internal: function (name, value) {
+ if ($.isPlainObject(name)) {
+ $.extend(true, module, name);
+ } else if (value !== undefined) {
+ module[name] = value;
+ } else {
+ return module[name];
+ }
+ },
+ debug: function () {
+ if (settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.debug.apply(console, arguments);
+ }
+ }
+ },
+ verbose: function () {
+ if (settings.verbose && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.verbose.apply(console, arguments);
+ }
+ }
+ },
+ error: function () {
+ module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
+ module.error.apply(console, arguments);
+ },
+ performance: {
+ log: function (message) {
+ var
+ currentTime,
+ executionTime,
+ previousTime
+ ;
+ if (settings.performance) {
+ currentTime = Date.now();
+ previousTime = time || currentTime;
+ executionTime = currentTime - previousTime;
+ time = currentTime;
+ performance.push({
+ Element: element,
+ Name: message[0],
+ Arguments: [].slice.call(message, 1) || '',
+ 'Execution Time': executionTime,
+ });
+ }
+ clearTimeout(module.performance.timer);
+ module.performance.timer = setTimeout(module.performance.display, 500);
+ },
+ display: function () {
+ var
+ title = settings.name + ':',
+ totalTime = 0
+ ;
+ time = false;
+ clearTimeout(module.performance.timer);
+ $.each(performance, function (index, data) {
+ totalTime += data['Execution Time'];
+ });
+ title += ' ' + totalTime + 'ms';
+ if (performance.length > 0) {
+ console.groupCollapsed(title);
+ if (console.table) {
+ console.table(performance);
+ } else {
+ $.each(performance, function (index, data) {
+ console.log(data.Name + ': ' + data['Execution Time'] + 'ms');
+ });
+ }
+ console.groupEnd();
+ }
+ performance = [];
+ },
+ },
+ invoke: function (query, passedArguments, context) {
+ var
+ object = instance,
+ maxDepth,
+ found,
+ response
+ ;
+ passedArguments = passedArguments || queryArguments;
+ context = context || element;
+ if (typeof query === 'string' && object !== undefined) {
+ query = query.split(/[ .]/);
+ maxDepth = query.length - 1;
+ $.each(query, function (depth, value) {
+ var camelCaseValue = depth !== maxDepth
+ ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
+ : query
+ ;
+ if ($.isPlainObject(object[camelCaseValue]) && (depth !== maxDepth)) {
+ object = object[camelCaseValue];
+ } else if (object[camelCaseValue] !== undefined) {
+ found = object[camelCaseValue];
+
+ return false;
+ } else if ($.isPlainObject(object[value]) && (depth !== maxDepth)) {
+ object = object[value];
+ } else if (object[value] !== undefined) {
+ found = object[value];
+
+ return false;
+ } else {
+ module.error(error.method, query);
+
+ return false;
+ }
+ });
+ }
+ if (isFunction(found)) {
+ response = found.apply(context, passedArguments);
+ } else if (found !== undefined) {
+ response = found;
+ }
+ if (Array.isArray(returnedValue)) {
+ returnedValue.push(response);
+ } else if (returnedValue !== undefined) {
+ returnedValue = [returnedValue, response];
+ } else if (response !== undefined) {
+ returnedValue = response;
+ }
+
+ return found;
+ },
+ };
+
+ if (methodInvoked) {
+ if (instance === undefined) {
+ module.initialize();
}
- }
- });
- },
- settings: function(newSettings, modules, modifyExisting) {
- modules = (typeof modules === 'string')
- ? [modules]
- : modules || settings.modules
- ;
- modifyExisting = (modifyExisting !== undefined)
- ? modifyExisting
- : true
- ;
- $.each(modules, function(index, name) {
- var
- $existingModules
- ;
- if(module.moduleExists(name)) {
- module.verbose('Changing default setting', newSettings, name);
- $.extend(true, $.fn[name].settings, newSettings);
- if(modifyExisting && namespace) {
- $existingModules = $(':data(module-' + namespace + ')');
- if($existingModules.length > 0) {
- module.verbose('Modifying existing settings', $existingModules);
- $existingModules[name]('setting', newSettings);
- }
+ module.invoke(query);
+ } else {
+ if (instance !== undefined) {
+ module.destroy();
}
- }
- });
- }
- },
-
- enable: {
- console: function() {
- module.console(true);
- },
- debug: function(modules, modifyExisting) {
- modules = modules || settings.modules;
- module.debug('Enabling debug for modules', modules);
- module.change.setting('debug', true, modules, modifyExisting);
- },
- verbose: function(modules, modifyExisting) {
- modules = modules || settings.modules;
- module.debug('Enabling verbose debug for modules', modules);
- module.change.setting('verbose', true, modules, modifyExisting);
- }
- },
- disable: {
- console: function() {
- module.console(false);
- },
- debug: function(modules, modifyExisting) {
- modules = modules || settings.modules;
- module.debug('Disabling debug for modules', modules);
- module.change.setting('debug', false, modules, modifyExisting);
- },
- verbose: function(modules, modifyExisting) {
- modules = modules || settings.modules;
- module.debug('Disabling verbose debug for modules', modules);
- module.change.setting('verbose', false, modules, modifyExisting);
- }
- },
-
- console: function(enable) {
- if(enable) {
- if(instance.cache.console === undefined) {
- module.error(error.console);
- return;
- }
- module.debug('Restoring console function');
- window.console = instance.cache.console;
- }
- else {
- module.debug('Disabling console function');
- instance.cache.console = window.console;
- window.console = {
- clear : function(){},
- error : function(){},
- group : function(){},
- groupCollapsed : function(){},
- groupEnd : function(){},
- info : function(){},
- log : function(){},
- markTimeline : function(){},
- warn : function(){}
- };
- }
- },
-
- destroy: function() {
- module.verbose('Destroying previous site for', $module);
- $module
- .removeData(moduleNamespace)
- ;
- },
-
- cache: {},
-
- setting: function(name, value) {
- if( $.isPlainObject(name) ) {
- $.extend(true, settings, name);
- }
- else if(value !== undefined) {
- settings[name] = value;
- }
- else {
- return settings[name];
- }
- },
- internal: function(name, value) {
- if( $.isPlainObject(name) ) {
- $.extend(true, module, name);
- }
- else if(value !== undefined) {
- module[name] = value;
- }
- else {
- return module[name];
- }
- },
- debug: function() {
- if(settings.debug) {
- if(settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.debug.apply(console, arguments);
- }
- }
- },
- verbose: function() {
- if(settings.verbose && settings.debug) {
- if(settings.performance) {
- module.performance.log(arguments);
+ module.initialize();
}
- else {
- module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.verbose.apply(console, arguments);
- }
- }
- },
- error: function() {
- module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
- module.error.apply(console, arguments);
- },
- performance: {
- log: function(message) {
- var
- currentTime,
- executionTime,
- previousTime
- ;
- if(settings.performance) {
- currentTime = new Date().getTime();
- previousTime = time || currentTime;
- executionTime = currentTime - previousTime;
- time = currentTime;
- performance.push({
- 'Element' : element,
- 'Name' : message[0],
- 'Arguments' : [].slice.call(message, 1) || '',
- 'Execution Time' : executionTime
- });
- }
- clearTimeout(module.performance.timer);
- module.performance.timer = setTimeout(module.performance.display, 500);
- },
- display: function() {
- var
- title = settings.name + ':',
- totalTime = 0
- ;
- time = false;
- clearTimeout(module.performance.timer);
- $.each(performance, function(index, data) {
- totalTime += data['Execution Time'];
- });
- title += ' ' + totalTime + 'ms';
- if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) {
- console.groupCollapsed(title);
- if(console.table) {
- console.table(performance);
- }
- else {
- $.each(performance, function(index, data) {
- console.log(data['Name'] + ': ' + data['Execution Time']+'ms');
- });
- }
- console.groupEnd();
- }
- performance = [];
- }
- },
- invoke: function(query, passedArguments, context) {
- var
- object = instance,
- maxDepth,
- found,
- response
- ;
- passedArguments = passedArguments || queryArguments;
- context = context || element;
- if(typeof query == 'string' && object !== undefined) {
- query = query.split(/[\. ]/);
- maxDepth = query.length - 1;
- $.each(query, function(depth, value) {
- var camelCaseValue = (depth != maxDepth)
- ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
- : query
- ;
- if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) {
- object = object[camelCaseValue];
- }
- else if( object[camelCaseValue] !== undefined ) {
- found = object[camelCaseValue];
- return false;
- }
- else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) {
- object = object[value];
- }
- else if( object[value] !== undefined ) {
- found = object[value];
- return false;
- }
- else {
- module.error(error.method, query);
- return false;
- }
- });
- }
- if ( $.isFunction( found ) ) {
- response = found.apply(context, passedArguments);
- }
- else if(found !== undefined) {
- response = found;
- }
- if(Array.isArray(returnedValue)) {
- returnedValue.push(response);
- }
- else if(returnedValue !== undefined) {
- returnedValue = [returnedValue, response];
- }
- else if(response !== undefined) {
- returnedValue = response;
- }
- return found;
- }
- };
-
- if(methodInvoked) {
- if(instance === undefined) {
- module.initialize();
- }
- module.invoke(query);
- }
- else {
- if(instance !== undefined) {
- module.destroy();
- }
- module.initialize();
- }
- return (returnedValue !== undefined)
- ? returnedValue
- : this
- ;
-};
-
-$.site.settings = {
-
- name : 'Site',
- namespace : 'site',
-
- error : {
- console : 'Console cannot be restored, most likely it was overwritten outside of module',
- method : 'The method you called is not defined.'
- },
-
- debug : false,
- verbose : false,
- performance : true,
-
- modules: [
- 'accordion',
- 'api',
- 'calendar',
- 'checkbox',
- 'dimmer',
- 'dropdown',
- 'embed',
- 'form',
- 'modal',
- 'nag',
- 'popup',
- 'slider',
- 'rating',
- 'shape',
- 'sidebar',
- 'state',
- 'sticky',
- 'tab',
- 'toast',
- 'transition',
- 'visibility',
- 'visit'
- ],
-
- siteNamespace : 'site',
- namespaceStub : {
- cache : {},
- config : {},
- sections : {},
- section : {},
- utilities : {}
- }
-
-};
-
-// allows for selection of elements with data attributes
-$.extend($.expr[ ":" ], {
- data: ($.expr.createPseudo)
- ? $.expr.createPseudo(function(dataName) {
- return function(elem) {
- return !!$.data(elem, dataName);
- };
- })
- : function(elem, i, match) {
- // support: jQuery < 1.8
- return !!$.data(elem, match[ 3 ]);
- }
-});
-
-})( jQuery, window, document );
+ return returnedValue !== undefined
+ ? returnedValue
+ : this;
+ };
+ $.site = $.fn.site;
+
+ $.site.settings = {
+
+ name: 'Site',
+ namespace: 'site',
+
+ error: {
+ console: 'Console cannot be restored, most likely it was overwritten outside of module',
+ method: 'The method you called is not defined.',
+ },
+
+ debug: false,
+ verbose: false,
+ performance: true,
+
+ modules: [
+ 'accordion',
+ 'api',
+ 'calendar',
+ 'checkbox',
+ 'dimmer',
+ 'dropdown',
+ 'embed',
+ 'flyout',
+ 'form',
+ 'modal',
+ 'nag',
+ 'popup',
+ 'progress',
+ 'rating',
+ 'search',
+ 'shape',
+ 'sidebar',
+ 'slider',
+ 'state',
+ 'sticky',
+ 'tab',
+ 'toast',
+ 'transition',
+ 'visibility',
+ ],
+
+ siteNamespace: 'site',
+ namespaceStub: {
+ cache: {},
+ config: {},
+ sections: {},
+ section: {},
+ utilities: {},
+ },
+
+ };
+
+ // allows for selection of elements with data attributes
+ $.extend($.expr.pseudos, {
+ data: $.expr.createPseudo(function (dataName) {
+ return function (elem) {
+ return !!$.data(elem, dataName);
+ };
+ }),
+ });
+})(jQuery, window, document);
diff --git a/definitions/globals/site.less b/definitions/globals/site.less
index c34cc19..4aa3ca0 100644
--- a/definitions/globals/site.less
+++ b/definitions/globals/site.less
@@ -1,22 +1,21 @@
/*!
* # Fomantic-UI - Site
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-
/*******************************
Theme
*******************************/
-@type : 'global';
-@element : 'site';
+@type: "global";
+@element: "site";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Page
@@ -26,23 +25,23 @@
html,
body {
- height: 100%;
+ height: 100%;
}
html {
- font-size: @emSize;
+ font-size: @emSize;
}
body {
- margin: 0;
- padding: 0;
- overflow-x: @pageOverflowX;
- min-width: @pageMinWidth;
- background: @pageBackground;
- font-family: @pageFont;
- font-size: @fontSize;
- line-height: @lineHeight;
- color: @textColor;
+ margin: 0;
+ padding: 0;
+ overflow-x: @pageOverflowX;
+ min-width: @pageMinWidth;
+ background: @pageBackground;
+ font-family: @pageFont;
+ font-size: @fontSize;
+ line-height: @lineHeight;
+ color: @textColor;
}
/*******************************
@@ -54,28 +53,28 @@ h2,
h3,
h4,
h5 {
- font-family: @headerFont;
- line-height: @headerLineHeight;
- margin: @headerMargin;
- font-weight: @headerFontWeight;
- padding: 0;
+ font-family: @headerFont;
+ line-height: @headerLineHeight;
+ margin: @headerMargin;
+ font-weight: @headerFontWeight;
+ padding: 0;
}
h1 {
- min-height: 1rem;
- font-size: @h1;
+ min-height: 1rem;
+ font-size: @h1;
}
h2 {
- font-size: @h2;
+ font-size: @h2;
}
h3 {
- font-size: @h3;
+ font-size: @h3;
}
h4 {
- font-size: @h4;
+ font-size: @h4;
}
h5 {
- font-size: @h5;
+ font-size: @h5;
}
h1:first-child,
@@ -83,7 +82,7 @@ h2:first-child,
h3:first-child,
h4:first-child,
h5:first-child {
- margin-top: 0;
+ margin-top: 0;
}
h1:last-child,
@@ -91,105 +90,104 @@ h2:last-child,
h3:last-child,
h4:last-child,
h5:last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
-
/*******************************
Text
*******************************/
p {
- margin: @paragraphMargin;
- line-height: @paragraphLineHeight;
+ margin: @paragraphMargin;
+ line-height: @paragraphLineHeight;
}
p:first-child {
- margin-top: 0;
+ margin-top: 0;
}
p:last-child {
- margin-bottom: 0;
+ margin-bottom: 0;
}
-/*-------------------
+/* -------------------
Links
---------------------*/
+-------------------- */
a {
- color: @linkColor;
- text-decoration: @linkUnderline;
+ color: @linkColor;
+ text-decoration: @linkUnderline;
}
a:hover {
- color: @linkHoverColor;
- text-decoration: @linkHoverUnderline;
+ color: @linkHoverColor;
+ text-decoration: @linkHoverUnderline;
}
-
/*******************************
Scrollbars
*******************************/
& when (@useCustomScrollbars) {
+ /* Force Simple Scrollbars */
+ body ::-webkit-scrollbar {
+ -webkit-appearance: none;
+ width: @customScrollbarWidth;
+ height: @customScrollbarHeight;
+ }
+ body ::-webkit-scrollbar-track {
+ background: @trackBackground;
+ border-radius: @trackBorderRadius;
+ }
+ body ::-webkit-scrollbar-thumb {
+ cursor: pointer;
+ border-radius: @thumbBorderRadius;
+ background: @thumbBackground;
+ transition: @thumbTransition;
+ }
+ body ::-webkit-scrollbar-thumb:window-inactive {
+ background: @thumbInactiveBackground;
+ }
+ body ::-webkit-scrollbar-thumb:hover {
+ background: @thumbHoverBackground;
+ }
+ body .ui {
+ & when (@supportIE) {
+ /* IE11 */
+ scrollbar-face-color: @thumbBackgroundHex;
+ scrollbar-shadow-color: @thumbBackgroundHex;
+ scrollbar-track-color: @trackBackgroundHex;
+ scrollbar-arrow-color: @trackBackgroundHex;
+ }
+
+ /* firefox: first color thumb, second track */
+ scrollbar-color: @thumbBackground @trackBackground;
+ scrollbar-width: thin;
+ }
- /* Force Simple Scrollbars */
- body ::-webkit-scrollbar {
- -webkit-appearance: none;
- width: @customScrollbarWidth;
- height: @customScrollbarHeight;
- }
- body ::-webkit-scrollbar-track {
- background: @trackBackground;
- border-radius: @trackBorderRadius;
- }
- body ::-webkit-scrollbar-thumb {
- cursor: pointer;
- border-radius: @thumbBorderRadius;
- background: @thumbBackground;
- transition: @thumbTransition;
- }
- body ::-webkit-scrollbar-thumb:window-inactive {
- background: @thumbInactiveBackground;
- }
- body ::-webkit-scrollbar-thumb:hover {
- background: @thumbHoverBackground;
- }
- body .ui {
- & when (@supportIE) {
- /* IE11 */
- scrollbar-face-color: @thumbBackgroundHex;
- scrollbar-shadow-color: @thumbBackgroundHex;
- scrollbar-track-color: @trackBackgroundHex;
- scrollbar-arrow-color: @trackBackgroundHex;
+ /* Inverted UI */
+ body .ui.inverted:not(.dimmer)::-webkit-scrollbar-track {
+ background: @trackInvertedBackground;
+ }
+ body .ui.inverted:not(.dimmer)::-webkit-scrollbar-thumb {
+ background: @thumbInvertedBackground;
}
- /* firefox : first color thumb, second track*/
- scrollbar-color: @thumbBackground @trackBackground;
- scrollbar-width: thin;
- }
-
- /* Inverted UI */
- body .ui.inverted:not(.dimmer)::-webkit-scrollbar-track {
- background: @trackInvertedBackground;
- }
- body .ui.inverted:not(.dimmer)::-webkit-scrollbar-thumb {
- background: @thumbInvertedBackground;
- }
- body .ui.inverted:not(.dimmer)::-webkit-scrollbar-thumb:window-inactive {
- background: @thumbInvertedInactiveBackground;
- }
- body .ui.inverted:not(.dimmer)::-webkit-scrollbar-thumb:hover {
- background: @thumbInvertedHoverBackground;
- }
-
- body .ui.inverted:not(.dimmer) {
- & when (@supportIE) {
- /* IE11 */
- scrollbar-face-color: @thumbInvertedBackgroundHex;
- scrollbar-shadow-color: @thumbInvertedBackgroundHex;
- scrollbar-track-color: @trackInvertedBackgroundHex;
- scrollbar-arrow-color: @trackInvertedBackgroundHex;
+ body .ui.inverted:not(.dimmer)::-webkit-scrollbar-thumb:window-inactive {
+ background: @thumbInvertedInactiveBackground;
+ }
+ body .ui.inverted:not(.dimmer)::-webkit-scrollbar-thumb:hover {
+ background: @thumbInvertedHoverBackground;
+ }
+
+ body .ui.inverted:not(.dimmer) {
+ & when (@supportIE) {
+ /* IE11 */
+ scrollbar-face-color: @thumbInvertedBackgroundHex;
+ scrollbar-shadow-color: @thumbInvertedBackgroundHex;
+ scrollbar-track-color: @trackInvertedBackgroundHex;
+ scrollbar-arrow-color: @trackInvertedBackgroundHex;
+ }
+
+ /* firefox: first color thumb, second track */
+ scrollbar-color: @thumbInvertedBackground @trackInvertedBackground;
}
- /* firefox : first color thumb, second track */
- scrollbar-color: @thumbInvertedBackground @trackInvertedBackground;
- }
}
/*******************************
@@ -198,33 +196,33 @@ a:hover {
/* Site */
::-webkit-selection {
- background-color: @highlightBackground;
- color: @highlightColor;
+ background-color: @highlightBackground;
+ color: @highlightColor;
}
::-moz-selection {
- background-color: @highlightBackground;
- color: @highlightColor;
+ background-color: @highlightBackground;
+ color: @highlightColor;
}
::selection {
- background-color: @highlightBackground;
- color: @highlightColor;
+ background-color: @highlightBackground;
+ color: @highlightColor;
}
/* Form */
textarea::-webkit-selection,
input::-webkit-selection {
- background-color: @inputHighlightBackground;
- color: @inputHighlightColor;
+ background-color: @inputHighlightBackground;
+ color: @inputHighlightColor;
}
textarea::-moz-selection,
input::-moz-selection {
- background-color: @inputHighlightBackground;
- color: @inputHighlightColor;
+ background-color: @inputHighlightBackground;
+ color: @inputHighlightColor;
}
textarea::selection,
input::selection {
- background-color: @inputHighlightBackground;
- color: @inputHighlightColor;
+ background-color: @inputHighlightBackground;
+ color: @inputHighlightColor;
}
.loadUIOverrides();
diff --git a/definitions/modules/accordion.js b/definitions/modules/accordion.js
index 6e108ee..5b9a928 100644
--- a/definitions/modules/accordion.js
+++ b/definitions/modules/accordion.js
@@ -1,624 +1,597 @@
/*!
* # Fomantic-UI - Accordion
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-;(function ($, window, document, undefined) {
-
-'use strict';
-
-$.isFunction = $.isFunction || function(obj) {
- return typeof obj === "function" && typeof obj.nodeType !== "number";
-};
-
-window = (typeof window != 'undefined' && window.Math == Math)
- ? window
- : (typeof self != 'undefined' && self.Math == Math)
- ? self
- : Function('return this')()
-;
-
-$.fn.accordion = function(parameters) {
- var
- $allModules = $(this),
-
- time = new Date().getTime(),
- performance = [],
-
- query = arguments[0],
- methodInvoked = (typeof query == 'string'),
- queryArguments = [].slice.call(arguments, 1),
-
- returnedValue
- ;
- $allModules
- .each(function() {
- var
- settings = ( $.isPlainObject(parameters) )
- ? $.extend(true, {}, $.fn.accordion.settings, parameters)
- : $.extend({}, $.fn.accordion.settings),
-
- className = settings.className,
- namespace = settings.namespace,
- selector = settings.selector,
- error = settings.error,
-
- eventNamespace = '.' + namespace,
- moduleNamespace = 'module-' + namespace,
- moduleSelector = $allModules.selector || '',
-
- $module = $(this),
- $title = $module.find(selector.title),
- $content = $module.find(selector.content),
-
- element = this,
- instance = $module.data(moduleNamespace),
- observer,
- module
- ;
-
- module = {
-
- initialize: function() {
- module.debug('Initializing', $module);
- module.bind.events();
- if(settings.observeChanges) {
- module.observeChanges();
- }
- module.instantiate();
- },
+(function ($, window, document) {
+ 'use strict';
- instantiate: function() {
- instance = module;
- $module
- .data(moduleNamespace, module)
- ;
- },
+ function isFunction(obj) {
+ return typeof obj === 'function' && typeof obj.nodeType !== 'number';
+ }
- destroy: function() {
- module.debug('Destroying previous instance', $module);
- $module
- .off(eventNamespace)
- .removeData(moduleNamespace)
- ;
- },
+ window = window !== undefined && window.Math === Math
+ ? window
+ : globalThis;
- refresh: function() {
- $title = $module.find(selector.title);
- $content = $module.find(selector.content);
- },
+ $.fn.accordion = function (parameters) {
+ var
+ $allModules = $(this),
- observeChanges: function() {
- if('MutationObserver' in window) {
- observer = new MutationObserver(function(mutations) {
- module.debug('DOM tree modified, updating selector cache');
- module.refresh();
- });
- observer.observe(element, {
- childList : true,
- subtree : true
- });
- module.debug('Setting up mutation observer', observer);
- }
- },
+ time = Date.now(),
+ performance = [],
- bind: {
- events: function() {
- module.debug('Binding delegated events');
- $module
- .on(settings.on + eventNamespace, selector.trigger, module.event.click)
- ;
- }
- },
+ query = arguments[0],
+ methodInvoked = typeof query === 'string',
+ queryArguments = [].slice.call(arguments, 1),
- event: {
- click: function(event) {
- if($(event.target).closest(selector.ignore).length === 0) {
- module.toggle.call(this);
- }
- }
- },
+ returnedValue
+ ;
+ $allModules.each(function () {
+ var
+ settings = $.isPlainObject(parameters)
+ ? $.extend(true, {}, $.fn.accordion.settings, parameters)
+ : $.extend({}, $.fn.accordion.settings),
+
+ className = settings.className,
+ namespace = settings.namespace,
+ selector = settings.selector,
+ error = settings.error,
+
+ eventNamespace = '.' + namespace,
+ moduleNamespace = 'module-' + namespace,
+ moduleSelector = $allModules.selector || '',
+
+ $module = $(this),
+ $title = $module.find(selector.title),
+ $content = $module.find(selector.content),
+
+ element = this,
+ instance = $module.data(moduleNamespace),
+ observer,
+ module
+ ;
- toggle: function(query) {
- var
- $activeTitle = (query !== undefined)
- ? (typeof query === 'number')
- ? $title.eq(query)
- : $(query).closest(selector.title)
- : $(this).closest(selector.title),
- $activeContent = $activeTitle.next($content),
- isAnimating = $activeContent.hasClass(className.animating),
- isActive = $activeContent.hasClass(className.active),
- isOpen = (isActive && !isAnimating),
- isOpening = (!isActive && isAnimating)
- ;
- module.debug('Toggling visibility of content', $activeTitle);
- if(isOpen || isOpening) {
- if(settings.collapsible) {
- module.close.call($activeTitle);
- }
- else {
- module.debug('Cannot close accordion content collapsing is disabled');
- }
- }
- else {
- module.open.call($activeTitle);
- }
- },
+ module = {
- open: function(query) {
- var
- $activeTitle = (query !== undefined)
- ? (typeof query === 'number')
- ? $title.eq(query)
- : $(query).closest(selector.title)
- : $(this).closest(selector.title),
- $activeContent = $activeTitle.next($content),
- isAnimating = $activeContent.hasClass(className.animating),
- isActive = $activeContent.hasClass(className.active),
- isOpen = (isActive || isAnimating)
- ;
- if(isOpen) {
- module.debug('Accordion already open, skipping', $activeContent);
- return;
- }
- module.debug('Opening accordion content', $activeTitle);
- settings.onOpening.call($activeContent);
- settings.onChanging.call($activeContent);
- if(settings.exclusive) {
- module.closeOthers.call($activeTitle);
- }
- $activeTitle
- .addClass(className.active)
- ;
- $activeContent
- .stop(true, true)
- .addClass(className.animating)
- ;
- if(settings.animateChildren) {
- if($.fn.transition !== undefined && $module.transition('is supported')) {
- $activeContent
- .children()
- .transition({
- animation : 'fade in',
- queue : false,
- useFailSafe : true,
- debug : settings.debug,
- verbose : settings.verbose,
- silent : settings.silent,
- duration : settings.duration,
- skipInlineHidden : true,
- onComplete: function() {
- $activeContent.children().removeClass(className.transition);
+ initialize: function () {
+ module.debug('Initializing', $module);
+ module.bind.events();
+ if (settings.observeChanges) {
+ module.observeChanges();
+ }
+ module.instantiate();
+ },
+
+ instantiate: function () {
+ instance = module;
+ $module
+ .data(moduleNamespace, module)
+ ;
+ },
+
+ destroy: function () {
+ module.debug('Destroying previous instance', $module);
+ $module
+ .off(eventNamespace)
+ .removeData(moduleNamespace)
+ ;
+ },
+
+ refresh: function () {
+ $title = $module.find(selector.title);
+ $content = $module.find(selector.content);
+ },
+
+ observeChanges: function () {
+ if ('MutationObserver' in window) {
+ observer = new MutationObserver(function (mutations) {
+ module.debug('DOM tree modified, updating selector cache');
+ module.refresh();
+ });
+ observer.observe(element, {
+ childList: true,
+ subtree: true,
+ });
+ module.debug('Setting up mutation observer', observer);
+ }
+ },
+
+ bind: {
+ events: function () {
+ module.debug('Binding delegated events');
+ $module
+ .on(settings.on + eventNamespace, selector.trigger, module.event.click)
+ ;
+ },
+ },
+
+ event: {
+ click: function (event) {
+ if ($(event.target).closest(selector.ignore).length === 0) {
+ module.toggle.call(this);
+ }
+ },
+ },
+
+ toggle: function (query) {
+ var
+ $activeTitle = query !== undefined
+ ? (typeof query === 'number'
+ ? $title.eq(query)
+ : $(query).closest(selector.title))
+ : $(this).closest(selector.title),
+ $activeContent = $activeTitle.next($content),
+ isAnimating = $activeContent.hasClass(className.animating),
+ isActive = $activeContent.hasClass(className.active),
+ isOpen = isActive && !isAnimating,
+ isOpening = !isActive && isAnimating
+ ;
+ module.debug('Toggling visibility of content', $activeTitle);
+ if (isOpen || isOpening) {
+ if (settings.collapsible) {
+ module.close.call($activeTitle);
+ } else {
+ module.debug('Cannot close accordion content collapsing is disabled');
+ }
+ } else {
+ module.open.call($activeTitle);
+ }
+ },
+
+ open: function (query) {
+ var
+ $activeTitle = query !== undefined
+ ? (typeof query === 'number'
+ ? $title.eq(query)
+ : $(query).closest(selector.title))
+ : $(this).closest(selector.title),
+ $activeContent = $activeTitle.next($content),
+ isAnimating = $activeContent.hasClass(className.animating),
+ isActive = $activeContent.hasClass(className.active),
+ isOpen = isActive || isAnimating
+ ;
+ if (isOpen) {
+ module.debug('Accordion already open, skipping', $activeContent);
+
+ return;
+ }
+ module.debug('Opening accordion content', $activeTitle);
+ settings.onOpening.call($activeContent);
+ settings.onChanging.call($activeContent);
+ if (settings.exclusive) {
+ module.closeOthers.call($activeTitle);
+ }
+ $activeTitle
+ .addClass(className.active)
+ ;
+ $activeContent
+ .stop(true, true)
+ .addClass(className.animating)
+ ;
+ if (settings.animateChildren) {
+ if ($.fn.transition !== undefined && $module.transition('is supported')) {
+ $activeContent
+ .children()
+ .transition({
+ animation: 'fade in',
+ queue: false,
+ useFailSafe: true,
+ debug: settings.debug,
+ verbose: settings.verbose,
+ silent: settings.silent,
+ duration: settings.duration,
+ skipInlineHidden: true,
+ onComplete: function () {
+ $activeContent.children().removeClass(className.transition);
+ },
+ })
+ ;
+ } else {
+ $activeContent
+ .children()
+ .stop(true, true)
+ .animate({
+ opacity: 1,
+ }, settings.duration, module.resetOpacity);
+ }
+ }
+ $activeContent
+ .slideDown(settings.duration, settings.easing, function () {
+ $activeContent
+ .removeClass(className.animating)
+ .addClass(className.active)
+ ;
+ module.reset.display.call(this);
+ settings.onOpen.call(this);
+ settings.onChange.call(this);
+ })
+ ;
+ },
+
+ close: function (query) {
+ var
+ $activeTitle = query !== undefined
+ ? (typeof query === 'number'
+ ? $title.eq(query)
+ : $(query).closest(selector.title))
+ : $(this).closest(selector.title),
+ $activeContent = $activeTitle.next($content),
+ isAnimating = $activeContent.hasClass(className.animating),
+ isActive = $activeContent.hasClass(className.active),
+ isOpening = !isActive && isAnimating,
+ isClosing = isActive && isAnimating
+ ;
+ if ((isActive || isOpening) && !isClosing) {
+ module.debug('Closing accordion content', $activeContent);
+ settings.onClosing.call($activeContent);
+ settings.onChanging.call($activeContent);
+ $activeTitle
+ .removeClass(className.active)
+ ;
+ $activeContent
+ .stop(true, true)
+ .addClass(className.animating)
+ ;
+ if (settings.animateChildren) {
+ if ($.fn.transition !== undefined && $module.transition('is supported')) {
+ $activeContent
+ .children()
+ .transition({
+ animation: 'fade out',
+ queue: false,
+ useFailSafe: true,
+ debug: settings.debug,
+ verbose: settings.verbose,
+ silent: settings.silent,
+ duration: settings.duration,
+ skipInlineHidden: true,
+ })
+ ;
+ } else {
+ $activeContent
+ .children()
+ .stop(true, true)
+ .animate({
+ opacity: 0,
+ }, settings.duration, module.resetOpacity);
+ }
+ }
+ $activeContent
+ .slideUp(settings.duration, settings.easing, function () {
+ $activeContent
+ .removeClass(className.animating)
+ .removeClass(className.active)
+ ;
+ module.reset.display.call(this);
+ settings.onClose.call(this);
+ settings.onChange.call(this);
+ })
+ ;
+ }
+ },
+
+ closeOthers: function (index) {
+ var
+ $activeTitle = index !== undefined
+ ? $title.eq(index)
+ : $(this).closest(selector.title),
+ $parentTitles = $activeTitle.parents(selector.content).prev(selector.title),
+ $activeAccordion = $activeTitle.closest(selector.accordion),
+ activeSelector = selector.title + '.' + className.active + ':visible',
+ activeContent = selector.content + '.' + className.active + ':visible',
+ $openTitles,
+ $nestedTitles,
+ $openContents
+ ;
+ if (settings.closeNested) {
+ $openTitles = $activeAccordion.find(activeSelector).not($parentTitles);
+ $openContents = $openTitles.next($content);
+ } else {
+ $openTitles = $activeAccordion.find(activeSelector).not($parentTitles);
+ $nestedTitles = $activeAccordion.find(activeContent).find(activeSelector).not($parentTitles);
+ $openTitles = $openTitles.not($nestedTitles);
+ $openContents = $openTitles.next($content);
+ }
+ if ($openTitles.length > 0) {
+ module.debug('Exclusive enabled, closing other content', $openTitles);
+ $openTitles
+ .removeClass(className.active)
+ ;
+ $openContents
+ .removeClass(className.animating)
+ .stop(true, true)
+ ;
+ if (settings.animateChildren) {
+ if ($.fn.transition !== undefined && $module.transition('is supported')) {
+ $openContents
+ .children()
+ .transition({
+ animation: 'fade out',
+ useFailSafe: true,
+ debug: settings.debug,
+ verbose: settings.verbose,
+ silent: settings.silent,
+ duration: settings.duration,
+ skipInlineHidden: true,
+ })
+ ;
+ } else {
+ $openContents
+ .children()
+ .stop(true, true)
+ .animate({
+ opacity: 0,
+ }, settings.duration, module.resetOpacity);
+ }
+ }
+ $openContents
+ .slideUp(settings.duration, settings.easing, function () {
+ $(this).removeClass(className.active);
+ module.reset.display.call(this);
+ })
+ ;
+ }
+ },
+
+ reset: {
+
+ display: function () {
+ module.verbose('Removing inline display from element', this);
+ var $element = $(this);
+ $element.css('display', '');
+ if ($element.attr('style') === '') {
+ $element
+ .attr('style', '')
+ .removeAttr('style')
+ ;
+ }
+ },
+
+ opacity: function () {
+ module.verbose('Removing inline opacity from element', this);
+ var $element = $(this);
+ $element.css('opacity', '');
+ if ($element.attr('style') === '') {
+ $element
+ .attr('style', '')
+ .removeAttr('style')
+ ;
+ }
+ },
+
+ },
+
+ setting: function (name, value) {
+ module.debug('Changing setting', name, value);
+ if ($.isPlainObject(name)) {
+ $.extend(true, settings, name);
+ } else if (value !== undefined) {
+ if ($.isPlainObject(settings[name])) {
+ $.extend(true, settings[name], value);
+ } else {
+ settings[name] = value;
+ }
+ } else {
+ return settings[name];
+ }
+ },
+ internal: function (name, value) {
+ module.debug('Changing internal', name, value);
+ if (value !== undefined) {
+ if ($.isPlainObject(name)) {
+ $.extend(true, module, name);
+ } else {
+ module[name] = value;
+ }
+ } else {
+ return module[name];
+ }
+ },
+ debug: function () {
+ if (!settings.silent && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.debug.apply(console, arguments);
+ }
+ }
+ },
+ verbose: function () {
+ if (!settings.silent && settings.verbose && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.verbose.apply(console, arguments);
+ }
+ }
+ },
+ error: function () {
+ if (!settings.silent) {
+ module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
+ module.error.apply(console, arguments);
+ }
+ },
+ performance: {
+ log: function (message) {
+ var
+ currentTime,
+ executionTime,
+ previousTime
+ ;
+ if (settings.performance) {
+ currentTime = Date.now();
+ previousTime = time || currentTime;
+ executionTime = currentTime - previousTime;
+ time = currentTime;
+ performance.push({
+ Name: message[0],
+ Arguments: [].slice.call(message, 1) || '',
+ Element: element,
+ 'Execution Time': executionTime,
+ });
+ }
+ clearTimeout(module.performance.timer);
+ module.performance.timer = setTimeout(module.performance.display, 500);
+ },
+ display: function () {
+ var
+ title = settings.name + ':',
+ totalTime = 0
+ ;
+ time = false;
+ clearTimeout(module.performance.timer);
+ $.each(performance, function (index, data) {
+ totalTime += data['Execution Time'];
+ });
+ title += ' ' + totalTime + 'ms';
+ if (moduleSelector) {
+ title += ' \'' + moduleSelector + '\'';
+ }
+ if (performance.length > 0) {
+ console.groupCollapsed(title);
+ if (console.table) {
+ console.table(performance);
+ } else {
+ $.each(performance, function (index, data) {
+ console.log(data.Name + ': ' + data['Execution Time'] + 'ms');
+ });
+ }
+ console.groupEnd();
+ }
+ performance = [];
+ },
+ },
+ invoke: function (query, passedArguments, context) {
+ var
+ object = instance,
+ maxDepth,
+ found,
+ response
+ ;
+ passedArguments = passedArguments || queryArguments;
+ context = context || element;
+ if (typeof query === 'string' && object !== undefined) {
+ query = query.split(/[ .]/);
+ maxDepth = query.length - 1;
+ $.each(query, function (depth, value) {
+ var camelCaseValue = depth !== maxDepth
+ ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
+ : query;
+ if ($.isPlainObject(object[camelCaseValue]) && (depth !== maxDepth)) {
+ object = object[camelCaseValue];
+ } else if (object[camelCaseValue] !== undefined) {
+ found = object[camelCaseValue];
+
+ return false;
+ } else if ($.isPlainObject(object[value]) && (depth !== maxDepth)) {
+ object = object[value];
+ } else if (object[value] !== undefined) {
+ found = object[value];
+
+ return false;
+ } else {
+ module.error(error.method, query);
+
+ return false;
+ }
+ });
+ }
+ if (isFunction(found)) {
+ response = found.apply(context, passedArguments);
+ } else if (found !== undefined) {
+ response = found;
+ }
+ if (Array.isArray(returnedValue)) {
+ returnedValue.push(response);
+ } else if (returnedValue !== undefined) {
+ returnedValue = [returnedValue, response];
+ } else if (response !== undefined) {
+ returnedValue = response;
}
- })
- ;
- }
- else {
- $activeContent
- .children()
- .stop(true, true)
- .animate({
- opacity: 1
- }, settings.duration, module.resetOpacity)
- ;
- }
- }
- $activeContent
- .slideDown(settings.duration, settings.easing, function() {
- $activeContent
- .removeClass(className.animating)
- .addClass(className.active)
- ;
- module.reset.display.call(this);
- settings.onOpen.call(this);
- settings.onChange.call(this);
- })
- ;
- },
- close: function(query) {
- var
- $activeTitle = (query !== undefined)
- ? (typeof query === 'number')
- ? $title.eq(query)
- : $(query).closest(selector.title)
- : $(this).closest(selector.title),
- $activeContent = $activeTitle.next($content),
- isAnimating = $activeContent.hasClass(className.animating),
- isActive = $activeContent.hasClass(className.active),
- isOpening = (!isActive && isAnimating),
- isClosing = (isActive && isAnimating)
- ;
- if((isActive || isOpening) && !isClosing) {
- module.debug('Closing accordion content', $activeContent);
- settings.onClosing.call($activeContent);
- settings.onChanging.call($activeContent);
- $activeTitle
- .removeClass(className.active)
- ;
- $activeContent
- .stop(true, true)
- .addClass(className.animating)
- ;
- if(settings.animateChildren) {
- if($.fn.transition !== undefined && $module.transition('is supported')) {
- $activeContent
- .children()
- .transition({
- animation : 'fade out',
- queue : false,
- useFailSafe : true,
- debug : settings.debug,
- verbose : settings.verbose,
- silent : settings.silent,
- duration : settings.duration,
- skipInlineHidden : true
- })
- ;
- }
- else {
- $activeContent
- .children()
- .stop(true, true)
- .animate({
- opacity: 0
- }, settings.duration, module.resetOpacity)
- ;
- }
+ return found;
+ },
+ };
+ if (methodInvoked) {
+ if (instance === undefined) {
+ module.initialize();
+ }
+ module.invoke(query);
+ } else {
+ if (instance !== undefined) {
+ instance.invoke('destroy');
+ }
+ module.initialize();
}
- $activeContent
- .slideUp(settings.duration, settings.easing, function() {
- $activeContent
- .removeClass(className.animating)
- .removeClass(className.active)
- ;
- module.reset.display.call(this);
- settings.onClose.call(this);
- settings.onChange.call(this);
- })
- ;
- }
- },
+ });
- closeOthers: function(index) {
- var
- $activeTitle = (index !== undefined)
- ? $title.eq(index)
- : $(this).closest(selector.title),
- $parentTitles = $activeTitle.parents(selector.content).prev(selector.title),
- $activeAccordion = $activeTitle.closest(selector.accordion),
- activeSelector = selector.title + '.' + className.active + ':visible',
- activeContent = selector.content + '.' + className.active + ':visible',
- $openTitles,
- $nestedTitles,
- $openContents
- ;
- if(settings.closeNested) {
- $openTitles = $activeAccordion.find(activeSelector).not($parentTitles);
- $openContents = $openTitles.next($content);
- }
- else {
- $openTitles = $activeAccordion.find(activeSelector).not($parentTitles);
- $nestedTitles = $activeAccordion.find(activeContent).find(activeSelector).not($parentTitles);
- $openTitles = $openTitles.not($nestedTitles);
- $openContents = $openTitles.next($content);
- }
- if( ($openTitles.length > 0) ) {
- module.debug('Exclusive enabled, closing other content', $openTitles);
- $openTitles
- .removeClass(className.active)
- ;
- $openContents
- .removeClass(className.animating)
- .stop(true, true)
- ;
- if(settings.animateChildren) {
- if($.fn.transition !== undefined && $module.transition('is supported')) {
- $openContents
- .children()
- .transition({
- animation : 'fade out',
- useFailSafe : true,
- debug : settings.debug,
- verbose : settings.verbose,
- silent : settings.silent,
- duration : settings.duration,
- skipInlineHidden : true
- })
- ;
- }
- else {
- $openContents
- .children()
- .stop(true, true)
- .animate({
- opacity: 0
- }, settings.duration, module.resetOpacity)
- ;
- }
- }
- $openContents
- .slideUp(settings.duration , settings.easing, function() {
- $(this).removeClass(className.active);
- module.reset.display.call(this);
- })
- ;
- }
- },
+ return returnedValue !== undefined
+ ? returnedValue
+ : this;
+ };
- reset: {
+ $.fn.accordion.settings = {
- display: function() {
- module.verbose('Removing inline display from element', this);
- $(this).css('display', '');
- if( $(this).attr('style') === '') {
- $(this)
- .attr('style', '')
- .removeAttr('style')
- ;
- }
- },
-
- opacity: function() {
- module.verbose('Removing inline opacity from element', this);
- $(this).css('opacity', '');
- if( $(this).attr('style') === '') {
- $(this)
- .attr('style', '')
- .removeAttr('style')
- ;
- }
- },
+ name: 'Accordion',
+ namespace: 'accordion',
- },
+ silent: false,
+ debug: false,
+ verbose: false,
+ performance: true,
- setting: function(name, value) {
- module.debug('Changing setting', name, value);
- if( $.isPlainObject(name) ) {
- $.extend(true, settings, name);
- }
- else if(value !== undefined) {
- if($.isPlainObject(settings[name])) {
- $.extend(true, settings[name], value);
- }
- else {
- settings[name] = value;
- }
- }
- else {
- return settings[name];
- }
- },
- internal: function(name, value) {
- module.debug('Changing internal', name, value);
- if(value !== undefined) {
- if( $.isPlainObject(name) ) {
- $.extend(true, module, name);
- }
- else {
- module[name] = value;
- }
- }
- else {
- return module[name];
- }
- },
- debug: function() {
- if(!settings.silent && settings.debug) {
- if(settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.debug.apply(console, arguments);
- }
- }
- },
- verbose: function() {
- if(!settings.silent && settings.verbose && settings.debug) {
- if(settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.verbose.apply(console, arguments);
- }
- }
+ on: 'click', // event on title that opens accordion
+
+ observeChanges: true, // whether accordion should automatically refresh on DOM insertion
+
+ exclusive: true, // whether a single accordion content panel should be open at once
+ collapsible: true, // whether accordion content can be closed
+ closeNested: false, // whether nested content should be closed when a panel is closed
+ animateChildren: true, // whether children opacity should be animated
+
+ duration: 350, // duration of animation
+ easing: 'easeOutQuad', // easing equation for animation
+
+ onOpening: function () {}, // callback before open animation
+ onClosing: function () {}, // callback before closing animation
+ onChanging: function () {}, // callback before closing or opening animation
+
+ onOpen: function () {}, // callback after open animation
+ onClose: function () {}, // callback after closing animation
+ onChange: function () {}, // callback after closing or opening animation
+
+ error: {
+ method: 'The method you called is not defined',
},
- error: function() {
- if(!settings.silent) {
- module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
- module.error.apply(console, arguments);
- }
+
+ className: {
+ active: 'active',
+ animating: 'animating',
+ transition: 'transition',
},
- performance: {
- log: function(message) {
- var
- currentTime,
- executionTime,
- previousTime
- ;
- if(settings.performance) {
- currentTime = new Date().getTime();
- previousTime = time || currentTime;
- executionTime = currentTime - previousTime;
- time = currentTime;
- performance.push({
- 'Name' : message[0],
- 'Arguments' : [].slice.call(message, 1) || '',
- 'Element' : element,
- 'Execution Time' : executionTime
- });
- }
- clearTimeout(module.performance.timer);
- module.performance.timer = setTimeout(module.performance.display, 500);
- },
- display: function() {
- var
- title = settings.name + ':',
- totalTime = 0
- ;
- time = false;
- clearTimeout(module.performance.timer);
- $.each(performance, function(index, data) {
- totalTime += data['Execution Time'];
- });
- title += ' ' + totalTime + 'ms';
- if(moduleSelector) {
- title += ' \'' + moduleSelector + '\'';
- }
- if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) {
- console.groupCollapsed(title);
- if(console.table) {
- console.table(performance);
- }
- else {
- $.each(performance, function(index, data) {
- console.log(data['Name'] + ': ' + data['Execution Time']+'ms');
- });
- }
- console.groupEnd();
- }
- performance = [];
- }
+
+ selector: {
+ accordion: '.accordion',
+ title: '.title',
+ trigger: '.title',
+ ignore: '.ui.dropdown',
+ content: '.content',
},
- invoke: function(query, passedArguments, context) {
- var
- object = instance,
- maxDepth,
- found,
- response
- ;
- passedArguments = passedArguments || queryArguments;
- context = context || element;
- if(typeof query == 'string' && object !== undefined) {
- query = query.split(/[\. ]/);
- maxDepth = query.length - 1;
- $.each(query, function(depth, value) {
- var camelCaseValue = (depth != maxDepth)
- ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
- : query
- ;
- if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) {
- object = object[camelCaseValue];
- }
- else if( object[camelCaseValue] !== undefined ) {
- found = object[camelCaseValue];
- return false;
- }
- else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) {
- object = object[value];
- }
- else if( object[value] !== undefined ) {
- found = object[value];
- return false;
- }
- else {
- module.error(error.method, query);
- return false;
- }
- });
- }
- if ( $.isFunction( found ) ) {
- response = found.apply(context, passedArguments);
- }
- else if(found !== undefined) {
- response = found;
- }
- if(Array.isArray(returnedValue)) {
- returnedValue.push(response);
- }
- else if(returnedValue !== undefined) {
- returnedValue = [returnedValue, response];
- }
- else if(response !== undefined) {
- returnedValue = response;
- }
- return found;
- }
- };
- if(methodInvoked) {
- if(instance === undefined) {
- module.initialize();
- }
- module.invoke(query);
- }
- else {
- if(instance !== undefined) {
- instance.invoke('destroy');
- }
- module.initialize();
- }
- })
- ;
- return (returnedValue !== undefined)
- ? returnedValue
- : this
- ;
-};
-
-$.fn.accordion.settings = {
-
- name : 'Accordion',
- namespace : 'accordion',
-
- silent : false,
- debug : false,
- verbose : false,
- performance : true,
-
- on : 'click', // event on title that opens accordion
-
- observeChanges : true, // whether accordion should automatically refresh on DOM insertion
-
- exclusive : true, // whether a single accordion content panel should be open at once
- collapsible : true, // whether accordion content can be closed
- closeNested : false, // whether nested content should be closed when a panel is closed
- animateChildren : true, // whether children opacity should be animated
-
- duration : 350, // duration of animation
- easing : 'easeOutQuad', // easing equation for animation
-
- onOpening : function(){}, // callback before open animation
- onClosing : function(){}, // callback before closing animation
- onChanging : function(){}, // callback before closing or opening animation
-
- onOpen : function(){}, // callback after open animation
- onClose : function(){}, // callback after closing animation
- onChange : function(){}, // callback after closing or opening animation
-
- error: {
- method : 'The method you called is not defined'
- },
-
- className : {
- active : 'active',
- animating : 'animating',
- transition: 'transition'
- },
-
- selector : {
- accordion : '.accordion',
- title : '.title',
- trigger : '.title',
- ignore : '.ui.dropdown',
- content : '.content'
- }
-
-};
-
-// Adds easing
-$.extend( $.easing, {
- easeOutQuad: function (x, t, b, c, d) {
- return -c *(t/=d)*(t-2) + b;
- }
-});
-
-})( jQuery, window, document );
+ };
+
+ // Adds easing
+ $.extend($.easing, {
+ easeOutQuad: function (x) {
+ return 1 - (1 - x) * (1 - x);
+ },
+ });
+})(jQuery, window, document);
diff --git a/definitions/modules/accordion.less b/definitions/modules/accordion.less
index 4ad2f78..fbbb855 100644
--- a/definitions/modules/accordion.less
+++ b/definitions/modules/accordion.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Accordion
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,10 +12,10 @@
Theme
*******************************/
-@type : 'module';
-@element : 'accordion';
+@type: "module";
+@element: "accordion";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Accordion
@@ -23,76 +23,76 @@
.ui.accordion,
.ui.accordion .accordion {
- max-width: 100%;
+ max-width: 100%;
}
.ui.accordion .accordion {
- margin: @childAccordionMargin;
- padding: @childAccordionPadding;
+ margin: @childAccordionMargin;
+ padding: @childAccordionPadding;
}
/* Title */
.ui.accordion.menu .item > .title,
.ui.accordion > .title,
.ui.accordion .accordion > .title {
- cursor: pointer;
- padding: @titlePadding;
- font-family: @titleFont;
- font-size: @titleFontSize;
- color: @titleColor;
- list-style: none;
- line-height: @titleLineHeight;
+ cursor: pointer;
+ padding: @titlePadding;
+ font-family: @titleFont;
+ font-size: @titleFontSize;
+ color: @titleColor;
+ list-style: none;
+ line-height: @titleLineHeight;
}
/* Default Styling */
.ui.accordion:not(.styled) .title ~ .content,
.ui.accordion:not(.styled) .accordion .title ~ .content {
- margin: @contentMargin;
- padding: @contentPadding;
+ margin: @contentMargin;
+ padding: @contentPadding;
}
.ui.accordion:not(.styled) .title ~ .content:last-child {
- padding-bottom: 0;
+ padding-bottom: 0;
}
/* Arrow */
.ui.accordion .ui.header > .dropdown.icon,
.ui.accordion .title > .dropdown.icon,
.ui.accordion .accordion .title > .dropdown.icon {
- display: @iconDisplay;
- float: @iconFloat;
- opacity: @iconOpacity;
- width: @iconWidth;
- height: @iconHeight;
- margin: @iconMargin;
- padding: @iconPadding;
- font-size: @iconFontSize;
- transition: @iconTransition;
- vertical-align: @iconVerticalAlign;
- transform: @iconTransform;
- &.right when (@variationAccordionRightDropdown) {
- float:right;
- transform: @iconTransformRight;
- }
+ display: @iconDisplay;
+ float: @iconFloat;
+ opacity: @iconOpacity;
+ width: @iconWidth;
+ height: @iconHeight;
+ margin: @iconMargin;
+ padding: @iconPadding;
+ font-size: @iconFontSize;
+ transition: @iconTransition;
+ vertical-align: @iconVerticalAlign;
+ transform: @iconTransform;
+ &.right when (@variationAccordionRightDropdown) {
+ float: right;
+ transform: @iconTransformRight;
+ }
}
-/*--------------
+/* --------------
Coupling
----------------*/
+--------------- */
/* Menu */
.ui.accordion.menu .item .title {
- display: block;
- padding: @menuTitlePadding;
+ display: block;
+ padding: @menuTitlePadding;
}
.ui.accordion.menu .item .title > .dropdown.icon {
- float: @menuIconFloat;
- margin: @menuIconMargin;
- transform: @menuIconTransform;
+ float: @menuIconFloat;
+ margin: @menuIconMargin;
+ transform: @menuIconTransform;
}
/* Header */
.ui.accordion .ui.header > .dropdown.icon {
- font-size: @iconFontSize;
- margin: @iconMargin;
+ font-size: @iconFontSize;
+ margin: @iconMargin;
}
/*******************************
@@ -103,11 +103,11 @@
.ui.accordion .accordion[open] > .title > .dropdown.icon,
.ui.accordion .active.title > .dropdown.icon,
.ui.accordion .accordion .active.title > .dropdown.icon {
- transform: @activeIconTransform;
+ transform: @activeIconTransform;
}
.ui.accordion.menu .item .active.title > .dropdown.icon {
- transform: @activeIconTransform;
+ transform: @activeIconTransform;
}
/*******************************
@@ -115,137 +115,134 @@
*******************************/
& when (@variationAccordionStyled) {
- /*--------------
- Styled
- ---------------*/
-
- .ui.styled.accordion {
- width: @styledWidth;
- }
-
- .ui.styled.accordion,
- .ui.styled.accordion .accordion {
- border-radius: @styledBorderRadius;
- background: @styledBackground;
- box-shadow: @styledBoxShadow;
- }
- .ui.styled.accordion > .title,
- .ui.styled.accordion .accordion > .title {
- margin: @styledTitleMargin;
- padding: @styledTitlePadding;
- color: @styledTitleColor;
- font-weight: @styledTitleFontWeight;
- border-top: @styledTitleBorder;
- transition: @styledTitleTransition;
- }
- .ui.styled.accordion > .title:first-child,
- .ui.styled.accordion .accordion > .title:first-child {
- border-top: none;
- }
-
-
- /* Content */
- .ui.styled.accordion > .content {
- margin: @styledContentMargin;
- padding: @styledContentPadding;
- }
- .ui.styled.accordion .accordion > .content {
- margin: @styledChildContentMargin;
- padding: @styledChildContentPadding;
- }
-
-
- /* Hover */
- .ui.styled.accordion > .title:hover {
- background: @styledTitleHoverBackground;
- color: @styledTitleHoverColor;
- }
- .ui.styled.accordion .accordion > .title:hover {
- background: @styledHoverChildTitleBackground;
- color: @styledHoverChildTitleColor;
- }
-
-
- /* Active */
- .ui.styled.accordion[open] > .title,
- .ui.styled.accordion .active.title {
- background: @styledActiveTitleBackground;
- color: @styledActiveTitleColor;
- }
- .ui.styled.accordion .accordion[open] > .title,
- .ui.styled.accordion .accordion .active.title {
- background: @styledActiveChildTitleBackground;
- color: @styledActiveChildTitleColor;
- }
+ /* --------------
+ Styled
+ --------------- */
+
+ .ui.styled.accordion {
+ width: @styledWidth;
+ }
+
+ .ui.styled.accordion,
+ .ui.styled.accordion .accordion {
+ border-radius: @styledBorderRadius;
+ background: @styledBackground;
+ box-shadow: @styledBoxShadow;
+ }
+ .ui.styled.accordion > .title,
+ .ui.styled.accordion .accordion > .title {
+ margin: @styledTitleMargin;
+ padding: @styledTitlePadding;
+ color: @styledTitleColor;
+ font-weight: @styledTitleFontWeight;
+ border-top: @styledTitleBorder;
+ transition: @styledTitleTransition;
+ }
+ .ui.styled.accordion > .title:first-child,
+ .ui.styled.accordion .accordion > .title:first-child {
+ border-top: none;
+ }
+
+ /* Content */
+ .ui.styled.accordion > .content {
+ margin: @styledContentMargin;
+ padding: @styledContentPadding;
+ }
+ .ui.styled.accordion .accordion > .content {
+ margin: @styledChildContentMargin;
+ padding: @styledChildContentPadding;
+ }
+
+ /* Hover */
+ .ui.styled.accordion > .title:hover {
+ background: @styledTitleHoverBackground;
+ color: @styledTitleHoverColor;
+ }
+ .ui.styled.accordion .accordion > .title:hover {
+ background: @styledHoverChildTitleBackground;
+ color: @styledHoverChildTitleColor;
+ }
+
+ /* Active */
+ .ui.styled.accordion[open] > .title,
+ .ui.styled.accordion .active.title {
+ background: @styledActiveTitleBackground;
+ color: @styledActiveTitleColor;
+ }
+ .ui.styled.accordion .accordion[open] > .title,
+ .ui.styled.accordion .accordion .active.title {
+ background: @styledActiveChildTitleBackground;
+ color: @styledActiveChildTitleColor;
+ }
}
& when (@variationAccordionCompact) {
- /*--------------
- Compact
- ---------------*/
+ /* --------------
+ Compact
+ --------------- */
- /* Default Styling */
+ /* Default Styling */
- .ui.compact.accordion:not(.styled) > .title,
- .ui.compact.accordion:not(.styled) .accordion > .title {
- padding: @titlePaddingCompact;
- }
+ .ui.compact.accordion:not(.styled) > .title,
+ .ui.compact.accordion:not(.styled) .accordion > .title {
+ padding: @titlePaddingCompact;
+ }
- .ui.compact.accordion:not(.styled) .title ~ .content,
- .ui.compact.accordion:not(.styled) .accordion .title ~ .content {
- padding: @contentPaddingCompact;
- }
+ .ui.compact.accordion:not(.styled) .title ~ .content,
+ .ui.compact.accordion:not(.styled) .accordion .title ~ .content {
+ padding: @contentPaddingCompact;
+ }
- /* Styled */
+ /* Styled */
- .ui.compact.styled.accordion > .title,
- .ui.compact.styled.accordion .accordion > .title {
- padding: @styledTitlePaddingCompact;
- }
+ .ui.compact.styled.accordion > .title,
+ .ui.compact.styled.accordion .accordion > .title {
+ padding: @styledTitlePaddingCompact;
+ }
- .ui.compact.styled.accordion .title ~ .content,
- .ui.compact.styled.accordion .accordion .title ~ .content {
- padding: @styledContentPaddingCompact;
- }
+ .ui.compact.styled.accordion .title ~ .content,
+ .ui.compact.styled.accordion .accordion .title ~ .content {
+ padding: @styledContentPaddingCompact;
+ }
}
- /*--------------
+
+/* --------------
Very Compact
- ---------------*/
+ --------------- */
& when (@variationAccordionVeryCompact) {
- .ui[class*="very compact"].accordion:not(.styled) > .title,
- .ui[class*="very compact"].accordion:not(.styled) .accordion > .title {
- padding: @titlePaddingVeryCompact;
- }
-
- .ui[class*="very compact"].accordion:not(.styled) .title ~ .content,
- .ui[class*="very compact"].accordion:not(.styled) .accordion .title ~ .content {
- padding: @contentPaddingVeryCompact;
- }
-
- .ui[class*="very compact"].styled.accordion > .title,
- .ui[class*="very compact"].styled.accordion .accordion > .title {
- padding: @styledTitlePaddingVeryCompact;
- }
-
- .ui[class*="very compact"].styled.accordion .title ~ .content,
- .ui[class*="very compact"].styled.accordion .accordion .title ~ .content {
- padding: @styledContentPaddingVeryCompact;
- }
-}
+ .ui[class*="very compact"].accordion:not(.styled) > .title,
+ .ui[class*="very compact"].accordion:not(.styled) .accordion > .title {
+ padding: @titlePaddingVeryCompact;
+ }
+
+ .ui[class*="very compact"].accordion:not(.styled) .title ~ .content,
+ .ui[class*="very compact"].accordion:not(.styled) .accordion .title ~ .content {
+ padding: @contentPaddingVeryCompact;
+ }
+ .ui[class*="very compact"].styled.accordion > .title,
+ .ui[class*="very compact"].styled.accordion .accordion > .title {
+ padding: @styledTitlePaddingVeryCompact;
+ }
+
+ .ui[class*="very compact"].styled.accordion .title ~ .content,
+ .ui[class*="very compact"].styled.accordion .accordion .title ~ .content {
+ padding: @styledContentPaddingVeryCompact;
+ }
+}
/*******************************
States
*******************************/
-/*--------------
+/* --------------
Not Active
----------------*/
+--------------- */
.ui.accordion:not(details) .title ~ .content:not(.active),
.ui.accordion .accordion:not(details) .title ~ .content:not(.active) {
- display: none;
+ display: none;
}
/*******************************
@@ -253,119 +250,118 @@
*******************************/
& when (@variationAccordionFluid) {
- /*--------------
- Fluid
- ---------------*/
-
- .ui.fluid.accordion,
- .ui.fluid.accordion .accordion {
- width: 100%;
- }
+ /* --------------
+ Fluid
+ --------------- */
+
+ .ui.fluid.accordion,
+ .ui.fluid.accordion .accordion {
+ width: 100%;
+ }
}
& when (@variationAccordionInverted) {
- /*--------------
- Inverted
- ---------------*/
-
- .ui.inverted.accordion.menu .item > .title,
- .ui.inverted.accordion > .title,
- .ui.inverted.accordion .accordion > .title {
- color: @invertedTitleColor;
- }
- & when (@variationAccordionStyled) {
- .ui.inverted.styled.accordion,
- .ui.inverted.styled.accordion .accordion {
- background: @invertedStyledBackground;
- box-shadow: @invertedStyledBoxShadow;
+ /* --------------
+ Inverted
+ --------------- */
+
+ .ui.inverted.accordion.menu .item > .title,
+ .ui.inverted.accordion > .title,
+ .ui.inverted.accordion .accordion > .title {
+ color: @invertedTitleColor;
}
- .ui.inverted.styled.accordion > .title,
- .ui.inverted.styled.accordion .accordion > .title {
- color: @invertedStyledTitleColor;
- border-top: @invertedStyledTitleBorder;
+ & when (@variationAccordionStyled) {
+ .ui.inverted.styled.accordion,
+ .ui.inverted.styled.accordion .accordion {
+ background: @invertedStyledBackground;
+ box-shadow: @invertedStyledBoxShadow;
+ }
+ .ui.inverted.styled.accordion > .title,
+ .ui.inverted.styled.accordion .accordion > .title {
+ color: @invertedStyledTitleColor;
+ border-top: @invertedStyledTitleBorder;
+ }
+
+ /* Hover */
+ .ui.inverted.styled.accordion > .title:hover {
+ background: @invertedStyledTitleHoverBackground;
+ color: @invertedStyledTitleHoverColor;
+ }
+ .ui.inverted.styled.accordion .accordion > .title:hover {
+ background: @invertedStyledHoverChildTitleBackground;
+ color: @invertedStyledHoverChildTitleColor;
+ }
+
+ /* Active */
+ .ui.inverted.styled.accordion[open] > .title,
+ .ui.inverted.styled.accordion .active.title {
+ background: @invertedStyledActiveTitleBackground;
+ color: @invertedStyledActiveTitleColor;
+ }
+ .ui.inverted.styled.accordion .accordion[open] > .title,
+ .ui.inverted.styled.accordion .accordion .active.title {
+ background: @invertedStyledActiveChildTitleBackground;
+ color: @invertedStyledActiveChildTitleColor;
+ }
}
+}
- /* Hover */
- .ui.inverted.styled.accordion > .title:hover {
- background: @invertedStyledTitleHoverBackground;
- color: @invertedStyledTitleHoverColor;
+& when (@variationAccordionBasicStyled) {
+ .ui.basic.styled.accordion,
+ .ui.basic.styled.accordion .accordion {
+ background: transparent;
+ box-shadow: none;
}
- .ui.inverted.styled.accordion .accordion > .title:hover {
- background: @invertedStyledHoverChildTitleBackground;
- color: @invertedStyledHoverChildTitleColor;
+ .ui.basic.styled.accordion > .title,
+ .ui.basic.styled.accordion .accordion > .title {
+ border: none;
+ color: @basicStyledTitleColor;
}
-
- /* Active */
- .ui.inverted.styled.accordion[open] > .title,
- .ui.inverted.styled.accordion .active.title {
- background: @invertedStyledActiveTitleBackground;
- color: @invertedStyledActiveTitleColor;
+ .ui.basic.styled.accordion > .title:hover,
+ .ui.basic.styled.accordion .accordion > .title:hover {
+ background: transparent;
+ color: @basicStyledTitleHoverColor;
+ }
+ .ui.basic.styled.accordion[open] > .title,
+ .ui.basic.styled.accordion .active.title,
+ .ui.basic.styled.accordion .accordion[open] > .title,
+ .ui.basic.styled.accordion .accordion .active.title {
+ background: transparent;
+ color: @basicStyledActiveTitleColor;
}
- .ui.inverted.styled.accordion .accordion[open] > .title,
- .ui.inverted.styled.accordion .accordion .active.title {
- background: @invertedStyledActiveChildTitleBackground;
- color: @invertedStyledActiveChildTitleColor;
+ & when (@variationAccordionInverted) {
+ .ui.inverted.basic.styled.accordion > .title,
+ .ui.inverted.basic.styled.accordion .accordion > .title {
+ background: transparent;
+ color: @invertedBasicStyledTitleColor;
+ }
+ .ui.inverted.basic.styled.accordion > .title:hover,
+ .ui.inverted.basic.styled.accordion .accordion > .title:hover {
+ background: transparent;
+ color: @invertedBasicStyledTitleHoverColor;
+ }
+ .ui.inverted.basic.styled.accordion[open] > .title,
+ .ui.inverted.basic.styled.accordion .active.title,
+ .ui.inverted.basic.styled.accordion .accordion[open] > .title,
+ .ui.inverted.basic.styled.accordion .accordion .active.title {
+ background: transparent;
+ color: @invertedBasicStyledActiveTitleColor;
+ }
}
- }
}
-& when (@variationAccordionBasicStyled) {
- .ui.basic.styled.accordion,
- .ui.basic.styled.accordion .accordion {
- background: transparent;
- box-shadow: none;
- }
- .ui.basic.styled.accordion > .title,
- .ui.basic.styled.accordion .accordion > .title {
- border: none;
- color: @basicStyledTitleColor;
- }
- .ui.basic.styled.accordion > .title:hover,
- .ui.basic.styled.accordion .accordion > .title:hover {
- background: transparent;
- color: @basicStyledTitleHoverColor;
- }
- .ui.basic.styled.accordion[open] > .title,
- .ui.basic.styled.accordion .active.title,
- .ui.basic.styled.accordion .accordion[open] > .title,
- .ui.basic.styled.accordion .accordion .active.title {
- background: transparent;
- color: @basicStyledActiveTitleColor;
- }
- & when (@variationAccordionInverted) {
- .ui.inverted.basic.styled.accordion > .title,
- .ui.inverted.basic.styled.accordion .accordion > .title {
- background: transparent;
- color: @invertedBasicStyledTitleColor;
+& when (@variationAccordionTree) {
+ .ui.tree.accordion:not(.styled) .title ~ .content,
+ .ui.tree.accordion:not(.styled) .accordion .title ~ .content {
+ padding: @treeContentPadding;
}
- .ui.inverted.basic.styled.accordion > .title:hover,
- .ui.inverted.basic.styled.accordion .accordion > .title:hover {
- background: transparent;
- color: @invertedBasicStyledTitleHoverColor;
+ .ui.tree.accordion > .content,
+ .ui.tree.accordion .accordion > .content {
+ margin-left: @treeContentLeftMargin;
}
- .ui.inverted.basic.styled.accordion[open] > .title,
- .ui.inverted.basic.styled.accordion .active.title,
- .ui.inverted.basic.styled.accordion .accordion[open] > .title,
- .ui.inverted.basic.styled.accordion .accordion .active.title {
- background: transparent;
- color: @invertedBasicStyledActiveTitleColor;
+ .ui.tree.accordion .accordion {
+ margin-top: @treeContentTopMargin;
}
- }
-}
-
-& when (@variationAccordionTree) {
- .ui.tree.accordion:not(.styled) .title ~ .content,
- .ui.tree.accordion:not(.styled) .accordion .title ~ .content {
- padding:@treeContentPadding;
- }
- .ui.tree.accordion > .content,
- .ui.tree.accordion .accordion > .content {
- margin-left: @treeContentLeftMargin;
- }
- .ui.tree.accordion .accordion {
- margin-top: @treeContentTopMargin;
- }
}
.loadUIOverrides();
-
diff --git a/definitions/modules/calendar.js b/definitions/modules/calendar.js
index 336f85d..99051d4 100644
--- a/definitions/modules/calendar.js
+++ b/definitions/modules/calendar.js
@@ -1,1890 +1,2015 @@
/*!
* # Fomantic-UI - Calendar
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-;(function ($, window, document, undefined) {
-
-'use strict';
-
-$.isFunction = $.isFunction || function(obj) {
- return typeof obj === "function" && typeof obj.nodeType !== "number";
-};
-
-window = (typeof window != 'undefined' && window.Math == Math)
- ? window
- : (typeof self != 'undefined' && self.Math == Math)
- ? self
- : Function('return this')()
-;
-
-$.fn.calendar = function(parameters) {
- var
- $allModules = $(this),
-
- moduleSelector = $allModules.selector || '',
-
- time = new Date().getTime(),
- performance = [],
-
- query = arguments[0],
- methodInvoked = (typeof query == 'string'),
- queryArguments = [].slice.call(arguments, 1),
- returnedValue,
- timeGapTable = {
- '5': {'row': 4, 'column': 3 },
- '10': {'row': 3, 'column': 2 },
- '15': {'row': 2, 'column': 2 },
- '20': {'row': 3, 'column': 1 },
- '30': {'row': 2, 'column': 1 }
- },
- numberText = ['','one','two','three','four','five','six','seven','eight']
- ;
-
- $allModules
- .each(function () {
- var
- settings = ( $.isPlainObject(parameters) )
- ? $.extend(true, {}, $.fn.calendar.settings, parameters)
- : $.extend({}, $.fn.calendar.settings),
-
- className = settings.className,
- namespace = settings.namespace,
- selector = settings.selector,
- formatter = settings.formatter,
- parser = settings.parser,
- metadata = settings.metadata,
- timeGap = timeGapTable[settings.minTimeGap],
- error = settings.error,
-
- eventNamespace = '.' + namespace,
- moduleNamespace = 'module-' + namespace,
-
- $module = $(this),
- $input = $module.find(selector.input),
- $container = $module.find(selector.popup),
- $activator = $module.find(selector.activator),
-
- element = this,
- instance = $module.data(moduleNamespace),
-
- isTouch,
- isTouchDown = false,
- isInverted = $module.hasClass(className.inverted),
- focusDateUsedForRange = false,
- selectionComplete = false,
- classObserver,
- module
- ;
-
- module = {
-
- initialize: function () {
- module.debug('Initializing calendar for', element, $module);
-
- isTouch = module.get.isTouch();
- module.setup.config();
- module.setup.popup();
- module.setup.inline();
- module.setup.input();
- module.setup.date();
- module.create.calendar();
-
- module.bind.events();
- module.observeChanges();
- module.instantiate();
- },
-
- instantiate: function () {
- module.verbose('Storing instance of calendar');
- instance = module;
- $module.data(moduleNamespace, instance);
- },
-
- destroy: function () {
- module.verbose('Destroying previous calendar for', element);
- $module.removeData(moduleNamespace);
- module.unbind.events();
- module.disconnect.classObserver();
- },
-
- setup: {
- config: function () {
- if (module.get.minDate() !== null) {
- module.set.minDate($module.data(metadata.minDate));
- }
- if (module.get.maxDate() !== null) {
- module.set.maxDate($module.data(metadata.maxDate));
- }
- module.setting('type', module.get.type());
- module.setting('on', settings.on || 'click');
- },
- popup: function () {
- if (settings.inline) {
- return;
- }
- if (!$activator.length) {
- $activator = $module.children().first();
- if (!$activator.length) {
- return;
- }
- }
- if ($.fn.popup === undefined) {
- module.error(error.popup);
- return;
- }
- if (!$container.length) {
- //prepend the popup element to the activator's parent so that it has less chance of messing with
- //the styling (eg input action button needs to be the last child to have correct border radius)
- var $activatorParent = $activator.parent(),
- domPositionFunction = $activatorParent.closest(selector.append).length !== 0 ? 'appendTo' : 'prependTo';
- $container = $('').addClass(className.popup)[domPositionFunction]($activatorParent);
- }
- $container.addClass(className.calendar);
- if(isInverted){
- $container.addClass(className.inverted);
- }
- var onVisible = function () {
- module.refreshTooltips();
- return settings.onVisible.apply($container, arguments);
- };
- var onHidden = function () {
- module.blur();
- return settings.onHidden.apply($container, arguments)
- }
- if (!$input.length) {
- //no input, $container has to handle focus/blur
- $container.attr('tabindex', '0');
- onVisible = function () {
- module.refreshTooltips();
- module.focus();
- return settings.onVisible.apply($container, arguments);
- };
- }
- var onShow = function () {
- //reset the focus date onShow
- module.set.focusDate(module.get.date());
- module.set.mode(module.get.validatedMode(settings.startMode));
- return settings.onShow.apply($container, arguments);
- };
- var on = module.setting('on');
- var options = $.extend({}, settings.popupOptions, {
- popup: $container,
- on: on,
- hoverable: on === 'hover',
- closable: on === 'click',
- onShow: onShow,
- onVisible: onVisible,
- onHide: settings.onHide,
- onHidden: onHidden
- });
- module.popup(options);
- },
- inline: function () {
- if ($activator.length && !settings.inline) {
- return;
- }
- settings.inline = true;
- $container = $('').addClass(className.calendar).appendTo($module);
- if (!$input.length) {
- $container.attr('tabindex', '0');
- }
- },
- input: function () {
- if (settings.touchReadonly && $input.length && isTouch) {
- $input.prop('readonly', true);
- }
- module.check.disabled();
- },
- date: function () {
- var date;
- if (settings.initialDate) {
- date = parser.date(settings.initialDate, settings);
- } else if ($module.data(metadata.date) !== undefined) {
- date = parser.date($module.data(metadata.date), settings);
- } else if ($input.length) {
- date = parser.date($input.val(), settings);
- }
- module.set.date(date, settings.formatInput, false);
- module.set.mode(module.get.mode(), false);
- }
- },
-
- trigger: {
- change: function() {
- var
- inputElement = $input[0]
- ;
- if(inputElement) {
- var events = document.createEvent('HTMLEvents');
- module.verbose('Triggering native change event');
- events.initEvent('change', true, false);
- inputElement.dispatchEvent(events);
- }
- }
- },
+(function ($, window, document) {
+ 'use strict';
- create: {
- calendar: function () {
- var i, r, c, p, row, cell, pageGrid;
-
- var
- mode = module.get.mode(),
- today = new Date(),
- date = module.get.date(),
- focusDate = module.get.focusDate(),
- display = module.helper.dateInRange(focusDate || date || settings.initialDate || today)
- ;
-
- if (!focusDate) {
- focusDate = display;
- module.set.focusDate(focusDate, false, false);
- }
+ function isFunction(obj) {
+ return typeof obj === 'function' && typeof obj.nodeType !== 'number';
+ }
+ window = window !== undefined && window.Math === Math
+ ? window
+ : globalThis;
+
+ $.fn.calendar = function (parameters) {
+ var
+ $allModules = $(this),
+ $document = $(document),
+
+ moduleSelector = $allModules.selector || '',
+
+ time = Date.now(),
+ performance = [],
+
+ query = arguments[0],
+ methodInvoked = typeof query === 'string',
+ queryArguments = [].slice.call(arguments, 1),
+ returnedValue,
+ timeGapTable = {
+ 5: { row: 4, column: 3 },
+ 10: { row: 3, column: 2 },
+ 15: { row: 2, column: 2 },
+ 20: { row: 3, column: 1 },
+ 30: { row: 2, column: 1 },
+ },
+ numberText = ['', 'one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight']
+ ;
+
+ $allModules.each(function () {
var
- isYear = mode === 'year',
- isMonth = mode === 'month',
- isDay = mode === 'day',
- isHour = mode === 'hour',
- isMinute = mode === 'minute',
- isTimeOnly = settings.type === 'time'
+ settings = $.isPlainObject(parameters)
+ ? $.extend(true, {}, $.fn.calendar.settings, parameters)
+ : $.extend({}, $.fn.calendar.settings),
+
+ className = settings.className,
+ namespace = settings.namespace,
+ selector = settings.selector,
+ formatter = settings.formatter,
+ parser = settings.parser,
+ metadata = settings.metadata,
+ timeGap = timeGapTable[settings.minTimeGap],
+ error = settings.error,
+
+ eventNamespace = '.' + namespace,
+ moduleNamespace = 'module-' + namespace,
+
+ $module = $(this),
+ $input = $module.find(selector.input),
+ $activator = $module.find(selector.activator),
+
+ element = this,
+ instance = $module.data(moduleNamespace),
+ $container = instance && instance.popupId ? $document.find('#' + instance.popupId) : $module.find(selector.popup),
+
+ isTouch,
+ isTouchDown = false,
+ isInverted = $module.hasClass(className.inverted),
+ focusDateUsedForRange = false,
+ selectionComplete = false,
+ classObserver,
+ module
;
- var multiMonth = Math.max(settings.multiMonth, 1);
- var monthOffset = !isDay ? 0 : module.get.monthOffset();
+ module = {
+
+ initialize: function () {
+ module.debug('Initializing calendar for', element, $module);
+
+ isTouch = module.get.isTouch();
+ module.setup.config();
+ module.setup.popup();
+ module.setup.inline();
+ module.setup.input();
+ module.setup.date();
+ module.create.calendar();
+
+ module.bind.events();
+ module.observeChanges();
+ module.instantiate();
+ },
+
+ instantiate: function () {
+ module.verbose('Storing instance of calendar');
+ instance = module;
+ $module.data(moduleNamespace, instance);
+ },
+
+ destroy: function () {
+ module.verbose('Destroying previous calendar for', element);
+ $module.removeData(moduleNamespace);
+ module.unbind.events();
+ module.disconnect.classObserver();
+ },
+
+ setup: {
+ config: function () {
+ if (module.get.minDate() !== null) {
+ module.set.minDate($module.data(metadata.minDate));
+ }
+ if (module.get.maxDate() !== null) {
+ module.set.maxDate($module.data(metadata.maxDate));
+ }
+ module.setting('type', module.get.type());
+ module.setting('on', settings.on || 'click');
+ },
+ popup: function () {
+ if (settings.inline) {
+ return;
+ }
+ if ($activator.length === 0) {
+ $activator = $module.children().first();
+ if ($activator.length === 0) {
+ return;
+ }
+ }
+ if ($.fn.popup === undefined) {
+ module.error(error.popup);
- var
- minute = display.getMinutes(),
- hour = display.getHours(),
- day = display.getDate(),
- startMonth = display.getMonth() + monthOffset,
- year = display.getFullYear()
- ;
+ return;
+ }
+ if ($container.length === 0) {
+ if (settings.context) {
+ module.popupId = namespace + '_popup_' + (Math.random().toString(16) + '000000000').slice(2, 10);
+ $container = $('', { id: module.popupId }).addClass(className.popup).appendTo($document.find(settings.context));
+ } else {
+ // prepend the popup element to the activator's parent so that it has less chance of messing with
+ // the styling (eg input action button needs to be the last child to have correct border radius)
+ var
+ $activatorParent = $activator.parent(),
+ domPositionFunction = $activatorParent.closest(selector.append).length > 0 ? 'appendTo' : 'prependTo'
+ ;
+ $container = $('').addClass(className.popup)[domPositionFunction]($activatorParent);
+ }
+ }
+ $container.addClass(className.calendar);
+ if (isInverted) {
+ $container.addClass(className.inverted);
+ }
+ var onVisible = function () {
+ module.refreshTooltips();
+
+ return settings.onVisible.apply($container, arguments);
+ };
+ var onHidden = function () {
+ module.blur();
+
+ return settings.onHidden.apply($container, arguments);
+ };
+ if ($input.length === 0) {
+ // no input, $container has to handle focus/blur
+ $container.attr('tabindex', '0');
+ onVisible = function () {
+ module.refreshTooltips();
+ module.focus();
+
+ return settings.onVisible.apply($container, arguments);
+ };
+ }
+ var onShow = function () {
+ // reset the focus date onShow
+ module.set.focusDate(module.get.date());
+ module.set.mode(module.get.validatedMode(settings.startMode));
+
+ return settings.onShow.apply($container, arguments);
+ };
+ var on = module.setting('on');
+ var options = $.extend({}, settings.popupOptions, {
+ popup: $container,
+ movePopup: !settings.context,
+ on: on,
+ hoverable: on === 'hover',
+ closable: on === 'click',
+ onShow: onShow,
+ onVisible: onVisible,
+ onHide: settings.onHide,
+ onHidden: onHidden,
+ });
+ module.popup(options);
+ },
+ inline: function () {
+ if ($activator.length > 0 && !settings.inline) {
+ return;
+ }
+ settings.inline = true;
+ $container = $('').addClass(className.calendar).appendTo($module);
+ if ($input.length === 0) {
+ $container.attr('tabindex', '0');
+ }
+ },
+ input: function () {
+ if (settings.touchReadonly && $input.length > 0 && isTouch) {
+ $input.prop('readonly', true);
+ }
+ module.check.disabled();
+ },
+ date: function () {
+ var date;
+ if (settings.initialDate) {
+ date = parser.date(settings.initialDate, settings);
+ } else if ($module.data(metadata.date) !== undefined) {
+ date = parser.date($module.data(metadata.date), settings);
+ } else if ($input.length > 0) {
+ date = parser.date($input.val(), settings);
+ }
+ module.set.date(date, settings.formatInput, false);
+ module.set.mode(module.get.mode(), false);
+ },
+ },
+
+ trigger: {
+ change: function () {
+ var
+ inputElement = $input[0]
+ ;
+ if (inputElement) {
+ var events = document.createEvent('HTMLEvents');
+ module.verbose('Triggering native change event');
+ events.initEvent('change', true, false);
+ inputElement.dispatchEvent(events);
+ }
+ },
+ },
+
+ create: {
+ calendar: function () {
+ var
+ i,
+ r,
+ c,
+ p,
+ row,
+ cell,
+ pageGrid
+ ;
+
+ var
+ mode = module.get.mode(),
+ today = new Date(),
+ date = module.get.date(),
+ focusDate = module.get.focusDate(),
+ display = module.helper.dateInRange(focusDate || date || parser.date(settings.initialDate, settings) || today)
+ ;
+
+ if (!focusDate) {
+ focusDate = display;
+ module.set.focusDate(focusDate, false, false);
+ }
- var columns = isDay ? settings.showWeekNumbers ? 8 : 7 : isHour ? 4 : timeGap['column'];
- var rows = isDay || isHour ? 6 : timeGap['row'];
- var pages = isDay ? multiMonth : 1;
+ var
+ isYear = mode === 'year',
+ isMonth = mode === 'month',
+ isDay = mode === 'day',
+ isHour = mode === 'hour',
+ isMinute = mode === 'minute',
+ isTimeOnly = settings.type === 'time'
+ ;
+
+ var multiMonth = Math.max(settings.multiMonth, 1);
+ var monthOffset = !isDay ? 0 : module.get.monthOffset();
+
+ var
+ minute = display.getMinutes(),
+ hour = display.getHours(),
+ day = display.getDate(),
+ startMonth = display.getMonth() + monthOffset,
+ year = display.getFullYear()
+ ;
+
+ var columns = isDay
+ ? (settings.showWeekNumbers ? 8 : 7)
+ : (isHour ? 4 : timeGap.column);
+ var rows = isDay || isHour ? 6 : timeGap.row;
+ var pages = isDay ? multiMonth : 1;
+
+ var container = $container;
+ var tooltipPosition = container.hasClass('left') ? 'right center' : 'left center';
+ container.empty();
+ if (pages > 1) {
+ pageGrid = $('').addClass(className.grid).appendTo(container);
+ }
- var container = $container;
- var tooltipPosition = container.hasClass("left") ? "right center" : "left center";
- container.empty();
- if (pages > 1) {
- pageGrid = $('').addClass(className.grid).appendTo(container);
- }
+ for (p = 0; p < pages; p++) {
+ if (pages > 1) {
+ var pageColumn = $('').addClass(className.column).appendTo(pageGrid);
+ container = pageColumn;
+ }
+
+ var month = startMonth + p;
+ var firstMonthDayColumn = (new Date(year, month, 1).getDay() - (settings.firstDayOfWeek % 7) + 7) % 7;
+ if (!settings.constantHeight && isDay) {
+ var requiredCells = new Date(year, month + 1, 0).getDate() + firstMonthDayColumn;
+ rows = Math.ceil(requiredCells / 7);
+ }
+
+ var
+ yearChange = isYear ? 10 : (isMonth ? 1 : 0),
+ monthChange = isDay ? 1 : 0,
+ dayChange = isHour || isMinute ? 1 : 0,
+ prevNextDay = isHour || isMinute ? day : 1,
+ prevDate = new Date(year - yearChange, month - monthChange, prevNextDay - dayChange, hour),
+ nextDate = new Date(year + yearChange, month + monthChange, prevNextDay + dayChange, hour),
+ prevLast = isYear
+ ? new Date(Math.ceil(year / 10) * 10 - 9, 0, 0)
+ : (isMonth
+ ? new Date(year, 0, 0)
+ : (isDay // eslint-disable-line unicorn/no-nested-ternary
+ ? new Date(year, month, 0)
+ : new Date(year, month, day, -1))),
+ nextFirst = isYear
+ ? new Date(Math.ceil(year / 10) * 10 + 1, 0, 1)
+ : (isMonth
+ ? new Date(year + 1, 0, 1)
+ : (isDay // eslint-disable-line unicorn/no-nested-ternary
+ ? new Date(year, month + 1, 1)
+ : new Date(year, month, day + 1)))
+ ;
+
+ var tempMode = mode;
+ if (isDay && settings.showWeekNumbers) {
+ tempMode += ' andweek';
+ }
+ var table = $('').addClass(className.table).addClass(tempMode).addClass(numberText[columns] + ' column')
+ .appendTo(container);
+ if (isInverted) {
+ table.addClass(className.inverted);
+ }
+ var textColumns = columns;
+ // no header for time-only mode
+ if (!isTimeOnly) {
+ var thead = $('').appendTo(table);
+
+ row = $('
').appendTo(thead);
+ cell = $(' | ').attr('colspan', '' + columns).appendTo(row);
+
+ var headerDate = isYear || isMonth
+ ? new Date(year, 0, 1)
+ : (isDay
+ ? new Date(year, month, 1)
+ : new Date(year, month, day, hour, minute));
+ var headerText = $('').addClass(className.link).appendTo(cell);
+ headerText.text(module.helper.dateFormat(formatter[mode + 'Header'], headerDate));
+ var newMode = isMonth
+ ? (settings.disableYear ? 'day' : 'year')
+ : (isDay
+ ? (settings.disableMonth ? 'year' : 'month') // eslint-disable-line unicorn/no-nested-ternary
+ : 'day');
+ headerText.data(metadata.mode, newMode);
+
+ if (p === 0) {
+ var prev = $('').addClass(className.prev).appendTo(cell);
+ prev.data(metadata.focusDate, prevDate);
+ prev.toggleClass(className.disabledCell, !module.helper.isDateInRange(prevLast, mode));
+ $('').addClass(className.prevIcon).appendTo(prev);
+ }
+
+ if (p === pages - 1) {
+ var next = $('').addClass(className.next).appendTo(cell);
+ next.data(metadata.focusDate, nextDate);
+ next.toggleClass(className.disabledCell, !module.helper.isDateInRange(nextFirst, mode));
+ $('').addClass(className.nextIcon).appendTo(next);
+ }
+ if (isDay) {
+ row = $('
').appendTo(thead);
+ if (settings.showWeekNumbers) {
+ cell = $(' | ').appendTo(row);
+ cell.text(settings.text.weekNo);
+ cell.addClass(className.weekCell);
+ textColumns--;
+ }
+ for (i = 0; i < textColumns; i++) {
+ cell = $(' | ').appendTo(row);
+ cell.text(formatter.dayColumnHeader((i + settings.firstDayOfWeek) % 7, settings));
+ }
+ }
+ }
+
+ var tbody = $('').appendTo(table);
+ i = isYear
+ ? Math.ceil(year / 10) * 10 - 9
+ : (isDay ? 1 - firstMonthDayColumn : 0);
+ for (r = 0; r < rows; r++) {
+ row = $('
').appendTo(tbody);
+ if (isDay && settings.showWeekNumbers) {
+ cell = $(' | ').appendTo(row);
+ cell.text(module.get.weekOfYear(year, month, i + 1 - settings.firstDayOfWeek));
+ cell.addClass(className.weekCell);
+ }
+ for (c = 0; c < textColumns; c++, i++) {
+ var cellDate = isYear
+ ? new Date(i, month, 1, hour, minute)
+ : (isMonth
+ ? new Date(year, i, 1, hour, minute)
+ : (isDay // eslint-disable-line unicorn/no-nested-ternary
+ ? new Date(year, month, i, hour, minute)
+ : (isHour
+ ? new Date(year, month, day, i)
+ : new Date(year, month, day, hour, i * settings.minTimeGap))));
+ var cellText = isYear
+ ? i
+ : (isMonth
+ ? settings.text.monthsShort[i]
+ : (isDay // eslint-disable-line unicorn/no-nested-ternary
+ ? cellDate.getDate()
+ : module.helper.dateFormat(formatter.cellTime, cellDate)));
+ cell = $(' | ').addClass(className.cell).appendTo(row);
+ cell.text(cellText);
+ cell.data(metadata.date, cellDate);
+ var adjacent = isDay && cellDate.getMonth() !== ((month + 12) % 12);
+ var disabled = (!settings.selectAdjacentDays && adjacent) || !module.helper.isDateInRange(cellDate, mode) || settings.isDisabled(cellDate, mode) || module.helper.isDisabled(cellDate, mode) || !module.helper.isEnabled(cellDate, mode);
+ var eventDate;
+ if (disabled) {
+ var disabledDate = module.helper.findDayAsObject(cellDate, mode, settings.disabledDates);
+ if (disabledDate !== null && disabledDate[metadata.message]) {
+ cell.attr('data-tooltip', disabledDate[metadata.message]);
+ cell.attr('data-position', disabledDate[metadata.position] || tooltipPosition);
+ if (disabledDate[metadata.inverted] || (isInverted && disabledDate[metadata.inverted] === undefined)) {
+ cell.attr('data-inverted', '');
+ }
+ if (disabledDate[metadata.variation]) {
+ cell.attr('data-variation', disabledDate[metadata.variation]);
+ }
+ }
+ if (mode === 'hour') {
+ var disabledHour = module.helper.findHourAsObject(cellDate, mode, settings.disabledHours);
+ if (disabledHour !== null && disabledHour[metadata.message]) {
+ cell.attr('data-tooltip', disabledHour[metadata.message]);
+ cell.attr('data-position', disabledHour[metadata.position] || tooltipPosition);
+ if (disabledHour[metadata.inverted] || (isInverted && disabledHour[metadata.inverted] === undefined)) {
+ cell.attr('data-inverted', '');
+ }
+ if (disabledHour[metadata.variation]) {
+ cell.attr('data-variation', disabledHour[metadata.variation]);
+ }
+ }
+ }
+ } else {
+ eventDate = module.helper.findDayAsObject(cellDate, mode, settings.eventDates);
+ if (eventDate !== null) {
+ cell.addClass(eventDate[metadata.class] || settings.eventClass);
+ if (eventDate[metadata.message]) {
+ cell.attr('data-tooltip', eventDate[metadata.message]);
+ cell.attr('data-position', eventDate[metadata.position] || tooltipPosition);
+ if (eventDate[metadata.inverted] || (isInverted && eventDate[metadata.inverted] === undefined)) {
+ cell.attr('data-inverted', '');
+ }
+ if (eventDate[metadata.variation]) {
+ cell.attr('data-variation', eventDate[metadata.variation]);
+ }
+ }
+ }
+ }
+ var active = module.helper.dateEqual(cellDate, date, mode);
+ var isToday = module.helper.dateEqual(cellDate, today, mode);
+ cell.toggleClass(className.adjacentCell, adjacent && !eventDate);
+ cell.toggleClass(className.disabledCell, disabled);
+ cell.toggleClass(className.activeCell, active && !(adjacent && disabled));
+ if (!isHour && !isMinute) {
+ cell.toggleClass(className.todayCell, !adjacent && isToday);
+ }
+
+ // Allow for external modifications of each cell
+ var cellOptions = {
+ mode: mode,
+ adjacent: adjacent,
+ disabled: disabled,
+ active: active,
+ today: isToday,
+ };
+ formatter.cell(cell, cellDate, cellOptions);
+
+ if (module.helper.dateEqual(cellDate, focusDate, mode)) {
+ // ensure that the focus date is exactly equal to the cell date
+ // so that, if selected, the correct value is set
+ module.set.focusDate(cellDate, false, false);
+ }
+ }
+ }
+
+ if (settings.today) {
+ var todayRow = $('
').appendTo(tbody);
+ var todayButton = $(' | ').attr('colspan', '' + columns).addClass(className.today).appendTo(todayRow);
+ todayButton.text(formatter.today(settings));
+ todayButton.data(metadata.date, today);
+ }
+
+ module.update.focus(false, table);
+
+ if (settings.inline) {
+ module.refreshTooltips();
+ }
+ }
+ },
+ },
+
+ update: {
+ focus: function (updateRange, container) {
+ container = container || $container;
+ var mode = module.get.mode();
+ var date = module.get.date();
+ var focusDate = module.get.focusDate();
+ var startDate = module.get.startDate();
+ var endDate = module.get.endDate();
+ var rangeDate = (updateRange ? focusDate : null) || date || (!isTouch ? focusDate : null);
+
+ container.find('td').each(function () {
+ var $cell = $(this);
+ var cellDate = $cell.data(metadata.date);
+ if (!cellDate) {
+ return;
+ }
+ var disabled = $cell.hasClass(className.disabledCell);
+ var active = $cell.hasClass(className.activeCell);
+ var adjacent = $cell.hasClass(className.adjacentCell);
+ var focused = module.helper.dateEqual(cellDate, focusDate, mode);
+ var inRange = !rangeDate
+ ? false
+ : (!!startDate && module.helper.isDateInRange(cellDate, mode, startDate, rangeDate))
+ || (!!endDate && module.helper.isDateInRange(cellDate, mode, rangeDate, endDate));
+ $cell.toggleClass(className.focusCell, focused && (!isTouch || isTouchDown) && (!adjacent || (settings.selectAdjacentDays && adjacent)) && !disabled);
+
+ if (module.helper.isTodayButton($cell)) {
+ return;
+ }
+ $cell.toggleClass(className.rangeCell, inRange && !active && !disabled);
+ });
+ },
+ },
+
+ refresh: function () {
+ module.create.calendar();
+ },
+
+ refreshTooltips: function () {
+ var winWidth = $(window).width();
+ $container.find('td[data-position]').each(function () {
+ var $cell = $(this);
+ var tooltipWidth = window.getComputedStyle($cell[0], '::after').width.replace(/[^\d.]/g, '');
+ var tooltipPosition = $cell.attr('data-position');
+ // use a fallback width of 250 (calendar width) for IE/Edge (which return "auto")
+ var calcPosition = (winWidth - $cell.width() - (parseInt(tooltipWidth, 10) || 250)) > $cell.offset().left ? 'right' : 'left';
+ if (tooltipPosition.indexOf(calcPosition) === -1) {
+ $cell.attr('data-position', tooltipPosition.replace(/(left|right)/, calcPosition));
+ }
+ });
+ },
+
+ bind: {
+ events: function () {
+ module.debug('Binding events');
+ $container.on('mousedown' + eventNamespace, module.event.mousedown);
+ $container.on('touchstart' + eventNamespace, module.event.mousedown);
+ $container.on('mouseup' + eventNamespace, module.event.mouseup);
+ $container.on('touchend' + eventNamespace, module.event.mouseup);
+ $container.on('mouseover' + eventNamespace, module.event.mouseover);
+ if ($input.length > 0) {
+ $input.on('input' + eventNamespace, module.event.inputChange);
+ $input.on('focus' + eventNamespace, module.event.inputFocus);
+ $input.on('blur' + eventNamespace, module.event.inputBlur);
+ $input.on('keydown' + eventNamespace, module.event.keydown);
+ } else {
+ $container.on('keydown' + eventNamespace, module.event.keydown);
+ }
+ },
+ },
+
+ unbind: {
+ events: function () {
+ module.debug('Unbinding events');
+ $container.off(eventNamespace);
+ if ($input.length > 0) {
+ $input.off(eventNamespace);
+ }
+ },
+ },
+
+ event: {
+ mouseover: function (event) {
+ var target = $(event.target);
+ var date = target.data(metadata.date);
+ var mousedown = event.buttons === 1;
+ if (date) {
+ module.set.focusDate(date, false, true, mousedown);
+ }
+ },
+ mousedown: function (event) {
+ if ($input.length > 0) {
+ // prevent the mousedown on the calendar causing the input to lose focus
+ event.preventDefault();
+ }
+ isTouchDown = event.type.indexOf('touch') >= 0;
+ var target = $(event.target);
+ var date = target.data(metadata.date);
+ if (date) {
+ module.set.focusDate(date, false, true, true);
+ }
+ },
+ mouseup: function (event) {
+ // ensure input has focus so that it receives keydown events for calendar navigation
+ module.focus();
+ event.preventDefault();
+ event.stopPropagation();
+ isTouchDown = false;
+ var target = $(event.target);
+ if (target.hasClass('disabled')) {
+ return;
+ }
+ var parent = target.parent();
+ if (parent.data(metadata.date) || parent.data(metadata.focusDate) || parent.data(metadata.mode)) {
+ // clicked on a child element, switch to parent (used when clicking directly on prev/next icon element)
+ target = parent;
+ }
+ var date = target.data(metadata.date);
+ var focusDate = target.data(metadata.focusDate);
+ var mode = target.data(metadata.mode);
+ if (date && settings.onSelect.call(element, date, module.get.mode()) !== false) {
+ var forceSet = target.hasClass(className.today);
+ module.selectDate(date, forceSet);
+ } else if (focusDate) {
+ module.set.focusDate(focusDate);
+ } else if (mode) {
+ module.set.mode(mode);
+ }
+ },
+ keydown: function (event) {
+ var keyCode = event.which;
+ if (keyCode === 9) {
+ // tab
+ module.popup('hide');
+ }
- for (p = 0; p < pages; p++) {
- if (pages > 1) {
- var pageColumn = $('').addClass(className.column).appendTo(pageGrid);
- container = pageColumn;
- }
-
- var month = startMonth + p;
- var firstMonthDayColumn = (new Date(year, month, 1).getDay() - settings.firstDayOfWeek % 7 + 7) % 7;
- if (!settings.constantHeight && isDay) {
- var requiredCells = new Date(year, month + 1, 0).getDate() + firstMonthDayColumn;
- rows = Math.ceil(requiredCells / 7);
- }
-
- var
- yearChange = isYear ? 10 : isMonth ? 1 : 0,
- monthChange = isDay ? 1 : 0,
- dayChange = isHour || isMinute ? 1 : 0,
- prevNextDay = isHour || isMinute ? day : 1,
- prevDate = new Date(year - yearChange, month - monthChange, prevNextDay - dayChange, hour),
- nextDate = new Date(year + yearChange, month + monthChange, prevNextDay + dayChange, hour),
- prevLast = isYear ? new Date(Math.ceil(year / 10) * 10 - 9, 0, 0) :
- isMonth ? new Date(year, 0, 0) : isDay ? new Date(year, month, 0) : new Date(year, month, day, -1),
- nextFirst = isYear ? new Date(Math.ceil(year / 10) * 10 + 1, 0, 1) :
- isMonth ? new Date(year + 1, 0, 1) : isDay ? new Date(year, month + 1, 1) : new Date(year, month, day + 1)
- ;
-
- var tempMode = mode;
- if (isDay && settings.showWeekNumbers){
- tempMode += ' andweek';
- }
- var table = $('').addClass(className.table).addClass(tempMode).addClass(numberText[columns] + ' column').appendTo(container);
- if(isInverted){
- table.addClass(className.inverted);
- }
- var textColumns = columns;
- //no header for time-only mode
- if (!isTimeOnly) {
- var thead = $('').appendTo(table);
-
- row = $('
').appendTo(thead);
- cell = $(' | ').attr('colspan', '' + columns).appendTo(row);
-
- var headerDate = isYear || isMonth ? new Date(year, 0, 1) :
- isDay ? new Date(year, month, 1) : new Date(year, month, day, hour, minute);
- var headerText = $('').addClass(className.link).appendTo(cell);
- headerText.text(module.helper.dateFormat(formatter[mode+'Header'], headerDate));
- var newMode = isMonth ? (settings.disableYear ? 'day' : 'year') :
- isDay ? (settings.disableMonth ? 'year' : 'month') : 'day';
- headerText.data(metadata.mode, newMode);
-
- if (p === 0) {
- var prev = $('').addClass(className.prev).appendTo(cell);
- prev.data(metadata.focusDate, prevDate);
- prev.toggleClass(className.disabledCell, !module.helper.isDateInRange(prevLast, mode));
- $('').addClass(className.prevIcon).appendTo(prev);
- }
+ if (module.popup('is visible')) {
+ var mode = module.get.mode();
+ switch (keyCode) {
+ // arrow keys
+ case 37:
+ case 38:
+ case 39:
+ case 40: {
+ var bigIncrement = mode === 'day'
+ ? 7
+ : (mode === 'hour'
+ ? 4
+ : (mode === 'minute' ? timeGap.column : 3)); // eslint-disable-line unicorn/no-nested-ternary
+ var increment = keyCode === 37
+ ? -1
+ : (keyCode === 38
+ ? -bigIncrement
+ : (keyCode === 39 ? 1 : bigIncrement)); // eslint-disable-line unicorn/no-nested-ternary
+ increment *= mode === 'minute' ? settings.minTimeGap : 1;
+ var focusDate = module.get.focusDate() || module.get.date() || new Date();
+ var year = focusDate.getFullYear() + (mode === 'year' ? increment : 0);
+ var month = focusDate.getMonth() + (mode === 'month' ? increment : 0);
+ var day = focusDate.getDate() + (mode === 'day' ? increment : 0);
+ var hour = focusDate.getHours() + (mode === 'hour' ? increment : 0);
+ var minute = focusDate.getMinutes() + (mode === 'minute' ? increment : 0);
+ var newFocusDate = new Date(year, month, day, hour, minute);
+ if (settings.type === 'time') {
+ newFocusDate = module.helper.mergeDateTime(focusDate, newFocusDate);
+ }
+ if (module.helper.isDateInRange(newFocusDate, mode)) {
+ module.set.focusDate(newFocusDate);
+ }
+
+ break;
+ }
+ // enter key
+ case 13: {
+ var date = module.get.focusDate();
+ if (date && !settings.isDisabled(date, mode) && !module.helper.isDisabled(date, mode) && module.helper.isEnabled(date, mode)) {
+ if (settings.onSelect.call(element, date, module.get.mode()) !== false) {
+ module.selectDate(date);
+ }
+ }
+ // disable form submission:
+ event.preventDefault();
+ event.stopPropagation();
+
+ break;
+ }
+ // escape key
+ case 27: {
+ module.popup('hide');
+ event.stopPropagation();
+
+ break;
+ }
+ }
+ }
- if (p === pages - 1) {
- var next = $('').addClass(className.next).appendTo(cell);
- next.data(metadata.focusDate, nextDate);
- next.toggleClass(className.disabledCell, !module.helper.isDateInRange(nextFirst, mode));
- $('').addClass(className.nextIcon).appendTo(next);
- }
- if (isDay) {
- row = $('
').appendTo(thead);
- if(settings.showWeekNumbers) {
- cell = $(' | ').appendTo(row);
- cell.text(settings.text.weekNo);
- cell.addClass(className.weekCell);
- textColumns--;
- }
- for (i = 0; i < textColumns; i++) {
- cell = $(' | ').appendTo(row);
- cell.text(formatter.dayColumnHeader((i + settings.firstDayOfWeek) % 7, settings));
- }
- }
- }
-
- var tbody = $('').appendTo(table);
- i = isYear ? Math.ceil(year / 10) * 10 - 9 : isDay ? 1 - firstMonthDayColumn : 0;
- for (r = 0; r < rows; r++) {
- row = $('
').appendTo(tbody);
- if(isDay && settings.showWeekNumbers){
- cell = $(' | ').appendTo(row);
- cell.text(module.get.weekOfYear(year,month,i+1-settings.firstDayOfWeek));
- cell.addClass(className.weekCell);
- }
- for (c = 0; c < textColumns; c++, i++) {
- var cellDate = isYear ? new Date(i, month, 1, hour, minute) :
- isMonth ? new Date(year, i, 1, hour, minute) : isDay ? new Date(year, month, i, hour, minute) :
- isHour ? new Date(year, month, day, i) : new Date(year, month, day, hour, i * settings.minTimeGap);
- var cellText = isYear ? i :
- isMonth ? settings.text.monthsShort[i] : isDay ? cellDate.getDate() :
- module.helper.dateFormat(formatter.cellTime,cellDate);
- cell = $(' | ').addClass(className.cell).appendTo(row);
- cell.text(cellText);
- cell.data(metadata.date, cellDate);
- var adjacent = isDay && cellDate.getMonth() !== ((month + 12) % 12);
- var disabled = (!settings.selectAdjacentDays && adjacent) || !module.helper.isDateInRange(cellDate, mode) || settings.isDisabled(cellDate, mode) || module.helper.isDisabled(cellDate, mode) || !module.helper.isEnabled(cellDate, mode);
- var eventDate;
- if (disabled) {
- var disabledDate = module.helper.findDayAsObject(cellDate, mode, settings.disabledDates);
- if (disabledDate !== null && disabledDate[metadata.message]) {
- cell.attr("data-tooltip", disabledDate[metadata.message]);
- cell.attr("data-position", disabledDate[metadata.position] || tooltipPosition);
- if(disabledDate[metadata.inverted] || (isInverted && disabledDate[metadata.inverted] === undefined)) {
- cell.attr("data-inverted", '');
- }
- if(disabledDate[metadata.variation]) {
- cell.attr("data-variation", disabledDate[metadata.variation]);
- }
- }
- if (mode === 'hour') {
- var disabledHour = module.helper.findHourAsObject(cellDate, mode, settings.disabledHours);
- if (disabledHour !== null && disabledHour[metadata.message]) {
- cell.attr("data-tooltip", disabledHour[metadata.message]);
- cell.attr("data-position", disabledHour[metadata.position] || tooltipPosition);
- if(disabledHour[metadata.inverted] || (isInverted && disabledHour[metadata.inverted] === undefined)) {
- cell.attr("data-inverted", '');
- }
- if(disabledHour[metadata.variation]) {
- cell.attr("data-variation", disabledHour[metadata.variation]);
- }
- }
- }
- } else {
- eventDate = module.helper.findDayAsObject(cellDate, mode, settings.eventDates);
- if (eventDate !== null) {
- cell.addClass(eventDate[metadata.class] || settings.eventClass);
- if (eventDate[metadata.message]) {
- cell.attr("data-tooltip", eventDate[metadata.message]);
- cell.attr("data-position", eventDate[metadata.position] || tooltipPosition);
- if(eventDate[metadata.inverted] || (isInverted && eventDate[metadata.inverted] === undefined)) {
- cell.attr("data-inverted", '');
- }
- if(eventDate[metadata.variation]) {
- cell.attr("data-variation", eventDate[metadata.variation]);
- }
- }
+ if (keyCode === 38 || keyCode === 40) {
+ // arrow-up || arrow-down
+ event.preventDefault(); // don't scroll
+ module.popup('show');
+ }
+ },
+ inputChange: function () {
+ var val = $input.val();
+ var date = parser.date(val, settings);
+ module.set.date(date, false);
+ },
+ inputFocus: function () {
+ $container.addClass(className.active);
+ },
+ inputBlur: function () {
+ $container.removeClass(className.active);
+ if (settings.formatInput) {
+ var date = module.get.date();
+ var text = module.helper.dateFormat(formatter[settings.type], date);
+ $input.val(text);
+ }
+ if (selectionComplete) {
+ module.trigger.change();
+ selectionComplete = false;
+ }
+ },
+ class: {
+ mutation: function (mutations) {
+ mutations.forEach(function (mutation) {
+ if (mutation.attributeName === 'class') {
+ module.check.disabled();
+ }
+ });
+ },
+ },
+ },
+
+ observeChanges: function () {
+ if ('MutationObserver' in window) {
+ classObserver = new MutationObserver(module.event.class.mutation);
+ module.debug('Setting up mutation observer', classObserver);
+ module.observe.class();
}
- }
- var active = module.helper.dateEqual(cellDate, date, mode);
- var isToday = module.helper.dateEqual(cellDate, today, mode);
- cell.toggleClass(className.adjacentCell, adjacent && !eventDate);
- cell.toggleClass(className.disabledCell, disabled);
- cell.toggleClass(className.activeCell, active && !(adjacent && disabled));
- if (!isHour && !isMinute) {
- cell.toggleClass(className.todayCell, !adjacent && isToday);
- }
-
- // Allow for external modifications of each cell
- var cellOptions = {
- mode: mode,
- adjacent: adjacent,
- disabled: disabled,
- active: active,
- today: isToday
- };
- formatter.cell(cell, cellDate, cellOptions);
-
- if (module.helper.dateEqual(cellDate, focusDate, mode)) {
- //ensure that the focus date is exactly equal to the cell date
- //so that, if selected, the correct value is set
- module.set.focusDate(cellDate, false, false);
- }
- }
- }
+ },
- if (settings.today) {
- var todayRow = $('
').appendTo(tbody);
- var todayButton = $(' | ').attr('colspan', '' + columns).addClass(className.today).appendTo(todayRow);
- todayButton.text(formatter.today(settings));
- todayButton.data(metadata.date, today);
- }
+ disconnect: {
+ classObserver: function () {
+ if ($input.length > 0 && classObserver) {
+ classObserver.disconnect();
+ }
+ },
+ },
+
+ observe: {
+ class: function () {
+ if ($input.length > 0 && classObserver) {
+ classObserver.observe($module[0], {
+ attributes: true,
+ });
+ }
+ },
+ },
+
+ is: {
+ disabled: function () {
+ return $module.hasClass(className.disabled);
+ },
+ },
+
+ check: {
+ disabled: function () {
+ $input.attr('tabindex', module.is.disabled() ? -1 : 0);
+ },
+ },
+
+ get: {
+ weekOfYear: function (weekYear, weekMonth, weekDay) {
+ // adapted from http://www.merlyn.demon.co.uk/weekcalc.htm
+ var ms1d = 24 * 3600 * 1000,
+ ms7d = 7 * ms1d,
+ DC3 = Date.UTC(weekYear, weekMonth, weekDay + 3) / ms1d, // an absolute day number
+ AWN = Math.floor(DC3 / 7), // an absolute week number
+ Wyr = new Date(AWN * ms7d).getUTCFullYear()
+ ;
+
+ return AWN - Math.floor(Date.UTC(Wyr, 0, 7) / ms7d) + 1;
+ },
+ formattedDate: function (format, date) {
+ return module.helper.dateFormat(format || formatter[settings.type], date || module.get.date());
+ },
+ date: function () {
+ return module.helper.sanitiseDate($module.data(metadata.date)) || null;
+ },
+ inputDate: function () {
+ return $input.val();
+ },
+ focusDate: function () {
+ return $module.data(metadata.focusDate) || null;
+ },
+ startDate: function () {
+ var startModule = module.get.calendarModule(settings.startCalendar);
+
+ return (startModule ? startModule.get.date() : $module.data(metadata.startDate)) || null;
+ },
+ endDate: function () {
+ var endModule = module.get.calendarModule(settings.endCalendar);
+
+ return (endModule ? endModule.get.date() : $module.data(metadata.endDate)) || null;
+ },
+ minDate: function () {
+ return $module.data(metadata.minDate) || null;
+ },
+ maxDate: function () {
+ return $module.data(metadata.maxDate) || null;
+ },
+ monthOffset: function () {
+ return $module.data(metadata.monthOffset) || settings.monthOffset || 0;
+ },
+ mode: function () {
+ // only returns valid modes for the current settings
+ var mode = $module.data(metadata.mode) || settings.startMode;
+
+ return module.get.validatedMode(mode);
+ },
+ validatedMode: function (mode) {
+ var validModes = module.get.validModes();
+ if ($.inArray(mode, validModes) >= 0) {
+ return mode;
+ }
- module.update.focus(false, table);
+ return settings.type === 'time'
+ ? 'hour'
+ : (settings.type === 'month'
+ ? 'month'
+ : (settings.type === 'year' ? 'year' : 'day')); // eslint-disable-line unicorn/no-nested-ternary
+ },
+ type: function () {
+ return $module.data(metadata.type) || settings.type;
+ },
+ validModes: function () {
+ var validModes = [];
+ if (settings.type !== 'time') {
+ if (!settings.disableYear || settings.type === 'year') {
+ validModes.push('year');
+ }
+ if (!(settings.disableMonth || settings.type === 'year') || settings.type === 'month') {
+ validModes.push('month');
+ }
+ if (settings.type.indexOf('date') >= 0) {
+ validModes.push('day');
+ }
+ }
+ if (settings.type.indexOf('time') >= 0) {
+ validModes.push('hour');
+ if (!settings.disableMinute) {
+ validModes.push('minute');
+ }
+ }
- if(settings.inline){
- module.refreshTooltips();
- }
- }
- }
- },
+ return validModes;
+ },
+ isTouch: function () {
+ try {
+ document.createEvent('TouchEvent');
- update: {
- focus: function (updateRange, container) {
- container = container || $container;
- var mode = module.get.mode();
- var date = module.get.date();
- var focusDate = module.get.focusDate();
- var startDate = module.get.startDate();
- var endDate = module.get.endDate();
- var rangeDate = (updateRange ? focusDate : null) || date || (!isTouch ? focusDate : null);
-
- container.find('td').each(function () {
- var cell = $(this);
- var cellDate = cell.data(metadata.date);
- if (!cellDate) {
- return;
- }
- var disabled = cell.hasClass(className.disabledCell);
- var active = cell.hasClass(className.activeCell);
- var adjacent = cell.hasClass(className.adjacentCell);
- var focused = module.helper.dateEqual(cellDate, focusDate, mode);
- var inRange = !rangeDate ? false :
- ((!!startDate && module.helper.isDateInRange(cellDate, mode, startDate, rangeDate)) ||
- (!!endDate && module.helper.isDateInRange(cellDate, mode, rangeDate, endDate)));
- cell.toggleClass(className.focusCell, focused && (!isTouch || isTouchDown) && (!adjacent || (settings.selectAdjacentDays && adjacent)) && !disabled);
-
- if (module.helper.isTodayButton(cell)) {
- return;
- }
- cell.toggleClass(className.rangeCell, inRange && !active && !disabled);
- });
- }
- },
+ return true;
+ } catch (e) {
+ return false;
+ }
+ },
+ calendarModule: function (selector) {
+ if (!selector) {
+ return null;
+ }
+ if (!(selector instanceof $)) {
+ selector = $document.find(selector).first();
+ }
- refresh: function () {
- module.create.calendar();
- },
+ // assume range related calendars are using the same namespace
+ return selector.data(moduleNamespace);
+ },
+ },
- refreshTooltips: function() {
- var winWidth = $(window).width();
- $container.find('td[data-position]').each(function () {
- var cell = $(this);
- var tooltipWidth = window.getComputedStyle(cell[0], '::after').width.replace(/[^0-9\.]/g,'');
- var tooltipPosition = cell.attr('data-position');
- // use a fallback width of 250 (calendar width) for IE/Edge (which return "auto")
- var calcPosition = (winWidth - cell.width() - (parseInt(tooltipWidth,10) || 250)) > cell.offset().left ? 'right' : 'left';
- if(tooltipPosition.indexOf(calcPosition) === -1) {
- cell.attr('data-position',tooltipPosition.replace(/(left|right)/,calcPosition));
- }
- });
- },
+ set: {
+ date: function (date, updateInput, fireChange) {
+ updateInput = updateInput !== false;
+ fireChange = fireChange !== false;
+ date = module.helper.sanitiseDate(date);
+ date = module.helper.dateInRange(date);
- bind: {
- events: function () {
- module.debug('Binding events');
- $container.on('mousedown' + eventNamespace, module.event.mousedown);
- $container.on('touchstart' + eventNamespace, module.event.mousedown);
- $container.on('mouseup' + eventNamespace, module.event.mouseup);
- $container.on('touchend' + eventNamespace, module.event.mouseup);
- $container.on('mouseover' + eventNamespace, module.event.mouseover);
- if ($input.length) {
- $input.on('input' + eventNamespace, module.event.inputChange);
- $input.on('focus' + eventNamespace, module.event.inputFocus);
- $input.on('blur' + eventNamespace, module.event.inputBlur);
- $input.on('keydown' + eventNamespace, module.event.keydown);
- } else {
- $container.on('keydown' + eventNamespace, module.event.keydown);
- }
- }
- },
+ var mode = module.get.mode();
+ var text = module.helper.dateFormat(formatter[settings.type], date);
- unbind: {
- events: function () {
- module.debug('Unbinding events');
- $container.off(eventNamespace);
- if ($input.length) {
- $input.off(eventNamespace);
- }
- }
- },
+ if (fireChange && settings.onBeforeChange.call(element, date, text, mode) === false) {
+ return false;
+ }
- event: {
- mouseover: function (event) {
- var target = $(event.target);
- var date = target.data(metadata.date);
- var mousedown = event.buttons === 1;
- if (date) {
- module.set.focusDate(date, false, true, mousedown);
- }
- },
- mousedown: function (event) {
- if ($input.length) {
- //prevent the mousedown on the calendar causing the input to lose focus
- event.preventDefault();
- }
- isTouchDown = event.type.indexOf('touch') >= 0;
- var target = $(event.target);
- var date = target.data(metadata.date);
- if (date) {
- module.set.focusDate(date, false, true, true);
- }
- },
- mouseup: function (event) {
- //ensure input has focus so that it receives keydown events for calendar navigation
- module.focus();
- event.preventDefault();
- event.stopPropagation();
- isTouchDown = false;
- var target = $(event.target);
- if (target.hasClass("disabled")) {
- return;
- }
- var parent = target.parent();
- if (parent.data(metadata.date) || parent.data(metadata.focusDate) || parent.data(metadata.mode)) {
- //clicked on a child element, switch to parent (used when clicking directly on prev/next icon element)
- target = parent;
- }
- var date = target.data(metadata.date);
- var focusDate = target.data(metadata.focusDate);
- var mode = target.data(metadata.mode);
- if (date && settings.onSelect.call(element, date, module.get.mode()) !== false) {
- var forceSet = target.hasClass(className.today);
- module.selectDate(date, forceSet);
- }
- else if (focusDate) {
- module.set.focusDate(focusDate);
- }
- else if (mode) {
- module.set.mode(mode);
- }
- },
- keydown: function (event) {
- var keyCode = event.which;
- if (keyCode === 9) {
- //tab
- module.popup('hide');
- }
+ module.set.focusDate(date);
- if (module.popup('is visible')) {
- var mode = module.get.mode();
- if (keyCode === 37 || keyCode === 38 || keyCode === 39 || keyCode === 40) {
- //arrow keys
- var bigIncrement = mode === 'day' ? 7 : mode === 'hour' ? 4 : mode === 'minute' ? timeGap['column'] : 3;
- var increment = keyCode === 37 ? -1 : keyCode === 38 ? -bigIncrement : keyCode == 39 ? 1 : bigIncrement;
- increment *= mode === 'minute' ? settings.minTimeGap : 1;
- var focusDate = module.get.focusDate() || module.get.date() || new Date();
- var year = focusDate.getFullYear() + (mode === 'year' ? increment : 0);
- var month = focusDate.getMonth() + (mode === 'month' ? increment : 0);
- var day = focusDate.getDate() + (mode === 'day' ? increment : 0);
- var hour = focusDate.getHours() + (mode === 'hour' ? increment : 0);
- var minute = focusDate.getMinutes() + (mode === 'minute' ? increment : 0);
- var newFocusDate = new Date(year, month, day, hour, minute);
- if (settings.type === 'time') {
- newFocusDate = module.helper.mergeDateTime(focusDate, newFocusDate);
- }
- if (module.helper.isDateInRange(newFocusDate, mode)) {
- module.set.focusDate(newFocusDate);
- }
- } else if (keyCode === 13) {
- //enter
- var date = module.get.focusDate();
- if (date && !settings.isDisabled(date, mode) && !module.helper.isDisabled(date, mode) && module.helper.isEnabled(date, mode)) {
- if (settings.onSelect.call(element, date, module.get.mode()) !== false) {
- module.selectDate(date);
- }
- }
- //disable form submission:
- event.preventDefault();
- event.stopPropagation();
- } else if (keyCode === 27) {
- module.popup('hide');
- event.stopPropagation();
- }
- }
+ if (settings.isDisabled(date, mode)) {
+ return false;
+ }
- if (keyCode === 38 || keyCode === 40) {
- //arrow-up || arrow-down
- event.preventDefault(); //don't scroll
- module.popup('show');
- }
- },
- inputChange: function () {
- var val = $input.val();
- var date = parser.date(val, settings);
- module.set.date(date, false);
- },
- inputFocus: function () {
- $container.addClass(className.active);
- },
- inputBlur: function () {
- $container.removeClass(className.active);
- if (settings.formatInput) {
- var date = module.get.date();
- var text = module.helper.dateFormat(formatter[settings.type], date);
- $input.val(text);
- }
- if(selectionComplete){
- module.trigger.change();
- selectionComplete = false;
- }
- },
- class: {
- mutation: function(mutations) {
- mutations.forEach(function(mutation) {
- if(mutation.attributeName === "class") {
- module.check.disabled();
- }
- });
- }
- }
- },
+ var endDate = module.get.endDate();
+ if (!!endDate && !!date && date > endDate) {
+ // selected date is greater than end date in range, so clear end date
+ module.set.endDate();
+ }
+ module.set.dataKeyValue(metadata.date, date);
- observeChanges: function() {
- if('MutationObserver' in window) {
- classObserver = new MutationObserver(module.event.class.mutation);
- module.debug('Setting up mutation observer', classObserver);
- module.observe.class();
- }
- },
+ if (updateInput && $input.length > 0) {
+ $input.val(text);
+ }
- disconnect: {
- classObserver: function() {
- if($input.length && classObserver) {
- classObserver.disconnect();
- }
- }
- },
+ if (fireChange) {
+ settings.onChange.call(element, date, text, mode);
+ }
+ },
+ startDate: function (date, refreshCalendar) {
+ date = module.helper.sanitiseDate(date);
+ var startModule = module.get.calendarModule(settings.startCalendar);
+ if (startModule) {
+ startModule.set.date(date);
+ }
+ module.set.dataKeyValue(metadata.startDate, date, refreshCalendar);
+ },
+ endDate: function (date, refreshCalendar) {
+ date = module.helper.sanitiseDate(date);
+ var endModule = module.get.calendarModule(settings.endCalendar);
+ if (endModule) {
+ endModule.set.date(date);
+ }
+ module.set.dataKeyValue(metadata.endDate, date, refreshCalendar);
+ },
+ focusDate: function (date, refreshCalendar, updateFocus, updateRange) {
+ date = module.helper.sanitiseDate(date);
+ date = module.helper.dateInRange(date);
+ var isDay = module.get.mode() === 'day';
+ var oldFocusDate = module.get.focusDate();
+ if (isDay && date && oldFocusDate) {
+ var yearDelta = date.getFullYear() - oldFocusDate.getFullYear();
+ var monthDelta = yearDelta * 12 + date.getMonth() - oldFocusDate.getMonth();
+ if (monthDelta) {
+ var monthOffset = module.get.monthOffset() - monthDelta;
+ module.set.monthOffset(monthOffset, false);
+ }
+ }
+ var changed = module.set.dataKeyValue(metadata.focusDate, date, !!date && refreshCalendar);
+ updateFocus = (updateFocus !== false && changed && refreshCalendar === false) || focusDateUsedForRange != updateRange;
+ focusDateUsedForRange = updateRange;
+ if (updateFocus) {
+ module.update.focus(updateRange);
+ }
+ },
+ minDate: function (date) {
+ date = module.helper.sanitiseDate(date);
+ if (settings.maxDate !== null && settings.maxDate <= date) {
+ module.verbose('Unable to set minDate variable bigger that maxDate variable', date, settings.maxDate);
+ } else {
+ module.setting('minDate', date);
+ module.set.dataKeyValue(metadata.minDate, date);
+ }
+ },
+ maxDate: function (date) {
+ date = module.helper.sanitiseDate(date);
+ if (settings.minDate !== null && settings.minDate >= date) {
+ module.verbose('Unable to set maxDate variable lower that minDate variable', date, settings.minDate);
+ } else {
+ module.setting('maxDate', date);
+ module.set.dataKeyValue(metadata.maxDate, date);
+ }
+ },
+ monthOffset: function (monthOffset, refreshCalendar) {
+ var multiMonth = Math.max(settings.multiMonth, 1);
+ monthOffset = Math.max(1 - multiMonth, Math.min(0, monthOffset));
+ module.set.dataKeyValue(metadata.monthOffset, monthOffset, refreshCalendar);
+ },
+ mode: function (mode, refreshCalendar) {
+ module.set.dataKeyValue(metadata.mode, mode, refreshCalendar);
+ },
+ dataKeyValue: function (key, value, refreshCalendar) {
+ var oldValue = $module.data(key);
+ var equal = oldValue === value || (oldValue <= value && oldValue >= value); // equality test for dates and string objects
+ if (value) {
+ $module.data(key, value);
+ } else {
+ $module.removeData(key);
+ }
+ refreshCalendar = refreshCalendar !== false && !equal;
+ if (refreshCalendar) {
+ module.refresh();
+ }
- observe: {
- class: function() {
- if($input.length && classObserver) {
- classObserver.observe($module[0], {
- attributes : true
- });
- }
- }
- },
+ return !equal;
+ },
+ },
+
+ selectDate: function (date, forceSet) {
+ module.verbose('New date selection', date);
+ var mode = module.get.mode();
+ var complete = forceSet || mode === 'minute'
+ || (settings.disableMinute && mode === 'hour')
+ || (settings.type === 'date' && mode === 'day')
+ || (settings.type === 'month' && mode === 'month')
+ || (settings.type === 'year' && mode === 'year');
+ if (complete) {
+ var canceled = module.set.date(date) === false;
+ if (!canceled) {
+ selectionComplete = true;
+ if (settings.closable) {
+ module.popup('hide');
+ // if this is a range calendar, focus the container or input. This will open the popup from its event listeners.
+ var endModule = module.get.calendarModule(settings.endCalendar);
+ if (endModule) {
+ endModule.refresh();
+ if (endModule.setting('on') !== 'focus') {
+ endModule.popup('show');
+ }
+ endModule.focus();
+ }
+ }
+ }
+ } else {
+ var newMode = mode === 'year'
+ ? (!settings.disableMonth ? 'month' : 'day')
+ : (mode === 'month'
+ ? 'day'
+ : (mode === 'day' ? 'hour' : 'minute')); // eslint-disable-line unicorn/no-nested-ternary
+ module.set.mode(newMode);
+ if (mode === 'hour' || (mode === 'day' && module.get.date())) {
+ // the user has chosen enough to consider a valid date/time has been chosen
+ module.set.date(date, true, false);
+ } else {
+ module.set.focusDate(date);
+ }
+ }
+ },
- is: {
- disabled: function() {
- return $module.hasClass(className.disabled);
- }
- },
+ changeDate: function (date) {
+ module.set.date(date);
+ },
- check: {
- disabled: function(){
- $input.attr('tabindex',module.is.disabled() ? -1 : 0);
- }
- },
+ clear: function () {
+ module.set.date();
+ },
- get: {
- weekOfYear: function(weekYear,weekMonth,weekDay) {
- // adapted from http://www.merlyn.demon.co.uk/weekcalc.htm
- var ms1d = 864e5, // milliseconds in a day
- ms7d = 7 * ms1d; // milliseconds in a week
-
- return function() { // return a closure so constants get calculated only once
- var DC3 = Date.UTC(weekYear, weekMonth, weekDay + 3) / ms1d, // an Absolute Day Number
- AWN = Math.floor(DC3 / 7), // an Absolute Week Number
- Wyr = new Date(AWN * ms7d).getUTCFullYear();
-
- return AWN - Math.floor(Date.UTC(Wyr, 0, 7) / ms7d) + 1;
- }();
- },
- formattedDate: function(format, date) {
- return module.helper.dateFormat(format || formatter[settings.type], date || module.get.date());
- },
- date: function () {
- return module.helper.sanitiseDate($module.data(metadata.date)) || null;
- },
- inputDate: function() {
- return $input.val();
- },
- focusDate: function () {
- return $module.data(metadata.focusDate) || null;
- },
- startDate: function () {
- var startModule = module.get.calendarModule(settings.startCalendar);
- return (startModule ? startModule.get.date() : $module.data(metadata.startDate)) || null;
- },
- endDate: function () {
- var endModule = module.get.calendarModule(settings.endCalendar);
- return (endModule ? endModule.get.date() : $module.data(metadata.endDate)) || null;
- },
- minDate: function() {
- return $module.data(metadata.minDate) || null;
- },
- maxDate: function() {
- return $module.data(metadata.maxDate) || null;
- },
- monthOffset: function () {
- return $module.data(metadata.monthOffset) || settings.monthOffset || 0;
- },
- mode: function () {
- //only returns valid modes for the current settings
- var mode = $module.data(metadata.mode) || settings.startMode;
- return module.get.validatedMode(mode);
- },
- validatedMode: function(mode){
- var validModes = module.get.validModes();
- if ($.inArray(mode, validModes) >= 0) {
- return mode;
- }
- return settings.type === 'time' ? 'hour' :
- settings.type === 'month' ? 'month' :
- settings.type === 'year' ? 'year' : 'day';
- },
- type: function() {
- return $module.data(metadata.type) || settings.type;
- },
- validModes: function () {
- var validModes = [];
- if (settings.type !== 'time') {
- if (!settings.disableYear || settings.type === 'year') {
- validModes.push('year');
- }
- if (!(settings.disableMonth || settings.type === 'year') || settings.type === 'month') {
- validModes.push('month');
- }
- if (settings.type.indexOf('date') >= 0) {
- validModes.push('day');
- }
- }
- if (settings.type.indexOf('time') >= 0) {
- validModes.push('hour');
- if (!settings.disableMinute) {
- validModes.push('minute');
- }
- }
- return validModes;
- },
- isTouch: function () {
- try {
- document.createEvent('TouchEvent');
- return true;
- }
- catch (e) {
- return false;
- }
- },
- calendarModule: function (selector) {
- if (!selector) {
- return null;
- }
- if (!(selector instanceof $)) {
- selector = $(document).find(selector).first();
- }
- //assume range related calendars are using the same namespace
- return selector.data(moduleNamespace);
- }
- },
+ popup: function () {
+ return $activator.popup.apply($activator, arguments);
+ },
- set: {
- date: function (date, updateInput, fireChange) {
- updateInput = updateInput !== false;
- fireChange = fireChange !== false;
- date = module.helper.sanitiseDate(date);
- date = module.helper.dateInRange(date);
+ focus: function () {
+ if ($input.length > 0) {
+ $input.trigger('focus');
+ } else {
+ $container.trigger('focus');
+ }
+ },
+ blur: function () {
+ if ($input.length > 0) {
+ $input.trigger('blur');
+ } else {
+ $container.trigger('blur');
+ }
+ },
- var mode = module.get.mode();
- var text = module.helper.dateFormat(formatter[settings.type],date);
+ helper: {
+ dateFormat: function (format, date) {
+ if (!(date instanceof Date)) {
+ return '';
+ }
+ if (typeof format === 'function') {
+ return format.call(module, date, settings);
+ }
- if (fireChange && settings.onBeforeChange.call(element, date, text, mode) === false) {
- return false;
- }
+ var
+ D = date.getDate(),
+ M = date.getMonth(),
+ Y = date.getFullYear(),
+ d = date.getDay(),
+ H = date.getHours(),
+ m = date.getMinutes(),
+ s = date.getSeconds(),
+ w = module.get.weekOfYear(Y, M, D + 1 - settings.firstDayOfWeek),
+ h = H % 12 || 12,
+ a = H < 12 ? settings.text.am.toLowerCase() : settings.text.pm.toLowerCase(),
+ tokens = {
+ D: D,
+ DD: ('0' + D).slice(-2),
+ M: M + 1,
+ MM: ('0' + (M + 1)).slice(-2),
+ MMM: settings.text.monthsShort[M],
+ MMMM: settings.text.months[M],
+ Y: Y,
+ YY: String(Y).slice(2),
+ YYYY: Y,
+ d: d,
+ dd: settings.text.dayNamesShort[d].slice(0, 2),
+ ddd: settings.text.dayNamesShort[d],
+ dddd: settings.text.dayNames[d],
+ h: h,
+ hh: ('0' + h).slice(-2),
+ H: H,
+ HH: ('0' + H).slice(-2),
+ m: m,
+ mm: ('0' + m).slice(-2),
+ s: s,
+ ss: ('0' + s).slice(-2),
+ a: a,
+ A: a.toUpperCase(),
+ S: ['th', 'st', 'nd', 'rd'][(D % 10) > 3 ? 0 : ((D % 100) - (D % 10) === 10 ? 0 : D % 10)],
+ w: w,
+ ww: ('0' + w).slice(-2),
+ }
+ ;
+
+ return format.replace(settings.regExp.token, function (match) {
+ if (match in tokens) {
+ return tokens[match];
+ }
+
+ return match.slice(1, -1);
+ });
+ },
+ isDisabled: function (date, mode) {
+ return (mode === 'day' || mode === 'month' || mode === 'year' || mode === 'hour') && (((mode === 'day' && settings.disabledDaysOfWeek.indexOf(date.getDay()) !== -1) || settings.disabledDates.some(function (d) {
+ var blocked = false;
+
+ if (typeof d === 'string') {
+ d = module.helper.sanitiseDate(d);
+ }
+ if (d instanceof Date) {
+ blocked = module.helper.dateEqual(date, d, mode);
+ } else if (d !== null && typeof d === 'object') {
+ if (d[metadata.year]) {
+ if (typeof d[metadata.year] === 'number') {
+ blocked = date.getFullYear() === d[metadata.year];
+ } else if (Array.isArray(d[metadata.year])) {
+ blocked = d[metadata.year].indexOf(date.getFullYear()) > -1;
+ }
+ } else if (d[metadata.month]) {
+ if (typeof d[metadata.month] === 'number') {
+ blocked = date.getMonth() === d[metadata.month];
+ } else if (Array.isArray(d[metadata.month])) {
+ blocked = d[metadata.month].indexOf(date.getMonth()) > -1;
+ } else if (d[metadata.month] instanceof Date) {
+ var sdate = module.helper.sanitiseDate(d[metadata.month]);
+
+ blocked = (date.getMonth() === sdate.getMonth()) && (date.getFullYear() === sdate.getFullYear());
+ }
+ } else if (d[metadata.date] && mode === 'day') {
+ if (d[metadata.date] instanceof Date) {
+ blocked = module.helper.dateEqual(date, module.helper.sanitiseDate(d[metadata.date]), mode);
+ } else if (Array.isArray(d[metadata.date])) {
+ blocked = d[metadata.date].some(function (idate) {
+ return module.helper.dateEqual(date, idate, mode);
+ });
+ }
+ }
+ }
+
+ return blocked;
+ })) || (mode === 'hour' && settings.disabledHours.some(function (d) {
+ var blocked = false;
+
+ if (typeof d === 'string') {
+ d = module.helper.sanitiseDate(d);
+ }
+ if (d instanceof Date) {
+ blocked = module.helper.dateEqual(date, d, mode);
+ } else if (typeof d === 'number') {
+ blocked = date.getHours() === d;
+ } else if (d !== null && typeof d === 'object') {
+ if (d[metadata.date]) {
+ if (d[metadata.date] instanceof Date) {
+ blocked = module.helper.dateEqual(date, module.helper.sanitiseDate(d[metadata.date]));
+ } else if (Array.isArray(d[metadata.date])) {
+ blocked = d[metadata.date].some(function (idate) {
+ return module.helper.dateEqual(date, idate, mode);
+ });
+ }
+ }
+
+ if (d[metadata.days]) {
+ if (typeof d[metadata.days] === 'number') {
+ blocked = date.getDay() === d[metadata.days];
+ } else if (Array.isArray(d[metadata.days])) {
+ blocked = d[metadata.days].indexOf(date.getDay()) > -1;
+ }
+ }
+
+ if (d[metadata.hours]) {
+ if (typeof d[metadata.hours] === 'number') {
+ blocked = blocked && date.getHours() === d[metadata.hours];
+ } else if (Array.isArray(d[metadata.hours])) {
+ blocked = blocked && d[metadata.hours].indexOf(date.getHours()) > -1;
+ }
+ }
+ }
+
+ return blocked;
+ })));
+ },
+ isEnabled: function (date, mode) {
+ if (mode === 'day') {
+ return settings.enabledDates.length === 0 || settings.enabledDates.some(function (d) {
+ var enabled = false;
+
+ if (typeof d === 'string') {
+ d = module.helper.sanitiseDate(d);
+ }
+ if (d instanceof Date) {
+ enabled = module.helper.dateEqual(date, d, mode);
+ } else if (d !== null && typeof d === 'object' && d[metadata.date]) {
+ enabled = module.helper.dateEqual(date, module.helper.sanitiseDate(d[metadata.date]), mode);
+ }
+
+ return enabled;
+ });
+ }
- module.set.focusDate(date);
+ return true;
+ },
+ findDayAsObject: function (date, mode, dates) {
+ if (mode === 'day' || mode === 'month' || mode === 'year') {
+ var d;
+ for (var i = 0; i < dates.length; i++) {
+ d = dates[i];
+ if (typeof d === 'string') {
+ d = module.helper.sanitiseDate(d);
+ }
+ if (d instanceof Date && module.helper.dateEqual(date, d, mode)) {
+ var dateObject = {};
+ dateObject[metadata.date] = d;
+
+ return dateObject;
+ }
+ if (d !== null && typeof d === 'object') {
+ if (d[metadata.year]) {
+ if (typeof d[metadata.year] === 'number' && date.getFullYear() === d[metadata.year]) {
+ return d;
+ }
+ if (Array.isArray(d[metadata.year])) {
+ if (d[metadata.year].indexOf(date.getFullYear()) > -1) {
+ return d;
+ }
+ }
+ } else if (d[metadata.month]) {
+ if (typeof d[metadata.month] === 'number' && date.getMonth() === d[metadata.month]) {
+ return d;
+ }
+ if (Array.isArray(d[metadata.month])) {
+ if (d[metadata.month].indexOf(date.getMonth()) > -1) {
+ return d;
+ }
+ } else if (d[metadata.month] instanceof Date) {
+ var sdate = module.helper.sanitiseDate(d[metadata.month]);
+ if ((date.getMonth() === sdate.getMonth()) && (date.getFullYear() === sdate.getFullYear())) {
+ return d;
+ }
+ }
+ } else if (d[metadata.date] && mode === 'day') {
+ if (d[metadata.date] instanceof Date && module.helper.dateEqual(date, module.helper.sanitiseDate(d[metadata.date]), mode)) {
+ return d;
+ }
+ if (Array.isArray(d[metadata.date])) {
+ if (d[metadata.date].some(function (idate) {
+ return module.helper.dateEqual(date, idate, mode);
+ })) {
+ return d;
+ }
+ }
+ }
+ }
+ }
+ }
- if (settings.isDisabled(date, mode)) {
- return false;
- }
+ return null;
+ },
+ findHourAsObject: function (date, mode, hours) {
+ if (mode === 'hour') {
+ var d;
+ var hourCheck = function (date, d) {
+ if (d[metadata.hours]) {
+ if (typeof d[metadata.hours] === 'number' && date.getHours() === d[metadata.hours]) {
+ return d;
+ }
+ if (Array.isArray(d[metadata.hours])) {
+ if (d[metadata.hours].indexOf(date.getHours()) > -1) {
+ return d;
+ }
+ }
+ }
+ };
+ for (var i = 0; i < hours.length; i++) {
+ d = hours[i];
+ if (typeof d === 'number' && date.getHours() === d) {
+ return null;
+ }
+ if (d !== null && typeof d === 'object') {
+ if (d[metadata.days] && hourCheck(date, d)) {
+ if (typeof d[metadata.days] === 'number' && date.getDay() === d[metadata.days]) {
+ return d;
+ }
+ if (Array.isArray(d[metadata.days])) {
+ if (d[metadata.days].indexOf(date.getDay()) > -1) {
+ return d;
+ }
+ }
+ } else if (d[metadata.date] && hourCheck(date, d)) {
+ if (d[metadata.date] instanceof Date && module.helper.dateEqual(date, module.helper.sanitiseDate(d[metadata.date]))) {
+ return d;
+ }
+ if (Array.isArray(d[metadata.date])) {
+ if (d[metadata.date].some(function (idate) {
+ return module.helper.dateEqual(date, idate, mode);
+ })) {
+ return d;
+ }
+ }
+ } else if (hourCheck(date, d)) {
+ return d;
+ }
+ }
+ }
+ }
- var endDate = module.get.endDate();
- if (!!endDate && !!date && date > endDate) {
- //selected date is greater than end date in range, so clear end date
- module.set.endDate(undefined);
- }
- module.set.dataKeyValue(metadata.date, date);
+ return null;
+ },
+ sanitiseDate: function (date) {
+ if (!(date instanceof Date)) {
+ date = parser.date('' + date, settings);
+ }
+ if (!date || isNaN(date.getTime())) {
+ return null;
+ }
- if (updateInput && $input.length) {
- $input.val(text);
- }
+ return date;
+ },
+ dateDiff: function (date1, date2, mode) {
+ if (!mode) {
+ mode = 'day';
+ }
- if (fireChange) {
- settings.onChange.call(element, date, text, mode);
- }
- },
- startDate: function (date, refreshCalendar) {
- date = module.helper.sanitiseDate(date);
- var startModule = module.get.calendarModule(settings.startCalendar);
- if (startModule) {
- startModule.set.date(date);
- }
- module.set.dataKeyValue(metadata.startDate, date, refreshCalendar);
- },
- endDate: function (date, refreshCalendar) {
- date = module.helper.sanitiseDate(date);
- var endModule = module.get.calendarModule(settings.endCalendar);
- if (endModule) {
- endModule.set.date(date);
- }
- module.set.dataKeyValue(metadata.endDate, date, refreshCalendar);
- },
- focusDate: function (date, refreshCalendar, updateFocus, updateRange) {
- date = module.helper.sanitiseDate(date);
- date = module.helper.dateInRange(date);
- var isDay = module.get.mode() === 'day';
- var oldFocusDate = module.get.focusDate();
- if (isDay && date && oldFocusDate) {
- var yearDelta = date.getFullYear() - oldFocusDate.getFullYear();
- var monthDelta = yearDelta * 12 + date.getMonth() - oldFocusDate.getMonth();
- if (monthDelta) {
- var monthOffset = module.get.monthOffset() - monthDelta;
- module.set.monthOffset(monthOffset, false);
- }
- }
- var changed = module.set.dataKeyValue(metadata.focusDate, date, !!date && refreshCalendar);
- updateFocus = (updateFocus !== false && changed && refreshCalendar === false) || focusDateUsedForRange != updateRange;
- focusDateUsedForRange = updateRange;
- if (updateFocus) {
- module.update.focus(updateRange);
- }
- },
- minDate: function (date) {
- date = module.helper.sanitiseDate(date);
- if (settings.maxDate !== null && settings.maxDate <= date) {
- module.verbose('Unable to set minDate variable bigger that maxDate variable', date, settings.maxDate);
- } else {
- module.setting('minDate', date);
- module.set.dataKeyValue(metadata.minDate, date);
- }
- },
- maxDate: function (date) {
- date = module.helper.sanitiseDate(date);
- if (settings.minDate !== null && settings.minDate >= date) {
- module.verbose('Unable to set maxDate variable lower that minDate variable', date, settings.minDate);
- } else {
- module.setting('maxDate', date);
- module.set.dataKeyValue(metadata.maxDate, date);
- }
- },
- monthOffset: function (monthOffset, refreshCalendar) {
- var multiMonth = Math.max(settings.multiMonth, 1);
- monthOffset = Math.max(1 - multiMonth, Math.min(0, monthOffset));
- module.set.dataKeyValue(metadata.monthOffset, monthOffset, refreshCalendar);
- },
- mode: function (mode, refreshCalendar) {
- module.set.dataKeyValue(metadata.mode, mode, refreshCalendar);
- },
- dataKeyValue: function (key, value, refreshCalendar) {
- var oldValue = $module.data(key);
- var equal = oldValue === value || (oldValue <= value && oldValue >= value); //equality test for dates and string objects
- if (value) {
- $module.data(key, value);
- } else {
- $module.removeData(key);
- }
- refreshCalendar = refreshCalendar !== false && !equal;
- if (refreshCalendar) {
- module.refresh();
- }
- return !equal;
- }
- },
+ var isTimeOnly = settings.type === 'time';
+ var isYear = mode === 'year';
+ var isYearOrMonth = isYear || mode === 'month';
+ var isMinute = mode === 'minute';
+ var isHourOrMinute = isMinute || mode === 'hour';
+ // only care about a minute accuracy of settings.minTimeGap
+ date1 = new Date(
+ isTimeOnly ? 2000 : date1.getFullYear(),
+ isTimeOnly ? 0 : (isYear ? 0 : date1.getMonth()),
+ isTimeOnly ? 1 : (isYearOrMonth ? 1 : date1.getDate()),
+ !isHourOrMinute ? 0 : date1.getHours(),
+ !isMinute ? 0 : settings.minTimeGap * Math.floor(date1.getMinutes() / settings.minTimeGap)
+ );
+ date2 = new Date(
+ isTimeOnly ? 2000 : date2.getFullYear(),
+ isTimeOnly ? 0 : (isYear ? 0 : date2.getMonth()),
+ isTimeOnly ? 1 : (isYearOrMonth ? 1 : date2.getDate()),
+ !isHourOrMinute ? 0 : date2.getHours(),
+ !isMinute ? 0 : settings.minTimeGap * Math.floor(date2.getMinutes() / settings.minTimeGap)
+ );
+
+ return date2.getTime() - date1.getTime();
+ },
+ dateEqual: function (date1, date2, mode) {
+ return !!date1 && !!date2 && module.helper.dateDiff(date1, date2, mode) === 0;
+ },
+ isDateInRange: function (date, mode, minDate, maxDate) {
+ if (!minDate && !maxDate) {
+ var startDate = module.get.startDate();
+ minDate = startDate && settings.minDate ? new Date(Math.max(startDate, settings.minDate)) : startDate || settings.minDate;
+ maxDate = settings.maxDate;
+ }
+ minDate = minDate && new Date(minDate.getFullYear(), minDate.getMonth(), minDate.getDate(), minDate.getHours(), settings.minTimeGap * Math.ceil(minDate.getMinutes() / settings.minTimeGap));
+
+ return !(!date
+ || (minDate && module.helper.dateDiff(date, minDate, mode) > 0)
+ || (maxDate && module.helper.dateDiff(maxDate, date, mode) > 0));
+ },
+ dateInRange: function (date, minDate, maxDate) {
+ if (!minDate && !maxDate) {
+ var startDate = module.get.startDate();
+ minDate = startDate && settings.minDate ? new Date(Math.max(startDate, settings.minDate)) : startDate || settings.minDate;
+ maxDate = settings.maxDate;
+ }
+ minDate = minDate && new Date(minDate.getFullYear(), minDate.getMonth(), minDate.getDate(), minDate.getHours(), settings.minTimeGap * Math.ceil(minDate.getMinutes() / settings.minTimeGap));
+ var isTimeOnly = settings.type === 'time';
+
+ return !date
+ ? date
+ : (minDate && module.helper.dateDiff(date, minDate, 'minute') > 0
+ ? (isTimeOnly ? module.helper.mergeDateTime(date, minDate) : minDate) // eslint-disable-line unicorn/no-nested-ternary
+ : (maxDate && module.helper.dateDiff(maxDate, date, 'minute') > 0 // eslint-disable-line unicorn/no-nested-ternary
+ ? (isTimeOnly ? module.helper.mergeDateTime(date, maxDate) : maxDate)
+ : date));
+ },
+ mergeDateTime: function (date, time) {
+ return !date || !time
+ ? time
+ : new Date(date.getFullYear(), date.getMonth(), date.getDate(), time.getHours(), time.getMinutes());
+ },
+ isTodayButton: function (element) {
+ return element.text() === settings.text.today;
+ },
+ },
+
+ setting: function (name, value) {
+ module.debug('Changing setting', name, value);
+ if ($.isPlainObject(name)) {
+ $.extend(true, settings, name);
+ } else if (value !== undefined) {
+ if ($.isPlainObject(settings[name])) {
+ $.extend(true, settings[name], value);
+ } else {
+ settings[name] = value;
+ }
+ } else {
+ return settings[name];
+ }
+ },
+ internal: function (name, value) {
+ if ($.isPlainObject(name)) {
+ $.extend(true, module, name);
+ } else if (value !== undefined) {
+ module[name] = value;
+ } else {
+ return module[name];
+ }
+ },
+ debug: function () {
+ if (!settings.silent && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.debug.apply(console, arguments);
+ }
+ }
+ },
+ verbose: function () {
+ if (!settings.silent && settings.verbose && settings.debug) {
+ if (settings.performance) {
+ module.performance.log(arguments);
+ } else {
+ module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
+ module.verbose.apply(console, arguments);
+ }
+ }
+ },
+ error: function () {
+ if (!settings.silent) {
+ module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
+ module.error.apply(console, arguments);
+ }
+ },
+ performance: {
+ log: function (message) {
+ var
+ currentTime,
+ executionTime,
+ previousTime
+ ;
+ if (settings.performance) {
+ currentTime = Date.now();
+ previousTime = time || currentTime;
+ executionTime = currentTime - previousTime;
+ time = currentTime;
+ performance.push({
+ Name: message[0],
+ Arguments: [].slice.call(message, 1) || '',
+ Element: element,
+ 'Execution Time': executionTime,
+ });
+ }
+ clearTimeout(module.performance.timer);
+ module.performance.timer = setTimeout(module.performance.display, 500);
+ },
+ display: function () {
+ var
+ title = settings.name + ':',
+ totalTime = 0
+ ;
+ time = false;
+ clearTimeout(module.performance.timer);
+ $.each(performance, function (index, data) {
+ totalTime += data['Execution Time'];
+ });
+ title += ' ' + totalTime + 'ms';
+ if (moduleSelector) {
+ title += ' \'' + moduleSelector + '\'';
+ }
+ if (performance.length > 0) {
+ console.groupCollapsed(title);
+ if (console.table) {
+ console.table(performance);
+ } else {
+ $.each(performance, function (index, data) {
+ console.log(data.Name + ': ' + data['Execution Time'] + 'ms');
+ });
+ }
+ console.groupEnd();
+ }
+ performance = [];
+ },
+ },
+ invoke: function (query, passedArguments, context) {
+ var
+ object = instance,
+ maxDepth,
+ found,
+ response
+ ;
+ passedArguments = passedArguments || queryArguments;
+ context = context || element;
+ if (typeof query === 'string' && object !== undefined) {
+ query = query.split(/[ .]/);
+ maxDepth = query.length - 1;
+ $.each(query, function (depth, value) {
+ var camelCaseValue = depth !== maxDepth
+ ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
+ : query
+ ;
+ if ($.isPlainObject(object[camelCaseValue]) && (depth !== maxDepth)) {
+ object = object[camelCaseValue];
+ } else if (object[camelCaseValue] !== undefined) {
+ found = object[camelCaseValue];
+
+ return false;
+ } else if ($.isPlainObject(object[value]) && (depth !== maxDepth)) {
+ object = object[value];
+ } else if (object[value] !== undefined) {
+ found = object[value];
+
+ return false;
+ } else {
+ module.error(error.method, query);
+
+ return false;
+ }
+ });
+ }
+ if (isFunction(found)) {
+ response = found.apply(context, passedArguments);
+ } else if (found !== undefined) {
+ response = found;
+ }
+ if (Array.isArray(returnedValue)) {
+ returnedValue.push(response);
+ } else if (returnedValue !== undefined) {
+ returnedValue = [returnedValue, response];
+ } else if (response !== undefined) {
+ returnedValue = response;
+ }
- selectDate: function (date, forceSet) {
- module.verbose('New date selection', date);
- var mode = module.get.mode();
- var complete = forceSet || mode === 'minute' ||
- (settings.disableMinute && mode === 'hour') ||
- (settings.type === 'date' && mode === 'day') ||
- (settings.type === 'month' && mode === 'month') ||
- (settings.type === 'year' && mode === 'year');
- if (complete) {
- var canceled = module.set.date(date) === false;
- if (!canceled) {
- selectionComplete = true;
- if(settings.closable) {
- module.popup('hide');
- //if this is a range calendar, focus the container or input. This will open the popup from its event listeners.
- var endModule = module.get.calendarModule(settings.endCalendar);
- if (endModule) {
- endModule.refresh();
- if (endModule.setting('on') !== 'focus') {
- endModule.popup('show');
- }
- endModule.focus();
+ return found;
+ },
+ };
+
+ if (methodInvoked) {
+ if (instance === undefined) {
+ module.initialize();
}
- }
- }
- } else {
- var newMode = mode === 'year' ? (!settings.disableMonth ? 'month' : 'day') :
- mode === 'month' ? 'day' : mode === 'day' ? 'hour' : 'minute';
- module.set.mode(newMode);
- if (mode === 'hour' || (mode === 'day' && module.get.date())) {
- //the user has chosen enough to consider a valid date/time has been chosen
- module.set.date(date, true, false);
+ module.invoke(query);
} else {
- module.set.focusDate(date);
- }
- }
+ if (instance !== undefined) {
+ instance.invoke('destroy');
+ }
+ module.initialize();
+ }
+ });
+
+ return returnedValue !== undefined
+ ? returnedValue
+ : this;
+ };
+
+ $.fn.calendar.settings = {
+
+ name: 'Calendar',
+ namespace: 'calendar',
+
+ silent: false,
+ debug: false,
+ verbose: false,
+ performance: true,
+
+ context: false,
+
+ type: 'datetime', // picker type, can be 'datetime', 'date', 'time', 'month', or 'year'
+ firstDayOfWeek: 0, // day for first day column (0 = Sunday)
+ constantHeight: true, // add rows to shorter months to keep day calendar height consistent (6 rows)
+ today: false, // show a 'today/now' button at the bottom of the calendar
+ closable: true, // close the popup after selecting a date/time
+ monthFirst: true, // month before day when parsing date from text
+ touchReadonly: true, // set input to readonly on touch devices
+ inline: false, // create the calendar inline instead of inside a popup
+ on: null, // when to show the popup (defaults to 'focus' for input, 'click' for others)
+ initialDate: null, // date to display initially when no date is selected (null = now)
+ startMode: false, // display mode to start in, can be 'year', 'month', 'day', 'hour', 'minute' (false = 'day')
+ minDate: null, // minimum date/time that can be selected, dates/times before are disabled
+ maxDate: null, // maximum date/time that can be selected, dates/times after are disabled
+ disableYear: false, // disable year selection mode
+ disableMonth: false, // disable month selection mode
+ disableMinute: false, // disable minute selection mode
+ formatInput: true, // format the input text upon input blur and module creation
+ startCalendar: null, // jquery object or selector for another calendar that represents the start date of a date range
+ endCalendar: null, // jquery object or selector for another calendar that represents the end date of a date range
+ multiMonth: 1, // show multiple months when in 'day' mode
+ monthOffset: 0, // position current month by offset when multimonth > 1
+ minTimeGap: 5,
+ showWeekNumbers: false, // show Number of Week at the very first column of a dayView
+ disabledHours: [], // specific hour(s) which won't be selectable and contain additional information.
+ disabledDates: [], // specific day(s) which won't be selectable and contain additional information.
+ disabledDaysOfWeek: [], // day(s) which won't be selectable(s) (0 = Sunday)
+ enabledDates: [], // specific day(s) which will be selectable, all other days will be disabled
+ eventDates: [], // specific day(s) which will be shown in a different color and using tooltips
+ centuryBreak: 60, // starting short year until 99 where it will be assumed to belong to the last century
+ currentCentury: 2000, // century to be added to 2-digit years (00 to {centuryBreak}-1)
+ selectAdjacentDays: false, // The calendar can show dates from adjacent month. These adjacent month dates can also be made selectable.
+ // popup options ('popup', 'on', 'hoverable', and show/hide callbacks are overridden)
+ popupOptions: {
+ position: 'bottom left',
+ lastResort: 'bottom left',
+ prefer: 'opposite',
+ observeChanges: false,
+ hideOnScroll: false,
},
- changeDate: function (date) {
- module.set.date(date);
+ text: {
+ days: ['S', 'M', 'T', 'W', 'T', 'F', 'S'],
+ dayNamesShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],
+ dayNames: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],
+ months: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
+ monthsShort: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],
+ today: 'Today',
+ now: 'Now',
+ am: 'AM',
+ pm: 'PM',
+ weekNo: 'Week',
},
- clear: function () {
- module.set.date(undefined);
+ formatter: {
+ yearHeader: function (date, settings) {
+ var decadeYear = Math.ceil(date.getFullYear() / 10) * 10;
+
+ return (decadeYear - 9) + ' - ' + (decadeYear + 2);
+ },
+ monthHeader: 'YYYY',
+ dayHeader: 'MMMM YYYY',
+ hourHeader: 'MMMM D, YYYY',
+ minuteHeader: 'MMMM D, YYYY',
+ dayColumnHeader: function (day, settings) {
+ return settings.text.days[day];
+ },
+ datetime: 'MMMM D, YYYY h:mm A',
+ date: 'MMMM D, YYYY',
+ time: 'h:mm A',
+ cellTime: 'h:mm A',
+ month: 'MMMM YYYY',
+ year: 'YYYY',
+ today: function (settings) {
+ return settings.type === 'date' ? settings.text.today : settings.text.now;
+ },
+ cell: function (cell, date, cellOptions) {},
},
- popup: function () {
- return $activator.popup.apply($activator, arguments);
- },
+ parser: {
+ date: function (text, settings) {
+ if (text instanceof Date) {
+ return text;
+ }
+ if (!text) {
+ return null;
+ }
+ text = String(text).trim().replace(/([./:-])\s+/g, '$1').replace(/\s+([./:-])/g, '$1')
+ .replace(/\s+/g, ' ');
+ if (text.length === 0) {
+ return null;
+ }
+ if (/^\d{4}(?:[./-]\d{1,2}){2}$/.test(text)) {
+ text = text.replace(/[./-]/g, '/') + ' 00:00:00';
+ }
+ // Reverse date and month in some cases
+ text = settings.monthFirst || !/^\d{1,2}[./-]/.test(text) ? text : text.replace(/[./-]/g, '/').replace(/(\d+)\/(\d+)/, '$2/$1');
+ var textDate = new Date(text);
+ var numberOnly = text.match(/^\d+$/) !== null;
+ if (!numberOnly && !isNaN(textDate.getDate())) {
+ return textDate;
+ }
+ text = text.toLowerCase();
- focus: function () {
- if ($input.length) {
- $input.focus();
- } else {
- $container.focus();
- }
- },
- blur: function () {
- if ($input.length) {
- $input.blur();
- } else {
- $container.blur();
- }
- },
+ var
+ i,
+ j,
+ k
+ ;
+ var
+ minute = -1,
+ hour = -1,
+ day = -1,
+ month = -1,
+ year = -1
+ ;
+ var isAm;
- helper: {
- dateFormat: function(format,date) {
- if (!(date instanceof Date)) {
- return '';
- }
- if(typeof format === 'function') {
- return format.call(module, date, settings);
- }
+ var isTimeOnly = settings.type === 'time';
+ var isDateOnly = settings.type.indexOf('time') < 0;
- var D = date.getDate(),
- M = date.getMonth(),
- Y = date.getFullYear(),
- d = date.getDay(),
- H = date.getHours(),
- m = date.getMinutes(),
- s = date.getSeconds(),
- w = module.get.weekOfYear(Y,M,D+1-settings.firstDayOfWeek),
- h = H % 12 || 12,
- a = H < 12 ? settings.text.am.toLowerCase() : settings.text.pm.toLowerCase(),
- tokens = {
- D: D,
- DD: ('0'+D).slice(-2),
- M: M + 1,
- MM: ('0'+(M+1)).slice(-2),
- MMM: settings.text.monthsShort[M],
- MMMM: settings.text.months[M],
- Y: Y,
- YY: String(Y).slice(2),
- YYYY: Y,
- d: d,
- dd: settings.text.dayNamesShort[d].slice(0,2),
- ddd: settings.text.dayNamesShort[d],
- dddd: settings.text.dayNames[d],
- h: h,
- hh: ('0'+h).slice(-2),
- H: H,
- HH: ('0'+H).slice(-2),
- m: m,
- mm: ('0'+m).slice(-2),
- s: s,
- ss: ('0'+s).slice(-2),
- a: a,
- A: a.toUpperCase(),
- S: ['th', 'st', 'nd', 'rd'][D % 10 > 3 ? 0 : (D % 100 - D % 10 !== 10) * D % 10],
- w: w,
- ww: ('0'+w).slice(-2)
- }
- ;
- return format.replace(settings.regExp.token, function (match) {
- if (match in tokens) {
- return tokens[match];
- }
- return match.slice(1, match.length - 1);
- });
- },
- isDisabled: function(date, mode) {
- return (mode === 'day' || mode === 'month' || mode === 'year' || mode === 'hour') && (((mode === 'day' && settings.disabledDaysOfWeek.indexOf(date.getDay()) !== -1) || settings.disabledDates.some(function(d){
- if(typeof d === 'string') {
- d = module.helper.sanitiseDate(d);
- }
- if (d instanceof Date) {
- return module.helper.dateEqual(date, d, mode);
- }
- if (d !== null && typeof d === 'object') {
- if (d[metadata.year]) {
- if (typeof d[metadata.year] === 'number') {
- return date.getFullYear() == d[metadata.year];
- } else if (Array.isArray(d[metadata.year])) {
- return d[metadata.year].indexOf(date.getFullYear()) > -1;
- }
- } else if (d[metadata.month]) {
- if (typeof d[metadata.month] === 'number') {
- return date.getMonth() == d[metadata.month];
- } else if (Array.isArray(d[metadata.month])) {
- return d[metadata.month].indexOf(date.getMonth()) > -1;
- } else if (d[metadata.month] instanceof Date) {
- var sdate = module.helper.sanitiseDate(d[metadata.month]);
- return (date.getMonth() == sdate.getMonth()) && (date.getFullYear() == sdate.getFullYear())
- }
- } else if (d[metadata.date] && mode === 'day') {
- if (d[metadata.date] instanceof Date) {
- return module.helper.dateEqual(date, module.helper.sanitiseDate(d[metadata.date]), mode);
- } else if (Array.isArray(d[metadata.date])) {
- return d[metadata.date].some(function(idate) {
- return module.helper.dateEqual(date, idate, mode);
- });
- }
- }
- }
- })) || (mode === 'hour' && settings.disabledHours.some(function(d){
- if (typeof d === 'string') {
- d = module.helper.sanitiseDate(d);
- }
- if (d instanceof Date) {
- return module.helper.dateEqual(date, d, mode);
- } else if (typeof d === 'number') {
- return date.getHours() === d;
- }
- if (d !== null && typeof d === 'object') {
- var blocked = true;
-
- if (d[metadata.date]) {
- if (d[metadata.date] instanceof Date) {
- blocked = module.helper.dateEqual(date, module.helper.sanitiseDate(d[metadata.date]));
- } else if (Array.isArray(d[metadata.date])) {
- return d[metadata.date].some(function(idate) {
- blocked = module.helper.dateEqual(date, idate, mode);
- });
- }
+ var
+ words = text.split(settings.regExp.dateWords),
+ word
+ ;
+ var
+ numbers = text.split(settings.regExp.dateNumbers),
+ number
+ ;
+
+ var parts;
+ var monthString;
+
+ if (!isDateOnly) {
+ // am/pm
+ isAm = $.inArray(settings.text.am.toLowerCase(), words) >= 0
+ ? true
+ : ($.inArray(settings.text.pm.toLowerCase(), words) >= 0 ? false : undefined);
+
+ // time with ':'
+ for (i = 0; i < numbers.length; i++) {
+ number = numbers[i];
+ if (number.indexOf(':') >= 0) {
+ if (hour < 0 || minute < 0) {
+ parts = number.split(':');
+ for (k = 0; k < Math.min(2, parts.length); k++) {
+ j = parseInt(parts[k], 10);
+ if (isNaN(j)) {
+ j = 0;
+ }
+ if (k === 0) {
+ hour = j % 24;
+ } else {
+ minute = j % 60;
+ }
+ }
+ }
+ numbers.splice(i, 1);
+ }
+ }
}
- if (d[metadata.days]) {
- if (typeof d[metadata.days] === 'number') {
- blocked = date.getDay() == d[metadata.days];
- } else if (Array.isArray(d[metadata.days])) {
- blocked = d[metadata.days].indexOf(date.getDay()) > -1;
- }
+ if (!isTimeOnly) {
+ // textual month
+ for (i = 0; i < words.length; i++) {
+ word = words[i];
+ if (word.length <= 0) {
+ continue;
+ }
+ for (j = 0; j < settings.text.months.length; j++) {
+ monthString = settings.text.months[j];
+ monthString = monthString.slice(0, word.length).toLowerCase();
+ if (monthString === word) {
+ month = j + 1;
+
+ break;
+ }
+ }
+ if (month >= 0) {
+ break;
+ }
+ }
+
+ // year > settings.centuryBreak
+ for (i = 0; i < numbers.length; i++) {
+ j = parseInt(numbers[i], 10);
+ if (isNaN(j)) {
+ continue;
+ }
+ if (j >= settings.centuryBreak && i === numbers.length - 1) {
+ if (j <= 99) {
+ j += settings.currentCentury - 100;
+ }
+ year = j;
+ numbers.splice(i, 1);
+
+ break;
+ }
+ }
+
+ // numeric month
+ if (month < 0) {
+ for (i = 0; i < numbers.length; i++) {
+ k = i > 1 || settings.monthFirst
+ ? i
+ : (i === 1 ? 0 : 1);
+ j = parseInt(numbers[k], 10);
+ if (isNaN(j)) {
+ continue;
+ }
+ if (j >= 1 && j <= 12) {
+ month = j;
+ numbers.splice(k, 1);
+
+ break;
+ }
+ }
+ }
+
+ // day
+ for (i = 0; i < numbers.length; i++) {
+ j = parseInt(numbers[i], 10);
+ if (isNaN(j)) {
+ continue;
+ }
+ if (j >= 1 && j <= 31) {
+ day = j;
+ numbers.splice(i, 1);
+
+ break;
+ }
+ }
+
+ // year <= settings.centuryBreak
+ if (year < 0) {
+ for (i = numbers.length - 1; i >= 0; i--) {
+ j = parseInt(numbers[i], 10);
+ if (isNaN(j)) {
+ continue;
+ }
+ if (j <= 99) {
+ j += settings.currentCentury;
+ }
+ year = j;
+ numbers.splice(i, 1);
+
+ break;
+ }
+ }
}
- if (d[metadata.hours]) {
- if (typeof d[metadata.hours] === 'number') {
- return blocked && date.getHours() == d[metadata.hours];
- } else if (Array.isArray(d[metadata.hours])) {
- return blocked && d[metadata.hours].indexOf(date.getHours()) > -1;
- }
+ if (!isDateOnly) {
+ // hour
+ if (hour < 0) {
+ for (i = 0; i < numbers.length; i++) {
+ j = parseInt(numbers[i], 10);
+ if (isNaN(j)) {
+ continue;
+ }
+ if (j >= 0 && j <= 23) {
+ hour = j;
+ numbers.splice(i, 1);
+
+ break;
+ }
+ }
+ }
+
+ // minute
+ if (minute < 0) {
+ for (i = 0; i < numbers.length; i++) {
+ j = parseInt(numbers[i], 10);
+ if (isNaN(j)) {
+ continue;
+ }
+ if (j >= 0 && j <= 59) {
+ minute = j;
+ numbers.splice(i, 1);
+
+ break;
+ }
+ }
+ }
}
- }
- })));
- },
- isEnabled: function(date, mode) {
- if (mode === 'day') {
- return settings.enabledDates.length === 0 || settings.enabledDates.some(function(d){
- if(typeof d === 'string') {
- d = module.helper.sanitiseDate(d);
+
+ if (minute < 0 && hour < 0 && day < 0 && month < 0 && year < 0) {
+ return null;
}
- if (d instanceof Date) {
- return module.helper.dateEqual(date, d, mode);
+
+ if (minute < 0) {
+ minute = 0;
}
- if (d !== null && typeof d === 'object' && d[metadata.date]) {
- return module.helper.dateEqual(date, module.helper.sanitiseDate(d[metadata.date]), mode);
+ if (hour < 0) {
+ hour = 0;
}
- });
- } else {
- return true;
- }
- },
- findDayAsObject: function(date, mode, dates) {
- if (mode === 'day' || mode === 'month' || mode === 'year') {
- var d;
- for (var i = 0; i < dates.length; i++) {
- d = dates[i];
- if(typeof d === 'string') {
- d = module.helper.sanitiseDate(d);
+ if (day < 0) {
+ day = 1;
}
- if (d instanceof Date && module.helper.dateEqual(date, d, mode)) {
- var dateObject = {};
- dateObject[metadata.date] = d;
- return dateObject;
+ if (month < 0) {
+ month = 1;
}
- else if (d !== null && typeof d === 'object') {
- if (d[metadata.year]) {
- if (typeof d[metadata.year] === 'number' && date.getFullYear() == d[metadata.year]) {
- return d;
- } else if (Array.isArray(d[metadata.year])) {
- if (d[metadata.year].indexOf(date.getFullYear()) > -1) {
- return d;
- }
- }
- } else if (d[metadata.month]) {
- if (typeof d[metadata.month] === 'number' && date.getMonth() == d[metadata.month]) {
- return d;
- } else if (Array.isArray(d[metadata.month])) {
- if (d[metadata.month].indexOf(date.getMonth()) > -1) {
- return d;
- }
- } else if (d[metadata.month] instanceof Date) {
- var sdate = module.helper.sanitiseDate(d[metadata.month]);
- if ((date.getMonth() == sdate.getMonth()) && (date.getFullYear() == sdate.getFullYear())) {
- return d;
- }
- }
- } else if (d[metadata.date] && mode === 'day') {
- if (d[metadata.date] instanceof Date && module.helper.dateEqual(date, module.helper.sanitiseDate(d[metadata.date]), mode)) {
- return d;
- } else if (Array.isArray(d[metadata.date])) {
- if(d[metadata.date].some(function(idate) { return module.helper.dateEqual(date, idate, mode); })) {
- return d;
- }
- }
- }
+ if (year < 0) {
+ year = new Date().getFullYear();
}
- }
- }
- return null;
- },
- findHourAsObject: function(date, mode, hours) {
- if (mode === 'hour') {
- var d;
- var hourCheck = function(date, d) {
- if (d[metadata.hours]) {
- if (typeof d[metadata.hours] === 'number' && date.getHours() == d[metadata.hours]) {
- return d;
- } else if (Array.isArray(d[metadata.hours])) {
- if (d[metadata.hours].indexOf(date.getHours()) > -1) {
- return d;
+
+ if (isAm !== undefined) {
+ if (isAm) {
+ if (hour === 12) {
+ hour = 0;
+ }
+ } else if (hour < 12) {
+ hour += 12;
}
- }
}
- }
- for (var i = 0; i < hours.length; i++) {
- d = hours[i];
- if (typeof d === 'number' && date.getHours() == d) {
- return null;
- } else if (d !== null && typeof d === 'object') {
- if (d[metadata.days] && hourCheck(date,d)) {
- if (typeof d[metadata.days] === 'number' && date.getDay() == d[metadata.days]) {
- return d;
- } else if (Array.isArray(d[metadata.days])) {
- if (d[metadata.days].indexOf(date.getDay()) > -1) {
- return d;
- }
- }
- } else if (d[metadata.date] && hourCheck(date,d)) {
- if (d[metadata.date] instanceof Date && module.helper.dateEqual(date, module.helper.sanitiseDate(d[metadata.date]))) {
- return d;
- } else if (Array.isArray(d[metadata.date])) {
- if (d[metadata.date].some(function(idate) { return module.helper.dateEqual(date, idate, mode); })) {
- return d;
- }
- }
- } else if (hourCheck(date,d)) {
- return d;
- }
+
+ var date = new Date(year, month - 1, day, hour, minute);
+ if (date.getMonth() !== month - 1 || date.getFullYear() !== year) {
+ // month or year don't match up, switch to last day of the month
+ date = new Date(year, month, 0, hour, minute);
}
- }
- }
- return null;
- },
- sanitiseDate: function (date) {
- if (!(date instanceof Date)) {
- date = parser.date('' + date, settings);
- }
- if (!date || isNaN(date.getTime())) {
- return null;
- }
- return date;
- },
- dateDiff: function (date1, date2, mode) {
- mode = mode || 'day';
- var isTimeOnly = settings.type === 'time';
- var isYear = mode === 'year';
- var isYearOrMonth = isYear || mode === 'month';
- var isMinute = mode === 'minute';
- var isHourOrMinute = isMinute || mode === 'hour';
- //only care about a minute accuracy of settings.minTimeGap
- date1 = new Date(
- isTimeOnly ? 2000 : date1.getFullYear(),
- isTimeOnly ? 0 : isYear ? 0 : date1.getMonth(),
- isTimeOnly ? 1 : isYearOrMonth ? 1 : date1.getDate(),
- !isHourOrMinute ? 0 : date1.getHours(),
- !isMinute ? 0 : settings.minTimeGap * Math.floor(date1.getMinutes() / settings.minTimeGap));
- date2 = new Date(
- isTimeOnly ? 2000 : date2.getFullYear(),
- isTimeOnly ? 0 : isYear ? 0 : date2.getMonth(),
- isTimeOnly ? 1 : isYearOrMonth ? 1 : date2.getDate(),
- !isHourOrMinute ? 0 : date2.getHours(),
- !isMinute ? 0 : settings.minTimeGap * Math.floor(date2.getMinutes() / settings.minTimeGap));
- return date2.getTime() - date1.getTime();
- },
- dateEqual: function (date1, date2, mode) {
- return !!date1 && !!date2 && module.helper.dateDiff(date1, date2, mode) === 0;
- },
- isDateInRange: function (date, mode, minDate, maxDate) {
- if (!minDate && !maxDate) {
- var startDate = module.get.startDate();
- minDate = startDate && settings.minDate ? new Date(Math.max(startDate, settings.minDate)) : startDate || settings.minDate;
- maxDate = settings.maxDate;
- }
- minDate = minDate && new Date(minDate.getFullYear(), minDate.getMonth(), minDate.getDate(), minDate.getHours(), settings.minTimeGap * Math.ceil(minDate.getMinutes() / settings.minTimeGap));
- return !(!date ||
- (minDate && module.helper.dateDiff(date, minDate, mode) > 0) ||
- (maxDate && module.helper.dateDiff(maxDate, date, mode) > 0));
- },
- dateInRange: function (date, minDate, maxDate) {
- if (!minDate && !maxDate) {
- var startDate = module.get.startDate();
- minDate = startDate && settings.minDate ? new Date(Math.max(startDate, settings.minDate)) : startDate || settings.minDate;
- maxDate = settings.maxDate;
- }
- minDate = minDate && new Date(minDate.getFullYear(), minDate.getMonth(), minDate.getDate(), minDate.getHours(), settings.minTimeGap * Math.ceil(minDate.getMinutes() / settings.minTimeGap));
- var isTimeOnly = settings.type === 'time';
- return !date ? date :
- (minDate && module.helper.dateDiff(date, minDate, 'minute') > 0) ?
- (isTimeOnly ? module.helper.mergeDateTime(date, minDate) : minDate) :
- (maxDate && module.helper.dateDiff(maxDate, date, 'minute') > 0) ?
- (isTimeOnly ? module.helper.mergeDateTime(date, maxDate) : maxDate) :
- date;
- },
- mergeDateTime: function (date, time) {
- return (!date || !time) ? time :
- new Date(date.getFullYear(), date.getMonth(), date.getDate(), time.getHours(), time.getMinutes());
- },
- isTodayButton: function(element) {
- return element.text() === settings.text.today;
- }
+
+ return isNaN(date.getTime()) ? null : date;
+ },
},
- setting: function (name, value) {
- module.debug('Changing setting', name, value);
- if ($.isPlainObject(name)) {
- $.extend(true, settings, name);
- }
- else if (value !== undefined) {
- if ($.isPlainObject(settings[name])) {
- $.extend(true, settings[name], value);
- }
- else {
- settings[name] = value;
- }
- }
- else {
- return settings[name];
- }
+ // callback before date is changed, return false to cancel the change
+ onBeforeChange: function (date, text, mode) {
+ return true;
+ },
+
+ // callback when date changes
+ onChange: function (date, text, mode) {},
+
+ // callback before show animation, return false to prevent show
+ onShow: function () {},
+
+ // callback after show animation
+ onVisible: function () {},
+
+ // callback before hide animation, return false to prevent hide
+ onHide: function () {},
+
+ // callback after hide animation
+ onHidden: function () {},
+
+ // callback before item is selected, return false to prevent selection
+ onSelect: function (date, mode) {},
+
+ // is the given date disabled?
+ isDisabled: function (date, mode) {
+ return false;
},
- internal: function (name, value) {
- if( $.isPlainObject(name) ) {
- $.extend(true, module, name);
- }
- else if(value !== undefined) {
- module[name] = value;
- }
- else {
- return module[name];
- }
+
+ selector: {
+ popup: '.ui.popup',
+ input: 'input',
+ activator: 'input',
+ append: '.inline.field,.inline.fields',
},
- debug: function () {
- if (!settings.silent && settings.debug) {
- if (settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.debug.apply(console, arguments);
- }
- }
+
+ regExp: {
+ dateWords: /[^A-Za-z\u00C0-\u024F]+/g,
+ dateNumbers: /[^\d:]+/g,
+ token: /d{1,4}|D{1,2}|M{1,4}|YY(?:YY)?|([Hhmsw])\1?|[ASYa]|"[^"]*"|'[^']*'/g,
},
- verbose: function () {
- if (!settings.silent && settings.verbose && settings.debug) {
- if (settings.performance) {
- module.performance.log(arguments);
- }
- else {
- module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
- module.verbose.apply(console, arguments);
- }
- }
+
+ error: {
+ popup: 'UI Popup, a required component is not included in this page',
+ method: 'The method you called is not defined.',
},
- error: function () {
- if (!settings.silent) {
- module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
- module.error.apply(console, arguments);
- }
+
+ className: {
+ calendar: 'calendar',
+ active: 'active',
+ popup: 'ui popup',
+ grid: 'ui equal width grid',
+ column: 'column',
+ table: 'ui celled center aligned unstackable table',
+ inverted: 'inverted',
+ prev: 'prev link',
+ next: 'next link',
+ prevIcon: 'chevron left icon',
+ nextIcon: 'chevron right icon',
+ link: 'link',
+ cell: 'link',
+ disabledCell: 'disabled',
+ weekCell: 'disabled',
+ adjacentCell: 'adjacent',
+ activeCell: 'active',
+ rangeCell: 'range',
+ focusCell: 'focus',
+ todayCell: 'today',
+ today: 'today link',
+ disabled: 'disabled',
},
- performance: {
- log: function (message) {
- var
- currentTime,
- executionTime,
- previousTime
- ;
- if (settings.performance) {
- currentTime = new Date().getTime();
- previousTime = time || currentTime;
- executionTime = currentTime - previousTime;
- time = currentTime;
- performance.push({
- 'Name': message[0],
- 'Arguments': [].slice.call(message, 1) || '',
- 'Element': element,
- 'Execution Time': executionTime
- });
- }
- clearTimeout(module.performance.timer);
- module.performance.timer = setTimeout(module.performance.display, 500);
- },
- display: function () {
- var
- title = settings.name + ':',
- totalTime = 0
- ;
- time = false;
- clearTimeout(module.performance.timer);
- $.each(performance, function (index, data) {
- totalTime += data['Execution Time'];
- });
- title += ' ' + totalTime + 'ms';
- if (moduleSelector) {
- title += ' \'' + moduleSelector + '\'';
- }
- if ((console.group !== undefined || console.table !== undefined) && performance.length > 0) {
- console.groupCollapsed(title);
- if (console.table) {
- console.table(performance);
- }
- else {
- $.each(performance, function (index, data) {
- console.log(data['Name'] + ': ' + data['Execution Time'] + 'ms');
- });
- }
- console.groupEnd();
- }
- performance = [];
- }
+
+ metadata: {
+ date: 'date',
+ focusDate: 'focusDate',
+ startDate: 'startDate',
+ endDate: 'endDate',
+ minDate: 'minDate',
+ maxDate: 'maxDate',
+ mode: 'mode',
+ type: 'type',
+ monthOffset: 'monthOffset',
+ message: 'message',
+ class: 'class',
+ inverted: 'inverted',
+ variation: 'variation',
+ position: 'position',
+ month: 'month',
+ year: 'year',
+ hours: 'hours',
+ days: 'days',
},
- invoke: function (query, passedArguments, context) {
- var
- object = instance,
- maxDepth,
- found,
- response
- ;
- passedArguments = passedArguments || queryArguments;
- context = context || element;
- if (typeof query == 'string' && object !== undefined) {
- query = query.split(/[\. ]/);
- maxDepth = query.length - 1;
- $.each(query, function (depth, value) {
- var camelCaseValue = (depth != maxDepth)
- ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
- : query
- ;
- if ($.isPlainObject(object[camelCaseValue]) && (depth != maxDepth)) {
- object = object[camelCaseValue];
- }
- else if (object[camelCaseValue] !== undefined) {
- found = object[camelCaseValue];
- return false;
- }
- else if ($.isPlainObject(object[value]) && (depth != maxDepth)) {
- object = object[value];
- }
- else if (object[value] !== undefined) {
- found = object[value];
- return false;
- }
- else {
- module.error(error.method, query);
- return false;
- }
- });
- }
- if ($.isFunction(found)) {
- response = found.apply(context, passedArguments);
- }
- else if (found !== undefined) {
- response = found;
- }
- if (Array.isArray(returnedValue)) {
- returnedValue.push(response);
- }
- else if (returnedValue !== undefined) {
- returnedValue = [returnedValue, response];
- }
- else if (response !== undefined) {
- returnedValue = response;
- }
- return found;
- }
- };
-
- if (methodInvoked) {
- if (instance === undefined) {
- module.initialize();
- }
- module.invoke(query);
- }
- else {
- if (instance !== undefined) {
- instance.invoke('destroy');
- }
- module.initialize();
- }
- })
- ;
- return (returnedValue !== undefined)
- ? returnedValue
- : this
- ;
-};
-
-$.fn.calendar.settings = {
-
- name : 'Calendar',
- namespace : 'calendar',
-
- silent: false,
- debug: false,
- verbose: false,
- performance: true,
-
- type : 'datetime', // picker type, can be 'datetime', 'date', 'time', 'month', or 'year'
- firstDayOfWeek : 0, // day for first day column (0 = Sunday)
- constantHeight : true, // add rows to shorter months to keep day calendar height consistent (6 rows)
- today : false, // show a 'today/now' button at the bottom of the calendar
- closable : true, // close the popup after selecting a date/time
- monthFirst : true, // month before day when parsing date from text
- touchReadonly : true, // set input to readonly on touch devices
- inline : false, // create the calendar inline instead of inside a popup
- on : null, // when to show the popup (defaults to 'focus' for input, 'click' for others)
- initialDate : null, // date to display initially when no date is selected (null = now)
- startMode : false, // display mode to start in, can be 'year', 'month', 'day', 'hour', 'minute' (false = 'day')
- minDate : null, // minimum date/time that can be selected, dates/times before are disabled
- maxDate : null, // maximum date/time that can be selected, dates/times after are disabled
- disableYear : false, // disable year selection mode
- disableMonth : false, // disable month selection mode
- disableMinute : false, // disable minute selection mode
- formatInput : true, // format the input text upon input blur and module creation
- startCalendar : null, // jquery object or selector for another calendar that represents the start date of a date range
- endCalendar : null, // jquery object or selector for another calendar that represents the end date of a date range
- multiMonth : 1, // show multiple months when in 'day' mode
- monthOffset : 0, // position current month by offset when multimonth > 1
- minTimeGap : 5,
- showWeekNumbers : false, // show Number of Week at the very first column of a dayView
- disabledHours : [], // specific hour(s) which won't be selectable and contain additional information.
- disabledDates : [], // specific day(s) which won't be selectable and contain additional information.
- disabledDaysOfWeek : [], // day(s) which won't be selectable(s) (0 = Sunday)
- enabledDates : [], // specific day(s) which will be selectable, all other days will be disabled
- eventDates : [], // specific day(s) which will be shown in a different color and using tooltips
- centuryBreak : 60, // starting short year until 99 where it will be assumed to belong to the last century
- currentCentury : 2000, // century to be added to 2-digit years (00 to {centuryBreak}-1)
- selectAdjacentDays : false, // The calendar can show dates from adjacent month. These adjacent month dates can also be made selectable.
- // popup options ('popup', 'on', 'hoverable', and show/hide callbacks are overridden)
- popupOptions: {
- position: 'bottom left',
- lastResort: 'bottom left',
- prefer: 'opposite',
- observeChanges: false,
- hideOnScroll: false
- },
-
- text: {
- days: ['S', 'M', 'T', 'W', 'T', 'F', 'S'],
- dayNamesShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],
- dayNames: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],
- months: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
- monthsShort: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],
- today: 'Today',
- now: 'Now',
- am: 'AM',
- pm: 'PM',
- weekNo: 'Week'
- },
-
- formatter: {
- yearHeader: function (date, settings) {
- var decadeYear = Math.ceil(date.getFullYear() / 10) * 10;
- return (decadeYear - 9) + ' - ' + (decadeYear + 2);
- },
- monthHeader: 'YYYY',
- dayHeader: 'MMMM YYYY',
- hourHeader: 'MMMM D, YYYY',
- minuteHeader: 'MMMM D, YYYY',
- dayColumnHeader: function (day, settings) {
- return settings.text.days[day];
- },
- datetime: 'MMMM D, YYYY h:mm A',
- date: 'MMMM D, YYYY',
- time: 'h:mm A',
- cellTime: 'h:mm A',
- month: 'MMMM YYYY',
- year: 'YYYY',
- today: function (settings) {
- return settings.type === 'date' ? settings.text.today : settings.text.now;
- },
- cell: function (cell, date, cellOptions) {
- }
- },
-
- parser: {
- date: function (text, settings) {
- if (text instanceof Date) {
- return text;
- }
- if (!text) {
- return null;
- }
- text = String(text).trim().replace(/([.:\/\-])\s+/g,'$1').replace(/\s+([.:\/-])/g,'$1').replace(/\s+/g,' ');
- if (text.length === 0) {
- return null;
- }
- if(text.match(/^[0-9]{4}[\/\-\.][0-9]{1,2}[\/\-\.][0-9]{1,2}$/)){
- text = text.replace(/[\/\-\.]/g,'/') + ' 00:00:00';
- }
- // Reverse date and month in some cases
- text = settings.monthFirst || !text.match(/^[0-9]{1,2}[\/\-\.]/) ? text : text.replace(/[\/\-\.]/g,'/').replace(/([0-9]+)\/([0-9]+)/,'$2/$1');
- var textDate = new Date(text);
- var numberOnly = text.match(/^[0-9]+$/) !== null;
- if(!numberOnly && !isNaN(textDate.getDate())) {
- return textDate;
- }
- text = text.toLowerCase();
-
- var i, j, k;
- var minute = -1, hour = -1, day = -1, month = -1, year = -1;
- var isAm = undefined;
-
- var isTimeOnly = settings.type === 'time';
- var isDateOnly = settings.type.indexOf('time') < 0;
-
- var words = text.split(settings.regExp.dateWords), word;
- var numbers = text.split(settings.regExp.dateNumbers), number;
-
- var parts;
- var monthString;
-
- if (!isDateOnly) {
- //am/pm
- isAm = $.inArray(settings.text.am.toLowerCase(), words) >= 0 ? true :
- $.inArray(settings.text.pm.toLowerCase(), words) >= 0 ? false : undefined;
-
- //time with ':'
- for (i = 0; i < numbers.length; i++) {
- number = numbers[i];
- if (number.indexOf(':') >= 0) {
- if (hour < 0 || minute < 0) {
- parts = number.split(':');
- for (k = 0; k < Math.min(2, parts.length); k++) {
- j = parseInt(parts[k]);
- if (isNaN(j)) {
- j = 0;
- }
- if (k === 0) {
- hour = j % 24;
- } else {
- minute = j % 60;
- }
- }
- }
- numbers.splice(i, 1);
- }
- }
- }
-
- if (!isTimeOnly) {
- //textual month
- for (i = 0; i < words.length; i++) {
- word = words[i];
- if (word.length <= 0) {
- continue;
- }
- for (j = 0; j < settings.text.months.length; j++) {
- monthString = settings.text.months[j];
- monthString = monthString.substring(0, word.length).toLowerCase();
- if (monthString === word) {
- month = j + 1;
- break;
- }
- }
- if (month >= 0) {
- break;
- }
- }
-
- //year > settings.centuryBreak
- for (i = 0; i < numbers.length; i++) {
- j = parseInt(numbers[i]);
- if (isNaN(j)) {
- continue;
- }
- if (j >= settings.centuryBreak && i === numbers.length-1) {
- if (j <= 99) {
- j += settings.currentCentury - 100;
- }
- year = j;
- numbers.splice(i, 1);
- break;
- }
- }
-
- //numeric month
- if (month < 0) {
- for (i = 0; i < numbers.length; i++) {
- k = i > 1 || settings.monthFirst ? i : i === 1 ? 0 : 1;
- j = parseInt(numbers[k]);
- if (isNaN(j)) {
- continue;
- }
- if (1 <= j && j <= 12) {
- month = j;
- numbers.splice(k, 1);
- break;
- }
- }
- }
-
- //day
- for (i = 0; i < numbers.length; i++) {
- j = parseInt(numbers[i]);
- if (isNaN(j)) {
- continue;
- }
- if (1 <= j && j <= 31) {
- day = j;
- numbers.splice(i, 1);
- break;
- }
- }
-
- //year <= settings.centuryBreak
- if (year < 0) {
- for (i = numbers.length - 1; i >= 0; i--) {
- j = parseInt(numbers[i]);
- if (isNaN(j)) {
- continue;
- }
- if (j <= 99) {
- j += settings.currentCentury;
- }
- year = j;
- numbers.splice(i, 1);
- break;
- }
- }
- }
-
- if (!isDateOnly) {
- //hour
- if (hour < 0) {
- for (i = 0; i < numbers.length; i++) {
- j = parseInt(numbers[i]);
- if (isNaN(j)) {
- continue;
- }
- if (0 <= j && j <= 23) {
- hour = j;
- numbers.splice(i, 1);
- break;
- }
- }
- }
-
- //minute
- if (minute < 0) {
- for (i = 0; i < numbers.length; i++) {
- j = parseInt(numbers[i]);
- if (isNaN(j)) {
- continue;
- }
- if (0 <= j && j <= 59) {
- minute = j;
- numbers.splice(i, 1);
- break;
- }
- }
- }
- }
-
- if (minute < 0 && hour < 0 && day < 0 && month < 0 && year < 0) {
- return null;
- }
-
- if (minute < 0) {
- minute = 0;
- }
- if (hour < 0) {
- hour = 0;
- }
- if (day < 0) {
- day = 1;
- }
- if (month < 0) {
- month = 1;
- }
- if (year < 0) {
- year = new Date().getFullYear();
- }
-
- if (isAm !== undefined) {
- if (isAm) {
- if (hour === 12) {
- hour = 0;
- }
- } else if (hour < 12) {
- hour += 12;
- }
- }
-
- var date = new Date(year, month - 1, day, hour, minute);
- if (date.getMonth() !== month - 1 || date.getFullYear() !== year) {
- //month or year don't match up, switch to last day of the month
- date = new Date(year, month, 0, hour, minute);
- }
- return isNaN(date.getTime()) ? null : date;
- }
- },
-
- // callback before date is changed, return false to cancel the change
- onBeforeChange: function (date, text, mode) {
- return true;
- },
-
- // callback when date changes
- onChange: function (date, text, mode) {
- },
-
- // callback before show animation, return false to prevent show
- onShow: function () {
- },
-
- // callback after show animation
- onVisible: function () {
- },
-
- // callback before hide animation, return false to prevent hide
- onHide: function () {
- },
-
- // callback after hide animation
- onHidden: function () {
- },
-
- // callback before item is selected, return false to prevent selection
- onSelect: function (date, mode) {
- },
-
- // is the given date disabled?
- isDisabled: function (date, mode) {
- return false;
- },
-
- selector: {
- popup: '.ui.popup',
- input: 'input',
- activator: 'input',
- append: '.inline.field,.inline.fields'
- },
-
- regExp: {
- dateWords: /[^A-Za-z\u00C0-\u024F]+/g,
- dateNumbers: /[^\d:]+/g,
- token: /d{1,4}|D{1,2}|M{1,4}|YY(?:YY)?|([Hhmsw])\1?|[SAaY]|"[^"]*"|'[^']*'/g
- },
-
- error: {
- popup: 'UI Popup, a required component is not included in this page',
- method: 'The method you called is not defined.'
- },
-
- className: {
- calendar: 'calendar',
- active: 'active',
- popup: 'ui popup',
- grid: 'ui equal width grid',
- column: 'column',
- table: 'ui celled center aligned unstackable table',
- inverted: 'inverted',
- prev: 'prev link',
- next: 'next link',
- prevIcon: 'chevron left icon',
- nextIcon: 'chevron right icon',
- link: 'link',
- cell: 'link',
- disabledCell: 'disabled',
- weekCell: 'disabled',
- adjacentCell: 'adjacent',
- activeCell: 'active',
- rangeCell: 'range',
- focusCell: 'focus',
- todayCell: 'today',
- today: 'today link',
- disabled: 'disabled'
- },
-
- metadata: {
- date: 'date',
- focusDate: 'focusDate',
- startDate: 'startDate',
- endDate: 'endDate',
- minDate: 'minDate',
- maxDate: 'maxDate',
- mode: 'mode',
- type: 'type',
- monthOffset: 'monthOffset',
- message: 'message',
- class: 'class',
- inverted: 'inverted',
- variation: 'variation',
- position: 'position',
- month: 'month',
- year: 'year',
- hours: 'hours',
- days: 'days'
- },
-
- eventClass: 'blue'
-};
+ eventClass: 'blue',
+ };
})(jQuery, window, document);
diff --git a/definitions/modules/calendar.less b/definitions/modules/calendar.less
index 4342546..0356852 100644
--- a/definitions/modules/calendar.less
+++ b/definitions/modules/calendar.less
@@ -1,10 +1,10 @@
/*!
* # Fomantic-UI - Calendar
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
@@ -12,41 +12,45 @@
Theme
*******************************/
-@type : 'module';
-@element : 'calendar';
+@type: "module";
+@element: "calendar";
-@import (multiple) '../../theme.config';
+@import (multiple) "../../theme.config";
/*******************************
Popup
*******************************/
-.ui.calendar .ui.popup {
- max-width: none;
- padding: 0;
- border: none;
- user-select: none;
+.ui.calendar.popup {
+ max-width: none;
+ padding: 0;
+ border: none;
+ user-select: none;
+ &.inverted::before when (@variationCalendarInverted) {
+ background: @invertedArrowBackground;
+ }
}
/*******************************
Calendar
*******************************/
-.ui.calendar .calendar:focus {
- outline: 0;
+.ui.calendar .calendar:focus,
+.ui.calendar.popup:focus {
+ outline: 0;
}
/*******************************
Grid
*******************************/
-.ui.calendar .ui.popup .ui.grid {
- display: block;
- white-space: nowrap;
+.ui.calendar.popup .ui.grid {
+ display: block;
+ white-space: nowrap;
}
-.ui.calendar .ui.popup .ui.grid > .column {
- width: auto;
+.ui.calendar.popup .ui.grid > .column {
+ width: auto;
}
/*******************************
@@ -56,140 +60,140 @@
.ui.calendar .ui.table.year,
.ui.calendar .ui.table.month,
.ui.calendar .ui.table.minute {
- min-width: 15em;
+ min-width: 15em;
}
.ui.calendar .ui.table.day {
- min-width: 18em;
+ min-width: 18em;
}
.ui.calendar .ui.table.day.andweek {
- min-width: 22em;
+ min-width: 22em;
}
.ui.calendar .ui.table.hour {
- min-width: 20em;
+ min-width: 20em;
}
.ui.calendar .ui.table tr th,
.ui.calendar .ui.table tr td {
- padding: 0.5em;
- white-space: nowrap;
+ padding: 0.5em;
+ white-space: nowrap;
}
.ui.calendar .ui.table tr th {
- border-left: none;
+ border-left: none;
}
.ui.calendar .ui.table tr th i.icon {
- margin: 0;
+ margin: 0;
}
.ui.calendar .ui.table tr:first-child th {
- position: relative;
- padding-left: 0;
- padding-right: 0;
+ position: relative;
+ padding-left: 0;
+ padding-right: 0;
}
.ui.calendar .ui.table.day tr:first-child th {
- border: none;
+ border: none;
}
.ui.calendar .ui.table.day tr:nth-child(2) th {
- padding-top: 0.2em;
- padding-bottom: 0.3em;
+ padding-top: 0.2em;
+ padding-bottom: 0.3em;
}
.ui.calendar .ui.table tr td {
- padding-left: 0.1em;
- padding-right: 0.1em;
+ padding-left: 0.1em;
+ padding-right: 0.1em;
}
.ui.calendar .ui.table tr .link {
- cursor: pointer;
+ cursor: pointer;
}
.ui.calendar .ui.table tr .prev.link {
- width: 14.28571429%;
- position: absolute;
- left: 0;
+ width: 14.28571%;
+ position: absolute;
+ left: 0;
}
.ui.calendar .ui.table tr .next.link {
- width: 14.28571429%;
- position: absolute;
- right: 0;
+ width: 14.28571%;
+ position: absolute;
+ right: 0;
}
.ui.ui.calendar .ui.table tr .disabled {
- pointer-events: auto;
- cursor: default;
- color: @disabledTextColor;
+ pointer-events: auto;
+ cursor: default;
+ color: @disabledTextColor;
}
.ui.calendar .ui.table tr .adjacent:not(.disabled):not(.active) {
- color: @adjacentTextColor;
- background: @adjacentBackground;
+ color: @adjacentTextColor;
+ background: @adjacentBackground;
}
-/*--------------
+/* --------------
States
----------------*/
+--------------- */
.ui.calendar .ui.table tr td.today {
- font-weight: @todayFontWeight;
+ font-weight: @todayFontWeight;
}
.ui.calendar .ui.table tr td.range {
- background: @rangeBackground;
- color: @rangeTextColor;
- box-shadow: @rangeBoxShadow;
+ background: @rangeBackground;
+ color: @rangeTextColor;
+ box-shadow: @rangeBoxShadow;
}
-.ui.calendar:not(.disabled) .calendar:focus .ui.table tbody tr td.focus,
-.ui.calendar:not(.disabled) .calendar.active .ui.table tbody tr td.focus {
- box-shadow: @focusBoxShadow;
+.ui.calendar:not(.disabled):focus .ui.table tbody tr td.focus,
+.ui.calendar:not(.disabled).popup.active .ui.table tbody tr td.focus {
+ box-shadow: @focusBoxShadow;
}
& when (@variationCalendarInverted) {
- .ui.inverted.calendar .ui.table.inverted tr td.range {
- background: @rangeInvertedBackground;
- color: @rangeInvertedTextColor;
- box-shadow: @rangeInvertedBoxShadow;
- }
-
- .ui.inverted.calendar:not(.disabled) .calendar:focus .ui.table.inverted tbody tr td.focus,
- .ui.inverted.calendar:not(.disabled) .calendar.active .ui.table.inverted tbody tr td.focus {
- box-shadow: @focusInvertedBoxShadow;
- }
- .ui.inverted.calendar .ui.inverted.table tr .disabled {
- color: @invertedDisabledTextColor;
- }
-
- .ui.inverted.calendar .ui.inverted.table tr .adjacent:not(.disabled):not(.active) {
- color: @adjacentInvertedTextColor;
- background: @adjacentInvertedBackground;
- }
+ .ui.inverted.calendar .ui.table.inverted tr td.range {
+ background: @rangeInvertedBackground;
+ color: @rangeInvertedTextColor;
+ box-shadow: @rangeInvertedBoxShadow;
+ }
+
+ .ui.inverted.calendar:not(.disabled) .calendar:focus .ui.table.inverted tbody tr td.focus,
+ .ui.inverted.calendar:not(.disabled).popup.active .ui.table.inverted tbody tr td.focus {
+ box-shadow: @focusInvertedBoxShadow;
+ }
+ .ui.inverted.calendar .ui.ui.ui.inverted.table tr .disabled {
+ color: @invertedDisabledTextColor;
+ }
+
+ .ui.inverted.calendar .ui.inverted.table tr .adjacent:not(.disabled):not(.active) {
+ color: @adjacentInvertedTextColor;
+ background: @adjacentInvertedBackground;
+ }
}
& when (@variationCalendarMultiMonth) {
- .ui.calendar.popup > .ui.ui.grid {
- margin: @multiMonthMargin;
- & > .column:not(:first-child) {
- padding-left: @multiMonthPadding;
- & > .ui.table {
- border-top-left-radius:0;
- border-bottom-left-radius:0;
- }
- }
- & > .column:not(:last-child) {
- padding-right:@multiMonthPadding;
- & > .ui.table {
- border-top-right-radius:0;
- border-bottom-right-radius:0;
- }
+ .ui.calendar.popup > .ui.ui.grid {
+ margin: @multiMonthMargin;
+ & > .column:not(:first-child) {
+ padding-left: @multiMonthPadding;
+ & > .ui.table {
+ border-top-left-radius: 0;
+ border-bottom-left-radius: 0;
+ }
+ }
+ & > .column:not(:last-child) {
+ padding-right: @multiMonthPadding;
+ & > .ui.table {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+ }
+ }
}
- }
}
/*******************************
@@ -197,19 +201,18 @@
*******************************/
& when (@variationCalendarDisabled) {
- /*--------------------
- Disabled
- ---------------------*/
+ /* --------------------
+ Disabled
+ --------------------- */
- .ui.disabled.calendar {
- opacity: @disabledOpacity;
- }
+ .ui.disabled.calendar {
+ opacity: @disabledOpacity;
+ }
- .ui.disabled.calendar > .input,
- .ui.disabled.calendar .ui.table tr .link {
- pointer-events: none;
- }
+ .ui.disabled.calendar > .input,
+ .ui.disabled.calendar .ui.table tr .link {
+ pointer-events: none;
+ }
}
-
.loadUIOverrides();
diff --git a/definitions/modules/checkbox.js b/definitions/modules/checkbox.js
index 0c0fd8b..9c72ee2 100644
--- a/definitions/modules/checkbox.js
+++ b/definitions/modules/checkbox.js
@@ -1,883 +1,884 @@
/*!
* # Fomantic-UI - Checkbox
- * http://github.com/fomantic/Fomantic-UI/
+ * https://github.com/fomantic/Fomantic-UI/
*
*
* Released under the MIT license
- * http://opensource.org/licenses/MIT
+ * https://opensource.org/licenses/MIT
*
*/
-;(function ($, window, document, undefined) {
+(function ($, window, document) {
+ 'use strict';
-'use strict';
+ function isFunction(obj) {
+ return typeof obj === 'function' && typeof obj.nodeType !== 'number';
+ }
-$.isFunction = $.isFunction || function(obj) {
- return typeof obj === "function" && typeof obj.nodeType !== "number";
-};
+ window = window !== undefined && window.Math === Math
+ ? window
+ : globalThis;
-window = (typeof window != 'undefined' && window.Math == Math)
- ? window
- : (typeof self != 'undefined' && self.Math == Math)
- ? self
- : Function('return this')()
-;
+ $.fn.checkbox = function (parameters) {
+ var
+ $allModules = $(this),
+ moduleSelector = $allModules.selector || '',
-$.fn.checkbox = function(parameters) {
- var
- $allModules = $(this),
- moduleSelector = $allModules.selector || '',
+ time = Date.now(),
+ performance = [],
- time = new Date().getTime(),
- performance = [],
+ query = arguments[0],
+ methodInvoked = typeof query === 'string',
+ queryArguments = [].slice.call(arguments, 1),
+ returnedValue
+ ;
- query = arguments[0],
- methodInvoked = (typeof query == 'string'),
- queryArguments = [].slice.call(arguments, 1),
- returnedValue
- ;
-
- $allModules
- .each(function() {
- var
- settings = $.extend(true, {}, $.fn.checkbox.settings, parameters),
-
- className = settings.className,
- namespace = settings.namespace,
- selector = settings.selector,
- error = settings.error,
-
- eventNamespace = '.' + namespace,
- moduleNamespace = 'module-' + namespace,
-
- $module = $(this),
- $label = $(this).children(selector.label),
- $input = $(this).children(selector.input),
- input = $input[0],
-
- initialLoad = false,
- shortcutPressed = false,
- instance = $module.data(moduleNamespace),
-
- observer,
- element = this,
- module
- ;
-
- module = {
-
- initialize: function() {
- module.verbose('Initializing checkbox', settings);
-
- module.create.label();
- module.bind.events();
-
- module.set.tabbable();
- module.hide.input();
-
- module.observeChanges();
- module.instantiate();
- module.setup();
- },
-
- instantiate: function() {
- module.verbose('Storing instance of module', module);
- instance = module;
- $module
- .data(moduleNamespace, module)
- ;
- },
-
- destroy: function() {
- module.verbose('Destroying module');
- module.unbind.events();
- module.show.input();
- $module.removeData(moduleNamespace);
- },
+ $allModules.each(function () {
+ var
+ settings = $.extend(true, {}, $.fn.checkbox.settings, parameters),
- fix: {
- reference: function() {
- if( $module.is(selector.input) ) {
- module.debug('Behavior called on adjusting invoked element');
- $module = $module.closest(selector.checkbox);
- module.refresh();
- }
- }
- },
+ className = settings.className,
+ namespace = settings.namespace,
+ selector = settings.selector,
+ error = settings.error,
- setup: function() {
- module.set.initialLoad();
- if( module.is.indeterminate() ) {
- module.debug('Initial value is indeterminate');
- module.indeterminate();
- }
- else if( module.is.checked() ) {
- module.debug('Initial value is checked');
- module.check();
- }
- else {
- module.debug('Initial value is unchecked');
- module.uncheck();
- }
- module.remove.initialLoad();
- },
+ eventNamespace = '.' + namespace,
+ moduleNamespace = 'module-' + namespace,
- refresh: function() {
- $label = $module.children(selector.label);
- $input = $module.children(selector.input);
- input = $input[0];
- },
+ $module = $(this),
+ $label = $(this).children(selector.label),
+ $input = $(this).children(selector.input),
+ input = $input[0],
- hide: {
- input: function() {
- module.verbose('Modifying z-index to be unselectable');
- $input.addClass(className.hidden);
- }
- },
- show: {
- input: function() {
- module.verbose('Modifying z-index to be selectable');
- $input.removeClass(className.hidden);
- }
- },
+ initialLoad = false,
+ shortcutPressed = false,
+ instance = $module.data(moduleNamespace),
- observeChanges: function() {
- if('MutationObserver' in window) {
- observer = new MutationObserver(function(mutations) {
- module.debug('DOM tree modified, updating selector cache');
- module.refresh();
- });
- observer.observe(element, {
- childList : true,
- subtree : true
- });
- module.debug('Setting up mutation observer', observer);
- }
- },
-
- attachEvents: function(selector, event) {
- var
- $element = $(selector)
- ;
- event = $.isFunction(module[event])
- ? module[event]
- : module.toggle
- ;
- if($element.length > 0) {
- module.debug('Attaching checkbox events to element', selector, event);
- $element
- .on('click' + eventNamespace, event)
- ;
- }
- else {
- module.error(error.notFound);
- }
- },
-
- preventDefaultOnInputTarget: function() {
- if(typeof event !== 'undefined' && event !== null && $(event.target).is(selector.input)) {
- module.verbose('Preventing default check action after manual check action');
- event.preventDefault();
- }
- },
-
- event: {
- change: function(event) {
- if( !module.should.ignoreCallbacks() ) {
- settings.onChange.call(input);
- }
- },
- click: function(event) {
- var
- $target = $(event.target)
- ;
- if( $target.is(selector.input) ) {
- module.verbose('Using default check action on initialized checkbox');
- return;
- }
- if( $target.is(selector.link) ) {
- module.debug('Clicking link inside checkbox, skipping toggle');
- return;
- }
- module.toggle();
- $input.focus();
- event.preventDefault();
- },
- keydown: function(event) {
- var
- key = event.which,
- keyCode = {
- enter : 13,
- space : 32,
- escape : 27,
- left : 37,
- up : 38,
- right : 39,
- down : 40
- }
+ observer,
+ element = this,
+ module
;
- var r = module.get.radios(),
- rIndex = r.index($module),
- rLen = r.length,
- checkIndex = false;
-
- if(key == keyCode.left || key == keyCode.up) {
- checkIndex = (rIndex === 0 ? rLen : rIndex) - 1;
- } else if(key == keyCode.right || key == keyCode.down) {
- checkIndex = rIndex === rLen-1 ? 0 : rIndex+1;
- }
-
- if (!module.should.ignoreCallbacks() && checkIndex !== false) {
- if(settings.beforeUnchecked.apply(input)===false) {
- module.verbose('Option not allowed to be unchecked, cancelling key navigation');
- return false;
- }
- if (settings.beforeChecked.apply($(r[checkIndex]).children(selector.input)[0])===false) {
- module.verbose('Next option should not allow check, cancelling key navigation');
- return false;
- }
- }
-
- shortcutPressed = false;
- if(key == keyCode.escape) {
- module.verbose('Escape key pressed blurring field');
- $input.blur();
- shortcutPressed = true;
- event.stopPropagation();
- }
- else if(!event.ctrlKey && module.can.change()) {
- if( key == keyCode.space || (key == keyCode.enter && settings.enableEnterKey) ) {
- module.verbose('Enter/space key pressed, toggling checkbox');
- module.toggle();
- shortcutPressed = true;
- } else if($module.is('.toggle, .slider') && !module.is.radio()) {
- if(key == keyCode.left && module.is.checked()) {
- module.uncheck();
- shortcutPressed = true;
- } else if(key == keyCode.right && module.is.unchecked()) {
- module.check();
- shortcutPressed = true;
- }
+ module = {
+
+ initialize: function () {
+ module.verbose('Initializing checkbox', settings);
+
+ module.create.label();
+ module.bind.events();
+
+ module.set.tabbable();
+ module.hide.input();
+
+ module.observeChanges();
+ module.instantiate();
+ module.setup();
+ },
+
+ instantiate: function () {
+ module.verbose('Storing instance of module', module);
+ instance = module;
+ $module
+ .data(moduleNamespace, module)
+ ;
+ },
+
+ destroy: function () {
+ module.verbose('Destroying module');
+ module.unbind.events();
+ module.show.input();
+ $module.removeData(moduleNamespace);
+ },
+
+ fix: {
+ reference: function () {
+ if ($module.is(selector.input)) {
+ module.debug('Behavior called on adjusting invoked element');
+ $module = $module.closest(selector.checkbox);
+ module.refresh();
+ }
+ },
+ },
+
+ setup: function () {
+ module.set.initialLoad();
+ if (module.is.indeterminate()) {
+ module.debug('Initial value is indeterminate');
+ module.indeterminate();
+ } else if (module.is.checked()) {
+ module.debug('Initial value is checked');
+ module.check();
+ } else {
+ module.debug('Initial value is unchecked');
+ module.uncheck();
+ }
+ module.remove.initialLoad();
+ },
+
+ refresh: function () {
+ $label = $module.children(selector.label);
+ $input = $module.children(selector.input);
+ input = $input[0];
+ },
+
+ hide: {
+ input: function () {
+ module.verbose('Modifying z-index to be unselectable');
+ $input.addClass(className.hidden);
+ },
+ },
+ show: {
+ input: function () {
+ module.verbose('Modifying z-index to be selectable');
+ $input.removeClass(className.hidden);
+ },
+ },
+
+ observeChanges: function () {
+ if ('MutationObserver' in window) {
+ observer = new MutationObserver(function (mutations) {
+ module.debug('DOM tree modified, updating selector cache');
+ module.refresh();
+ });
+ observer.observe(element, {
+ childList: true,
+ subtree: true,
+ });
+ module.debug('Setting up mutation observer', observer);
+ }
+ },
+
+ attachEvents: function (selector, event) {
+ var
+ $element = $(selector)
+ ;
+ event = isFunction(module[event])
+ ? module[event]
+ : module.toggle;
+ if ($element.length > 0) {
+ module.debug('Attaching checkbox events to element', selector, event);
+ $element
+ .on('click' + eventNamespace, event)
+ ;
+ } else {
+ module.error(error.notFound);
+ }
+ },
+
+ preventDefaultOnInputTarget: function () {
+ if (event !== undefined && event !== null && $(event.target).is(selector.input)) {
+ module.verbose('Preventing default check action after manual check action');
+ event.preventDefault();
+ }
+ },
+
+ event: {
+ change: function (event) {
+ if (!module.should.ignoreCallbacks()) {
+ settings.onChange.call(input);
+ }
+ },
+ click: function (event) {
+ var
+ $target = $(event.target)
+ ;
+ if ($target.is(selector.input)) {
+ module.verbose('Using default check action on initialized checkbox');
+
+ return;
+ }
+ if ($target.is(selector.link)) {
+ module.debug('Clicking link inside checkbox, skipping toggle');
+
+ return;
+ }
+ module.toggle();
+ $input.trigger('focus');
+ event.preventDefault();
+ },
+ keydown: function (event) {
+ var
+ key = event.which,
+ keyCode = {
+ enter: 13,
+ space: 32,
+ escape: 27,
+ left: 37,
+ up: 38,
+ right: 39,
+ down: 40,
+ }
+ ;
+
+ var
+ r = module.get.radios(),
+ rIndex = r.index($module),
+ rLen = r.length,
+ checkIndex = false
+ ;
+
+ if (key === keyCode.left || key === keyCode.up) {
+ checkIndex = (rIndex === 0 ? rLen : rIndex) - 1;
+ } else if (key === keyCode.right || key === keyCode.down) {
+ checkIndex = rIndex === rLen - 1 ? 0 : rIndex + 1;
+ }
+
+ if (!module.should.ignoreCallbacks() && checkIndex !== false) {
+ if (settings.beforeUnchecked.apply(input) === false) {
+ module.verbose('Option not allowed to be unchecked, cancelling key navigation');
+
+ return false;
+ }
+ if (settings.beforeChecked.apply($(r[checkIndex]).children(selector.input)[0]) === false) {
+ module.verbose('Next option should not allow check, cancelling key navigation');
+
+ return false;
+ }
+ }
+
+ shortcutPressed = false;
+ if (key === keyCode.escape) {
+ module.verbose('Escape key pressed blurring field');
+ $input.trigger('blur');
+ shortcutPressed = true;
+ event.stopPropagation();
+ } else if (!event.ctrlKey && module.can.change()) {
+ if (key === keyCode.space || (key === keyCode.enter && settings.enableEnterKey)) {
+ module.verbose('Enter/space key pressed, toggling checkbox');
+ module.toggle();
+ shortcutPressed = true;
+ } else if ($module.is('.toggle, .slider') && !module.is.radio()) {
+ if (key === keyCode.left && module.is.checked()) {
+ module.uncheck();
+ shortcutPressed = true;
+ } else if (key === keyCode.right && module.is.unchecked()) {
+ module.check();
+ shortcutPressed = true;
+ }
+ }
+ }
+ },
+ keyup: function (event) {
+ if (shortcutPressed) {
+ event.preventDefault();
+ }
+ },
+ },
+
+ check: function () {
+ if (!module.should.allowCheck()) {
+ return;
+ }
+ module.debug('Checking checkbox', $input);
+ module.set.checked();
+ if (!module.should.ignoreCallbacks()) {
+ settings.onChecked.call(input);
+ module.trigger.change();
+ }
+ module.preventDefaultOnInputTarget();
+ },
+
+ uncheck: function () {
+ if (!module.should.allowUncheck()) {
+ return;
+ }
+ module.debug('Unchecking checkbox');
+ module.set.unchecked();
+ if (!module.should.ignoreCallbacks()) {
+ settings.onUnchecked.call(input);
+ module.trigger.change();
+ }
+ module.preventDefaultOnInputTarget();
+ },
+
+ indeterminate: function () {
+ if (module.should.allowIndeterminate()) {
+ module.debug('Checkbox is already indeterminate');
+
+ return;
+ }
+ module.debug('Making checkbox indeterminate');
+ module.set.indeterminate();
+ if (!module.should.ignoreCallbacks()) {
+ settings.onIndeterminate.call(input);
+ module.trigger.change();
+ }
+ },
+
+ determinate: function () {
+ if (module.should.allowDeterminate()) {
+ module.debug('Checkbox is already determinate');
+
+ return;
+ }
+ module.debug('Making checkbox determinate');
+ module.set.determinate();
+ if (!module.should.ignoreCallbacks()) {
+ settings.onDeterminate.call(input);
+ module.trigger.change();
+ }
+ },
+
+ enable: function () {
+ if (module.is.enabled()) {
+ module.debug('Checkbox is already enabled');
+
+ return;
+ }
+ module.debug('Enabling checkbox');
+ module.set.enabled();
+ if (!module.should.ignoreCallbacks()) {
+ settings.onEnable.call(input);
+ // preserve legacy callbacks
+ settings.onEnabled.call(input);
+ }
+ },
+
+ disable: function () {
+ if (module.is.disabled()) {
+ module.debug('Checkbox is already disabled');
+
+ return;
+ }
+ module.debug('Disabling checkbox');
+ module.set.disabled();
+ if (!module.should.ignoreCallbacks()) {
+ settings.onDisable.call(input);
+ // preserve legacy callbacks
+ settings.onDisabled.call(input);
+ }
+ },
+
+ get: {
+ radios: function () {
+ var
+ name = module.get.name()
+ ;
+
+ return $('input[name="' + name + '"]').closest(selector.checkbox);
+ },
+ otherRadios: function () {
+ return module.get.radios().not($module);
+ },
+ name: function () {
+ return $input.attr('name');
+ },
+ },
+
+ is: {
+ initialLoad: function () {
+ return initialLoad;
+ },
+ radio: function () {
+ return $input.hasClass(className.radio) || $input.attr('type') === 'radio';
+ },
+ indeterminate: function () {
+ return $input.prop('indeterminate') !== undefined && $input.prop('indeterminate');
+ },
+ checked: function () {
+ return $input.prop('checked') !== undefined && $input.prop('checked');
+ },
+ disabled: function () {
+ return $input.prop('disabled') !== undefined && $input.prop('disabled');
+ },
+ enabled: function () {
+ return !module.is.disabled();
+ },
+ determinate: function () {
+ return !module.is.indeterminate();
+ },
+ unchecked: function () {
+ return !module.is.checked();
+ },
+ },
+
+ should: {
+ allowCheck: function () {
+ if (module.is.determinate() && module.is.checked() && !module.is.initialLoad()) {
+ module.debug('Should not allow check, checkbox is already checked');
+
+ return false;
+ }
+ if (!module.should.ignoreCallbacks() && settings.beforeChecked.apply(input) === false) {
+ module.debug('Should not allow check, beforeChecked cancelled');
+
+ return false;
+ }
+
+ return true;
+ },
+ allowUncheck: function () {
+ if (module.is.determinate() && module.is.unchecked() && !module.is.initialLoad()) {
+ module.debug('Should not allow uncheck, checkbox is already unchecked');
+
+ return false;
+ }
+ if (!module.should.ignoreCallbacks() && settings.beforeUnchecked.apply(input) === false) {
+ module.debug('Should not allow uncheck, beforeUnchecked cancelled');
+
+ return false;
+ }
+
+ return true;
+ },
+ allowIndeterminate: function () {
+ if (module.is.indeterminate() && !module.is.initialLoad()) {
+ module.debug('Should not allow indeterminate, checkbox is already indeterminate');
+
+ return false;
+ }
+ if (!module.should.ignoreCallbacks() && settings.beforeIndeterminate.apply(input) === false) {
+ module.debug('Should not allow indeterminate, beforeIndeterminate cancelled');
+
+ return false;
+ }
+
+ return true;
+ },
+ allowDeterminate: function () {
+ if (module.is.determinate() && !module.is.initialLoad()) {
+ module.debug('Should not allow determinate, checkbox is already determinate');
+
+ return false;
+ }
+ if (!module.should.ignoreCallbacks() && settings.beforeDeterminate.apply(input) === false) {
+ module.debug('Should not allow determinate, beforeDeterminate cancelled');
+
+ return false;
+ }
+
+ return true;
+ },
+ ignoreCallbacks: function () {
+ return initialLoad && !settings.fireOnInit;
+ },
+ },
+
+ can: {
+ change: function () {
+ return !($module.hasClass(className.disabled) || $module.hasClass(className.readOnly) || $input.prop('disabled') || $input.prop('readonly'));
+ },
+ uncheck: function () {
+ return typeof settings.uncheckable === 'boolean'
+ ? settings.uncheckable
+ : !module.is.radio();
+ },
+ },
+
+ set: {
+ initialLoad: function () {
+ initialLoad = true;
+ },
+ checked: function () {
+ module.verbose('Setting class to checked');
+ $module
+ .removeClass(className.indeterminate)
+ .addClass(className.checked)
+ ;
+ if (module.is.radio()) {
+ module.uncheckOthers();
+ }
+ if (!module.is.indeterminate() && module.is.checked()) {
+ module.debug('Input is already checked, skipping input property change');
+
+ return;
+ }
+ module.verbose('Setting state to checked', input);
+ $input
+ .prop('indeterminate', false)
+ .prop('checked', true)
+ ;
+ },
+ unchecked: function () {
+ module.verbose('Removing checked class');
+ $module
+ .removeClass(className.indeterminate)
+ .removeClass(className.checked)
+ ;
+ if (!module.is.indeterminate() && module.is.unchecked()) {
+ module.debug('Input is already unchecked');
+
+ return;
+ }
+ module.debug('Setting state to unchecked');
+ $input
+ .prop('indeterminate', false)
+ .prop('checked', false)
+ ;
+ },
+ indeterminate: function () {
+ module.verbose('Setting class to indeterminate');
+ $module
+ .addClass(className.indeterminate)
+ ;
+ if (module.is.indeterminate()) {
+ module.debug('Input is already indeterminate, skipping input property change');
+
+ return;
+ }
+ module.debug('Setting state to indeterminate');
+ $input
+ .prop('indeterminate', true)
+ ;
+ },
+ determinate: function () {
+ module.verbose('Removing indeterminate class');
+ $module
+ .removeClass(className.indeterminate)
+ ;
+ if (module.is.determinate()) {
+ module.debug('Input is already determinate, skipping input property change');
+
+ return;
+ }
+ module.debug('Setting state to determinate');
+ $input
+ .prop('indeterminate', false)
+ ;
+ },
+ disabled: function () {
+ module.verbose('Setting class to disabled');
+ $module
+ .addClass(className.disabled)
+ ;
+ if (module.is.disabled()) {
+ module.debug('Input is already disabled, skipping input property change');
+
+ return;
+ }
+ module.debug('Setting state to disabled');
+ $input
+ .prop('disabled', 'disabled')
+ ;
+ },
+ enabled: function () {
+ module.verbose('Removing disabled class');
+ $module.removeClass(className.disabled);
+ if (module.is.enabled()) {
+ module.debug('Input is already enabled, skipping input property change');
+
+ return;
+ }
+ module.debug('Setting state to enabled');
+ $input
+ .prop('disabled', false)
+ ;
+ },
+ tabbable: function () {
+ module.verbose('Adding tabindex to checkbox');
+ if ($input.attr('tabindex') === undefined) {
+ $input.attr('tabindex', 0);
+ }
+ },
+ },
+
+ remove: {
+ initialLoad: function () {
+ initialLoad = false;
+ },
+ },
+
+ trigger: {
+ change: function () {
+ var
+ inputElement = $input[0]
+ ;
+ if (inputElement) {
+ var events = document.createEvent('HTMLEvents');
+ module.verbose('Triggering native change event');
+ events.initEvent('change', true, false);
+ inputElement.dispatchEvent(events);
+ }
+ },
+ },
+
+ create: {
+ label: function () {
+ if ($input.prevAll(selector.label).length > 0) {
+ $input.prev(selector.label).detach().insertAfter($input);
+ module.debug('Moving existing label', $label);
+ } else if (!module.has.label()) {
+ $label = $('