aboutsummaryrefslogtreecommitdiff
path: root/js/src
diff options
context:
space:
mode:
authorfat <[email protected]>2015-05-07 17:07:38 -0700
committerfat <[email protected]>2015-05-07 17:14:38 -0700
commit660505188241418ffda53b5eb848defecd5f57e1 (patch)
treeec0895cb5267cc798f386f96caca653a7fe191f1 /js/src
parentc3a79b1a8c2fa8d7fc8edcd3e626dad8b45d5dc3 (diff)
downloadbootstrap-660505188241418ffda53b5eb848defecd5f57e1.tar.xz
bootstrap-660505188241418ffda53b5eb848defecd5f57e1.zip
button -> es6
Diffstat (limited to 'js/src')
-rw-r--r--js/src/alert.js8
-rw-r--r--js/src/button.js158
-rw-r--r--js/src/util.js4
3 files changed, 165 insertions, 5 deletions
diff --git a/js/src/alert.js b/js/src/alert.js
index d69ad8910..67a1ceda4 100644
--- a/js/src/alert.js
+++ b/js/src/alert.js
@@ -8,7 +8,7 @@ import Util from './util'
* --------------------------------------------------------------------------
*/
-const Alert = (() => {
+const Alert = (($) => {
/**
@@ -58,6 +58,8 @@ const Alert = (() => {
// public
close(element) {
+ element = element || this.element
+
let rootElement = this._getRootElement(element)
let customEvent = this._triggerCloseEvent(rootElement)
@@ -167,12 +169,12 @@ const Alert = (() => {
$.fn[NAME] = Alert._jQueryInterface
$.fn[NAME].Constructor = Alert
$.fn[NAME].noConflict = function () {
- $.fn[NAME] = Alert._JQUERY_NO_CONFLICT
+ $.fn[NAME] = JQUERY_NO_CONFLICT
return Alert._jQueryInterface
}
return Alert
-})()
+})(jQuery)
export default Alert
diff --git a/js/src/button.js b/js/src/button.js
new file mode 100644
index 000000000..7e9344923
--- /dev/null
+++ b/js/src/button.js
@@ -0,0 +1,158 @@
+/**
+ * --------------------------------------------------------------------------
+ * Bootstrap (v4.0.0): button.js
+ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
+ * --------------------------------------------------------------------------
+ */
+
+const Button = (($) => {
+
+
+ /**
+ * ------------------------------------------------------------------------
+ * Constants
+ * ------------------------------------------------------------------------
+ */
+
+ const NAME = 'button'
+ const VERSION = '4.0.0'
+ const DATA_KEY = 'bs.button'
+ const JQUERY_NO_CONFLICT = $.fn[NAME]
+ const TRANSITION_DURATION = 150
+
+ const ClassName = {
+ ACTIVE : 'active',
+ BUTTON : 'btn',
+ FOCUS : 'focus'
+ }
+
+ const Selector = {
+ DATA_TOGGLE_CARROT : '[data-toggle^="button"]',
+ DATA_TOGGLE : '[data-toggle="buttons"]',
+ INPUT : 'input',
+ ACTIVE : '.active',
+ BUTTON : '.btn'
+ }
+
+ const Event = {
+ CLICK : 'click.bs.button.data-api',
+ FOCUS_BLUR : 'focus.bs.button.data-api blur.bs.button.data-api'
+ }
+
+
+ /**
+ * ------------------------------------------------------------------------
+ * Class Definition
+ * ------------------------------------------------------------------------
+ */
+
+ class Button {
+
+ constructor(element) {
+ this.element = element
+ }
+
+ // public
+
+ toggle() {
+ let triggerChangeEvent = true
+ let rootElement = $(this.element).closest(
+ Selector.DATA_TOGGLE
+ )[0]
+
+ if (rootElement) {
+ let input = $(this.element).find(Selector.INPUT)[0]
+
+ if (input) {
+ if (input.type === 'radio') {
+ if (input.checked &&
+ $(this.element).hasClass(ClassName.ACTIVE)) {
+ triggerChangeEvent = false
+
+ } else {
+ let activeElement = $(rootElement).find(Selector.ACTIVE)[0]
+
+ if (activeElement) {
+ $(activeElement).removeClass(ClassName.ACTIVE)
+ }
+ }
+ }
+
+ if (triggerChangeEvent) {
+ input.checked = !$(this.element).hasClass(ClassName.ACTIVE)
+ $(this.element).trigger('change')
+ }
+ }
+ } else {
+ this.element.setAttribute('aria-pressed',
+ !$(this.element).hasClass(ClassName.ACTIVE))
+ }
+
+ if (triggerChangeEvent) {
+ $(this.element).toggleClass(ClassName.ACTIVE)
+ }
+ }
+
+
+ // static
+
+ static _jQueryInterface(config) {
+ return this.each(function () {
+ let data = $(this).data(DATA_KEY)
+
+ if (!data) {
+ data = new Button(this)
+ $(this).data(DATA_KEY, data)
+ }
+
+ if (config === 'toggle') {
+ data[config]()
+ }
+ })
+ }
+
+ }
+
+
+ /**
+ * ------------------------------------------------------------------------
+ * Data Api implementation
+ * ------------------------------------------------------------------------
+ */
+
+ $(document)
+ .on(Event.CLICK, Selector.DATA_TOGGLE_CARROT, function (event) {
+ event.preventDefault()
+
+ let button = event.target
+
+ if (!$(button).hasClass(ClassName.BUTTON)) {
+ button = $(button).closest(Selector.BUTTON)
+ }
+
+ Button._jQueryInterface.call($(button), 'toggle')
+ })
+ .on(Event.FOCUS_BLUR, Selector.DATA_TOGGLE_CARROT, function (event) {
+ var button = $(event.target).closest(Selector.BUTTON)[0]
+ $(button).toggleClass(ClassName.FOCUS, /^focus(in)?$/.test(event.type))
+ })
+
+
+ /**
+ * ------------------------------------------------------------------------
+ * jQuery
+ * ------------------------------------------------------------------------
+ */
+
+ $.fn[NAME] = Button._jQueryInterface
+ $.fn[NAME].Constructor = Button
+ $.fn[NAME].noConflict = function () {
+ $.fn[NAME] = JQUERY_NO_CONFLICT
+ return Button._jQueryInterface
+ }
+
+ return Button
+
+})(jQuery)
+
+export default Button
diff --git a/js/src/util.js b/js/src/util.js
index 68205edef..abc548a45 100644
--- a/js/src/util.js
+++ b/js/src/util.js
@@ -5,7 +5,7 @@
* --------------------------------------------------------------------------
*/
-const Util = (() => {
+const Util = (($) => {
/**
@@ -119,6 +119,6 @@ const Util = (() => {
return Util
-})()
+})(jQuery)
export default Util