server-generated-popups 1.1.10 → 1.3

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
  SHA1:
3
- metadata.gz: 81c141d306d989a9d4f5b84c0767257a36538e4d
4
- data.tar.gz: f0a9cb33e5732d2fbb76bdc684447ca99cf95b2c
3
+ metadata.gz: 630076eed1bfc318b8f21bbe7abdb617215718f8
4
+ data.tar.gz: 15a315841849ed114576e9d8ef0bf77f23c76d7d
5
5
  SHA512:
6
- metadata.gz: 5d24a6db486a9e6d4ee8103b9b3a0efbe7bbb7db897fb15f15699678c3f1db26de29c5b97f85d2b990f2183893781ad5418ec008319a2276c4992e9cd76b3651
7
- data.tar.gz: 4da2429b2ec4167f5bc717c69cda86a653add8642218d0c3fb66977052ae7a2a1f1dd27232c03e2dba7a612d9398d0f1bc85ed53eee8904ebab740bbee1e0f28
6
+ metadata.gz: 8b1fcbe381bfc849aca99927bb369016d90e92befac446a26206b9d0e4e294ac834a33b7bbf88835eb0027c6badeff7a7b77b93f31b3dc6d6d79b9498d7b9400
7
+ data.tar.gz: 5435ad2604d88da62802e6022d0cd7bb3c6d8f564d41a483220baab5538e5eb3b2e22a6639ceac7bb213c79b7127e5e9d1274050879e78265e62224a13849702
data/README.md CHANGED
@@ -1,7 +1,8 @@
1
- You need to briefly show something to the user. You decide on a popup. You look at your options: `window.open()` is easy, but is blocked by the browser when called not in a `click` handler; JavaScript plugins are over-engineered and want you to create dedicated routes, hidden links or embed your content where it doesn't belong just to accomodate them. Oh boy. Does it have to be that bad? No.
1
+ Have a controller action that's supposed to respond by showing a [modal dialog](https://en.wikipedia.org/wiki/Modal_window)?
2
2
 
3
- Now you can do this:
3
+ Now you can do it like this:
4
4
 
5
+ <sub>views/invoices/show.js.erb<sub>
5
6
  ```javascript
6
7
  Popup("<%=j render @invoice %>").show('up')
7
8
  ```
@@ -10,11 +11,13 @@ Popup("<%=j render @invoice %>").show('up')
10
11
 
11
12
  Animations, styles — all included. One line gets you a fully working solution.
12
13
 
