beyond-rails 0.0.217 → 0.0.222

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: dc8e595696f351d27825c440fc48825dc0360b4a0aeeb23d8ff88f51d70e7794
4
- data.tar.gz: f65dc6990f6962438dc867f2eb6f29f50658f8ac474b52cb13765621ffbf358a
3
+ metadata.gz: 9092f0bac590910c0f6c461a47857ad83cb7efacb67586997817cae359792141
4
+ data.tar.gz: 0ad899417aab8fc983e7757fbb10d92a0716b73b71336dd676a113409c88adb8
5
5
  SHA512:
6
- metadata.gz: d5b3863f1fd9a07e8ccc2c086c5ca2292e9c40a2e40fbd860935dbff10378f3421d7294be5557c894affae7a5f665a63b1bf4a11de0dfc5549174b9947a58a08
7
- data.tar.gz: f5319191d5a32812c4a18ecd28e1bce0d56fa1f16c69f72c7db633d805d1a61edc6fad8b589658f61e8bd604882704ec1e6d589e6ea9faf11ceadf0469f11ddc
6
+ metadata.gz: 52d4d14acf31d6bd983bb790129edfb3be544f2d65614ec9c0939ec3935f74e132422529a9a6e4e1cc3da8075b76089c96168782c8a0feb005d8e35118aa4385
7
+ data.tar.gz: 0f1a43fb0eec229837bd6626baac37af0a6b6ccd9a5857475d9198610006df39782856c2cdfde45af9781a6fcbdc32cf935ab22ed105b2f07cc782d5b3d53e18
@@ -49,7 +49,19 @@ export default class Modal {
49
49
  this.modal = this.dom
50
50
  }
51
51
 
52
+ triggerShowEventIfNeeded() {
53
+ if (typeof $ === 'function') {
54
+ $(this.dom).trigger('beyond.modal.show')
55
+ }
56
+ }
57
+
52
58
  show(html) {
59
+
60
+ if (this.isVisible && html) {
61
+ this.replace(html)
62
+ return this.triggerShowEventIfNeeded()
63
+ }
64
+
53
65
  if (html) {
54
66
  this.replace(html)
55
67
  }
@@ -57,9 +69,7 @@ export default class Modal {
57
69
  this.modal.style.display = 'block'
58
70
  setTimeout(() => {
59
71
  this.modal.classList.add('js-active')
60
- if (typeof $ === 'function') {
61
- $(this.dom).trigger('beyond.modal.show')
62
- }
72
+ this.triggerShowEventIfNeeded()
63
73
  }, 50)
64
74
  }
65
75
 
@@ -27,6 +27,16 @@ import Tooltip from './components/Tooltip'
27
27
  import bind from './utils/bind'
28
28
  import docReady from './utils/docReady'
29
29
  import unbindAll from './utils/unbindAll'
30
+ import {
31
+ $,
32
+ $$,
33
+ allOff,
34
+ load,
35
+ on,
36
+ onload,
37
+ onunload,
38
+ unload
39
+ } from './utils/dom'
30
40
 
31
41
  export {
32
42
  Alert,
@@ -49,7 +59,15 @@ export {
49
59
  Timepicker,
50
60
  Toast,
51
61
  Tooltip,
62
+ $,
63
+ $$,
52
64
  bind,
65
+ allOff,
53
66
  docReady,
54
- unbindAll
67
+ load,
68
+ on,
69
+ onload,
70
+ onunload,
71
+ unbindAll,
72
+ unload
55
73
  }
@@ -0,0 +1,56 @@
1
+ const offFns = []
2
+ const loadRows = []
3
+ const unloadRows = []
4
+
5
+ const onPage = row => {
6
+ const { controller, action } = row
7
+ const { dataset } = document.body
8
+ return (dataset.controller === controller) && (dataset.action === action)
9
+ }
10
+
11
+ export const $ = (selector, dom = document) => dom.querySelector(selector)
12
+
13
+ export const $$ = (selector, dom = document) => Array.from(dom.querySelectorAll(selector))
14
+
15
+ export const on = (dom, event, cb, useCapture = false) => {
16
+ dom.addEventListener(event, cb, useCapture)
17
+ const off = () => dom.removeEventListener(event, cb, useCapture)
18
+ offFns.push(off)
19
+
20
+ return () => {
21
+ const index = offFns.findIndex(fn => fn === off)
22
+ if (index !== -1) {
23
+ offFns.splice(index, 1)
24
+ }
25
+ off()
26
+ }
27
+ }
28
+
29
+ export const allOff = () => {
30
+ offFns.forEach(fn => fn())
31
+ offFns.length = 0
32
+ }
33
+
34
+ export const onload = (controller, action, fn) => {
35
+ loadRows.push({ controller, action, fn })
36
+ }
37
+
38
+ export const load = () => {
39
+ loadRows.forEach(row => {
40
+ if (onPage(row)) {
41
+ row.fn()
42
+ }
43
+ })
44
+ }
45
+
46
+ export const onunload = (controller, action, fn) => {
47
+ unloadRows.push({ controller, action, fn })
48
+ }
49
+
50
+ export const unload = () => {
51
+ unloadRows.forEach(row => {
52
+ if (onPage(row)) {
53
+ row.fn()
54
+ }
55
+ })
56
+ }
@@ -90,27 +90,27 @@
90
90
 
91
91
  .#{$classname} {
92
92
  @if $side == '' {
93
- #{$prop}: $space;
93
+ #{$prop}: $space !important;
94
94
  }
95
95
  @else if $side == 't' {
96
- #{$prop}-top: $space;
96
+ #{$prop}-top: $space !important;
97
97
  }
98
98
  @else if $side == 'b' {
99
- #{$prop}-bottom: $space;
99
+ #{$prop}-bottom: $space !important;
100
100
  }
101
101
  @else if $side == 'l' {
102
- #{$prop}-left: $space;
102
+ #{$prop}-left: $space !important;
103
103
  }
104
104
  @else if $side == 'r' {
105
- #{$prop}-right: $space;
105
+ #{$prop}-right: $space !important;
106
106
  }
107
107
  @else if $side == 'x' {
108
- #{$prop}-left: $space;
109
- #{$prop}-right: $space;
108
+ #{$prop}-left: $space !important;
109
+ #{$prop}-right: $space !important;
110
110
  }
111
111
  @else if $side == 'y' {
112
- #{$prop}-top: $space;
113
- #{$prop}-bottom: $space;
112
+ #{$prop}-top: $space !important;
113
+ #{$prop}-bottom: $space !important;
114
114
  }
115
115
  @else {
116
116
  @error "Unknown side #{$side}.";
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: beyond-rails
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.217
4
+ version: 0.0.222
5
5
  platform: ruby
6
6
  authors:
7
7
  - kmsheng
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2020-09-30 00:00:00.000000000 Z
12
+ date: 2020-10-07 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: sassc
@@ -173,6 +173,7 @@ files:
173
173
  - src/js/utils/dateGt.js
174
174
  - src/js/utils/dateLt.js
175
175
  - src/js/utils/docReady.js
176
+ - src/js/utils/dom.js
176
177
  - src/js/utils/domEval.js
177
178
  - src/js/utils/getFloatedTargetPos.js
178
179
  - src/js/utils/getKey.js