13
- Perfect with [Server-generated JavaScript Responses](https://signalvnoise.com/posts/3697-server-generated-javascript-responses) and [Turbolinks™](https://github.com/turbolinks/turbolinks), but not limited to them.
14
+ Perfect with Rails and its [Server-generated JavaScript Responses](https://signalvnoise.com/posts/3697-server-generated-javascript-responses), but not limited to them.
15
+
16
+ The screenshot above is from [Invoices for Milestones](http://invoicesformilestones.com), where this plugin is extracted from. Invoices for Milestones is a dead simple invoicing tool for self-employed. If you work for yourself, check it out.
14
17
 
15
18
  ## Installation
16
19
 
17
- The plugin depends on jQuery, but you already have it, do you?
20
+ The plugin depends on jQuery, but you already have it, don't you?
18
21
 
19
22
  ### Rails
20
23
 
@@ -26,7 +29,7 @@ Then `require popup` into both your styleheet and javascript files.
26
29
 
27
30
  ### Any framework
28
31
 
29
- Download this repo. Grab `popup.js` and `popup.css` from the `assets` directory and put them wherever you put JS and CSS in your framework.
32
+ Download this repo. Grab `popup.js` and `popup.css` from the `assets` directory and put them wherever you put JS and CSS in your framework. Follow examples in the following section, they are written to apply to any web framework.
30
33
 
31
34
  ## Usage
32
35
 
@@ -55,13 +58,13 @@ popup.hide('down')
55
58
  ```
56
59
 
57
60
  <br>
58
- Override the width of a popup by passing the value in px:
61
+ Override the width of the popup by passing the value in px:
59
62
 
60
63
  ```javascript
61
64
  Popup("<div>Hello</div>", {width: 300})
62
65
  ```
63
66
 
64
- If you need to do something after the popup slides onto the screen — play an animation and attach a handler to the "Close" button — pass a second argument to the `show` method:
67
+ If you need to do something after the popup slides onto the screen — pass a second argument to the `show` method. Here I play an animation and attach a handler to the "Close" button:
65
68
 
66
69
  ```javascript
67
70
  editInvoiceDetails = Popup("<%=j render @invoice %>").show('up', function () {
@@ -73,7 +76,3 @@ editInvoiceDetails = Popup("<%=j render @invoice %>").show('up', function () {
73
76
  ```
74
77
 
75
78
  That's all I ever need from it. Do you need something else? Feel free to contribute.
76
-
77
- ## Credits
78
-
79
- The code and the animated demo were extracted from [Invoices for Milestones](http://invoicesformilestones.com), a dead simple invoicing tool for self-employed. If you work for yourself, check it out.
@@ -9,28 +9,60 @@ function PopupClass(html, options) {
9
9
  options = $.extend({}, {width: 300}, options || {})
10
10
  this.popupWindow.css({
11
11
  'width': options.width.toString() + 'px',
12
- 'margin-left': (options.width/2 * -1).toString() + 'px'
12
+ 'margin-left': (options.width/2 * -1).toString() + 'px',
13
+ 'padding': options.padding
13
14
  })
14
15
  this.popupWindow.append(contents)
16
+
17
+ this.createBackdrop()
15
18
  }
16
19
 
17
20
  PopupClass.prototype.distanceFromTop = function () {
18
21
  return ($(window).height() - this.popupWindow.height())/2
19
22
  }
20
- PopupClass.prototype.move = function (from, to, callback) {
23
+ PopupClass.prototype.translate = function (from, to, callback) {
21
24
  this.popupWindow.css('top', from)
22
25
  this.popupWindow.animate({top: to}, callback)
23
26
  }
24
27
 
25
- PopupClass.prototype.show = function (direction, callback) {
28
+ PopupClass.prototype.createBackdrop = function () {
29
+ this.backdrop = $('<div id="popup-backdrop"></div>')
30
+ $('body').append(this.backdrop)
31
+ }
32
+ PopupClass.prototype.showBackdrop = function () {
33
+ this.backdrop.css('opacity', 0.5)
34
+ }
35
+ PopupClass.prototype.hideBackdrop = function () {
36
+ this.backdrop.css('opacity', 0)
37
+ }
38
+ PopupClass.prototype.createCloseButton = function () {
39
+ closeButton = $('<div class="closeButton"></div>')
40
+ popupObject = this
41
+ closeButton.click(function () {
42
+ popupObject.hide('down')
43
+ })
44
+ this.popupWindow.append(closeButton)
45
+ }
46
+
47
+ PopupClass.prototype.show = function (direction, options) {
48
+ options = options || {}
49
+
26
50
  $('body').append(this.popupWindow)
27
- startFrom = (direction == 'up') ? '180%' : '-80%'
28
- this.move(startFrom, this.distanceFromTop(), callback)
29
- return this;
51
+ beyondScreen = (direction == 'up') ? '180%' : '-80%'
52
+ this.translate(beyondScreen, this.distanceFromTop(), options.callback)
53
+
54
+ if (options.backdrop)
55
+ this.showBackdrop()
56
+ if (options.closeButton)
57
+ this.createCloseButton()
58
+ return this
30
59
  }
60
+
31
61
  PopupClass.prototype.hide = function (direction) {
32
- moveTo = (direction == 'down') ? '180%' : '-80%'
33
- this.move(this.distanceFromTop(), moveTo, function () {
62
+ beyondScreen = (direction == 'down') ? '180%' : '-80%'
63
+ this.translate(this.distanceFromTop(), beyondScreen, function () {
34
64
  this.remove() // this == $('.popup') here
35
65
  })
66
+
67
+ this.hideBackdrop()
36
68
  }
@@ -5,6 +5,20 @@
5
5
  box-shadow: 0px 10px 20px rgba(0,0,0,0.3);
6
6
  }
7
7
 
8
- .invoice {
9
- padding: 10px;
8
+ #popup-backdrop {
9
+ position: fixed;
10
+ top: 0; left: 0; bottom: 0; right: 0;
11
+ background-color: black;
12
+
13
+ opacity: 0;
14
+ transition: opacity 0.3s linear;
15
+ }
16
+
17
+ .closeButton {
18
+ width: 16px; height: 16px;
19
+ top: 16px; right: 16px;
20
+
21
+ position: absolute;
22
+ cursor: pointer;
23
+ background: url('');
10
24
  }
data/demo/index.html ADDED
@@ -0,0 +1,18 @@
1
+ <html>
2
+ <head>
3
+ <title>popup.js</title>
4
+ <meta charset="UTF-8">
5
+ <script src="https://code.jquery.com/jquery-2.2.4.min.js"></script>
6
+ <link rel="stylesheet" type="text/css" href="../app/assets/stylesheets/popup.css">
7
+ <script src="../app/assets/javascripts/popup.js"></script>
8
+ </head>
9
+ <script type="text/javascript">
10
+ $(document).ready(function () {
11
+ popup = Popup("<h2>Hello</h2><p>Lorem ipsum</p>", {padding: '16px'})
12
+ popup.show('up', {backdrop: true, closeButton: true})
13
+ });
14
+ </script>
15
+ <body>
16
+
17
+ </body>
18
+ </html>
@@ -12,5 +12,7 @@ Gem::Specification.new do |gem|
12
12
  gem.test_files = gem.files.grep(%r{^(test|spec|features)/})
13
13
  gem.name = "server-generated-popups"
14
14
  gem.require_paths = ["lib"]
15
- gem.version = "1.1.10"
15
+ gem.version = "1.3"
16
+
17
+ gem.add_runtime_dependency 'jquery-rails'
16
18
  end
metadata CHANGED
@@ -1,15 +1,29 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: server-generated-popups
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.1.10
4
+ version: '1.3'
5
5
  platform: ruby
6
6
  authors:
7
7
  - Anton Khamets
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2016-07-21 00:00:00.000000000 Z
12
- dependencies: []
11
+ date: 2017-05-08 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: jquery-rails
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
13
27
  description:
14
28
  email:
15
29
  - colorfulfool@gmail.com
@@ -21,6 +35,7 @@ files:
21
35
  - README.md
22
36
  - app/assets/javascripts/popup.js
23
37
  - app/assets/stylesheets/popup.css
38
+ - demo/index.html
24
39
  - lib/server-generated-popups.rb
25
40
  - server-generated-popups.gemspec
26
41
  homepage: https://github.com/colorfulfool/rails-popup
@@ -42,7 +57,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
42
57
  version: '0'
43
58
  requirements: []
44
59
  rubyforge_project:
45
- rubygems_version: 2.5.1
60
+ rubygems_version: 2.4.8
46
61
  signing_key:
47
62
  specification_version: 4
48
63
  summary: Show a popup with one line of code. Perfect for format.js responses, and