middleman-favicon-maker 3.4.1 → 3.5

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: 4ea8530b747f81bb37285af745a28e9afbbf6839
4
- data.tar.gz: 2fda3e341b19b0e4641ca26126c37bcfa8b33c65
3
+ metadata.gz: 9fa52aace31c3229aadff949f52cba09aac233f8
4
+ data.tar.gz: c04dc678fcf570072041acd4776778a48ff691f4
5
5
  SHA512:
6
- metadata.gz: ee2937349abc27e83d203ea5cde1613d64b2a1f97c24b6cb4e8d9963ed2cc40143690fb00888ae67590ff2a9727ec8dc984280dbb4bc27ddced0a89b96493753
7
- data.tar.gz: f9e07b9ec637f2d0f44c44216befadc282e590cdb3ac03dca7e909e64cb279f1e7e2ff6d9889784e9b1ed6a53f01a247966d0345b42c739e87d017a4197750c1
6
+ metadata.gz: 4225513d005709c6e3854e18f1795790801dbe3ee80a61c5dc0fe8b9cff8e545e13c5b77e4b04a4ee45bbd177571a73ef66d967f498f7db82bffa25eccab3aeb
7
+ data.tar.gz: fae09d7a7d7599a58724c4168127a6d03e71f172f9265dac5edbb3fa13c3f859f63b02c14e71e69f0d98674c0a341e3a15960836135a6c56fa0d616a70fc392f
data/LICENSE CHANGED
@@ -1,4 +1,4 @@
1
- Copyright (c) 2012 Kematzy, Andreas Follmann, Thomas Reynolds
1
+ Copyright (c) 2012-2014 Andreas Follmann, Thomas Reynolds
2
2
 
3
3
  Permission is hereby granted, free of charge, to any person obtaining
4
4
  a copy of this software and associated documentation files (the
data/README.md CHANGED
@@ -12,68 +12,61 @@ Before you can use FaviconMaker, you need to install [ImageMagick](http://www.im
12
12
  brew install imagemagick
13
13
  ```
14
14
 
15
- ### Using Bundler (recommended)
15
+ ### Using Bundler
16
16
 
17
17
  ``` ruby
18
- gem "middleman-favicon-maker", "~> 3.2"
18
+ gem "middleman-favicon-maker", "~> 3.5"
19
19
  ```
20
20
 
21
21
  If you're using Middleman version 2.x, use version 0.0.6 of middleman-favicon-maker.
22
22
 
23
- ### Standalone
24
-
25
- ``` shell
26
- gem install middleman-favicon-maker
27
- ```
28
-
29
23
  ## Integrating with Middleman
30
24
 
31
- Create a favicon_base.png image and place it in your source directory. Ideally, this image's dimensions would be 144 x 144. In config.rb, extend the `configure :build` block:
25
+ Create a favicon_template.png image and place it in your source directory. Ideally, this image's dimensions would be 152 x 152. In config.rb, extend the `configure :build` block:
26
+
27
+ ### Simple config
28
+ This config assumes that a PNG file named favicon_template.png lives in the source folder. The generated icons are stored in the build folder root.
32
29
 
33
30
  ``` ruby
34
31
  configure :build do
35
32
  ...
36
- activate :favicon_maker
33
+ activate :favicon_maker, :icons => {
34
+ "favicon_template.png" => [
35
+ { icon: "apple-touch-icon-152x152-precomposed.png" },
36
+ { icon: "apple-touch-icon-114x114-precomposed.png" },
37
+ { icon: "apple-touch-icon-72x72-precomposed.png" },
38
+ ]
39
+ }
37
40
  ...
38
41
  end
39
42
  ```
40
43
 
41
- When you build your Middleman project, middleman-favicon-maker will generate the following files in your build directory:
42
-
43
- * apple-touch-icon-144x144-precomposed.png
44
- * apple-touch-icon-120x120-precomposed.png
45
- * apple-touch-icon-114x114-precomposed.png
46
- * apple-touch-icon-72x72-precomposed.png
47
- * apple-touch-icon-57x57-precomposed.png
48
- * apple-touch-icon-precomposed.png
49
- * apple-touch-icon.png
50
- * favicon.ico
51
- * favicon.png
52
-
53
- The base image will not be copied into the build folder.
54
-
55
- ## Customizing middleman-favicon-maker
56
-
57
- Version 3.x of this gem uses the `favicon_maker_` prefix for configuration options to be consistent with the activation keyword `:favicon_maker`. Previously the `favicon_` prefix was used.
58
-
59
- You can set the following options for middleman-favicon-maker:
60
-
61
- ``` ruby
62
- :favicon_maker_root_dir # default: app.root
63
- :favicon_maker_input_dir # default: app.views -> source/
64
- :favicon_maker_output_dir # default: app.build_dir -> build/
65
- :favicon_maker_base_image # default: "favicon_base.png"
66
- :favicon_maker_versions # default: [ :fav_png, :fav_ico ]
67
- :favicon_maker_custom_versions # default: {}
68
- ```
69
-
70
- For example:
44
+ ### Advanced config
45
+ Using all configuration options. The template_dir/output_dir require absolute paths. You can use multiple template files that suit the different resolutions better. ```format``` and ```size``` are optional and only required when the size of the icon and/or the file format is not encoded in the filename. Multiple resolutions in one file is only supported for the .ico format.
71
46
 
72
47
  ``` ruby
73
- activate :favicon_maker,
74
- :favicon_maker_input_dir =>"favicons"
75
- :favicon_maker_custom_versions => {:apple_extreme_retina => {:filename => "apple-touch-icon-228x228-precomposed.png", :dimensions => "228x228", :format => "png"}}
48
+ configure :build do
49
+ ...
50
+ activate :favicon_maker do |f|
51
+ f.template_dir = File.join(root, 'source')
52
+ f.output_dir = File.join(root, 'build')
53
+ f.icons = {
54
+ "favicon_template_hires.png" => [
55
+ { icon: "apple-touch-icon-152x152-precomposed.png" },
56
+ { icon: "apple-touch-icon-114x114-precomposed.png" },
57
+ { icon: "apple-touch-icon-72x72-precomposed.png" },
58
+ { icon: "mstile-144x144", format: :png },
59
+ ],
60
+ "favicon_template_lores.png" => [
61
+ { icon: "favicon.png", size: "16x16" },
62
+ { icon: "favicon.ico", size: "64x64,32x32,24x24,16x16" },
63
+ ]
64
+ }
65
+ end
66
+ ...
67
+ end
76
68
  ```
69
+ The template images are deleted from the build folder (Middleman copies them) after all icons have been generated.
77
70
 
78
71
  ## Markup meta links
79
72
 
@@ -93,6 +86,7 @@ Specifying meta links is only necessary if you want to support non-iOS devices.
93
86
  ### HAML
94
87
 
95
88
  ``` haml
89
+ %link{ rel: "apple-touch-icon", sizes: "152x152", href: "apple-touch-icon-144x144-precomposed.png" }
96
90
  %link{ rel: "apple-touch-icon", sizes: "144x144", href: "apple-touch-icon-144x144-precomposed.png" }
97
91
  %link{ rel: "apple-touch-icon", sizes: "114x114", href: "apple-touch-icon-114x114-precomposed.png" }
98
92
  %link{ rel: "apple-touch-icon", sizes: "72x72", href: "apple-touch-icon-72x72-precomposed.png" }
@@ -103,4 +97,4 @@ Specifying meta links is only necessary if you want to support non-iOS devices.
103
97
 
104
98
  ## Copyright
105
99
 
106
- © 2011-2013 Andreas Follmann. See LICENSE for details.
100
+ © 2011-2014 Andreas Follmann. See LICENSE for details.
@@ -1,43 +1,46 @@
1
+ require "favicon_maker"
2
+
1
3
  module Middleman
2
4
  module FaviconMaker
3
- class << self
4
- def registered(app, options={})
5
- require "favicon_maker"
6
-
7
- options[:favicon_maker_root_dir] ||= ''
8
- options[:favicon_maker_input_dir] ||= ''
9
- options[:favicon_maker_output_dir] ||= ''
10
- options[:favicon_maker_base_image] ||= 'favicon_base.png'
11
- options[:favicon_maker_versions] ||= [ :fav_png, :fav_ico ]
12
- options[:favicon_maker_custom_versions] ||= {}
13
-
14
- app.after_configuration do
15
- # configs are either default or set by user in config.rb
16
- # due to Middleman extension limitations, we need to ensure they are sane
17
- # before we continue
18
- options[:favicon_maker_root_dir] = root if options[:favicon_maker_root_dir].empty?
19
- options[:favicon_maker_input_dir] = source if options[:favicon_maker_input_dir].empty?
20
- options[:favicon_maker_output_dir] = build_dir if options[:favicon_maker_output_dir].empty?
21
- end
5
+ class FaviconMakerExtension < Extension
6
+
7
+ option :template_dir, nil, "Template dir for icon templates"
8
+ option :output_dir, nil, "Output dir for generated icons"
9
+ option :icons, {}, "Hash with template filename (key) and Array of Hashes with icon configs"
10
+
11
+ def after_configuration
12
+ options[:template_dir] ||= File.join(app.root, app.settings[:source]) if options[:template_dir].nil?
13
+ options[:output_dir] ||= File.join(app.root, app.settings[:build_dir]) if options[:output_dir].nil?
14
+ end
15
+
16
+ def after_build(builder)
22
17
 
23
- app.after_build do |builder|
24
- ::FaviconMaker::Generator.create_versions({
25
- :root_dir => options[:favicon_maker_root_dir],
26
- :input_dir => options[:favicon_maker_input_dir],
27
- :output_dir => options[:favicon_maker_output_dir],
28
- :base_image => options[:favicon_maker_base_image],
29
- :versions => options[:favicon_maker_versions],
30
- :custom_versions => options[:favicon_maker_custom_versions],
31
- :copy => true
32
- }) do |f, status|
33
- builder.say_status status, f.gsub(root + "/", "")
18
+ template_files = []
19
+ ::FaviconMaker.generate do
20
+ setup do
21
+ template_dir options[:template_dir]
22
+ output_dir options[:output_dir]
34
23
  end
35
24
 
36
- # remove favicon_base_image from the build dir
37
- builder.remove_file File.join(options[:favicon_maker_root_dir], options[:favicon_maker_output_dir], options[:favicon_maker_base_image])
25
+ options[:icons].each do |input_filename, icon_configs|
26
+ from input_filename do
27
+ icon_configs.each do |icon_config|
28
+ icon icon_config.delete(:icon), icon_config
29
+ end
30
+ end
31
+ end
32
+
33
+ each_icon do |filepath, template_filepath|
34
+ builder.say_status :generate, filepath.gsub(options[:output_dir] + "/", "")
35
+ template_files << template_filepath
36
+ end
38
37
  end
38
+
39
+ template_files.uniq.each do |template_filepath|
40
+ builder.remove_file template_filepath.gsub(options[:template_dir], options[:output_dir])
41
+ end
42
+
39
43
  end
40
- alias :included :registered
41
44
  end
42
45
  end
43
- end
46
+ end
@@ -1,8 +1,8 @@
1
1
  module Middleman
2
2
  module FaviconMaker
3
3
  MAJOR = 3
4
- MINOR = 4
5
- PATCH = 1
4
+ MINOR = 5
5
+ PATCH = nil
6
6
  BUILD = nil
7
7
 
8
8
  VERSION = [MAJOR, MINOR, PATCH, BUILD].compact.join('.')
@@ -1,6 +1,8 @@
1
1
  require "middleman-core"
2
+ require "middleman-favicon-maker/version"
2
3
 
3
4
  ::Middleman::Extensions.register(:favicon_maker) do
4
5
  require "middleman-favicon-maker/extension"
5
- ::Middleman::FaviconMaker
6
- end
6
+ ::Middleman::FaviconMaker::FaviconMakerExtension
7
+ end
8
+
@@ -7,7 +7,7 @@ Gem::Specification.new do |gem|
7
7
  gem.email = ["hello@toyrocketscience.com"]
8
8
  gem.version = Middleman::FaviconMaker::VERSION
9
9
  gem.platform = Gem::Platform::RUBY
10
- gem.authors = ["Andreas Follmann", "Kematzy"]
10
+ gem.authors = ["Andreas Follmann"]
11
11
  gem.email = ["andreas@toyrocketscience.com"]
12
12
  gem.homepage = "https://github.com/follmann/middleman-favicon-maker"
13
13
  gem.summary = %q{Generate favicon files in various sizes from a base image in your Middleman project}
@@ -20,5 +20,5 @@ Gem::Specification.new do |gem|
20
20
 
21
21
  # Additional dependencies
22
22
  gem.add_runtime_dependency("middleman-core", [">= 3.0.0"])
23
- gem.add_runtime_dependency("favicon_maker", ["~> 0.3"])
23
+ gem.add_runtime_dependency("favicon_maker", ["~> 1.0"])
24
24
  end
metadata CHANGED
@@ -1,15 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: middleman-favicon-maker
3
3
  version: !ruby/object:Gem::Version
4
- version: 3.4.1
4
+ version: '3.5'
5
5
  platform: ruby
6
6
  authors:
7
7
  - Andreas Follmann
8
- - Kematzy
9
8
  autorequire:
10
9
  bindir: bin
11
10
  cert_chain: []
12
- date: 2014-01-09 00:00:00.000000000 Z
11
+ date: 2014-01-12 00:00:00.000000000 Z
13
12
  dependencies:
14
13
  - !ruby/object:Gem::Dependency
15
14
  name: middleman-core
@@ -31,14 +30,14 @@ dependencies:
31
30
  requirements:
32
31
  - - ~>
33
32
  - !ruby/object:Gem::Version
34
- version: '0.3'
33
+ version: '1.0'
35
34
  type: :runtime
36
35
  prerelease: false
37
36
  version_requirements: !ruby/object:Gem::Requirement
38
37
  requirements:
39
38
  - - ~>
40
39
  - !ruby/object:Gem::Version
41
- version: '0.3'
40
+ version: '1.0'
42
41
  description: Generate favicon files in various sizes from a base image in your Middleman
43
42
  project
44
43
  email:
@@ -55,7 +54,6 @@ files:
55
54
  - lib/middleman-favicon-maker.rb
56
55
  - lib/middleman-favicon-maker/extension.rb
57
56
  - lib/middleman-favicon-maker/version.rb
58
- - lib/middleman_extension.rb
59
57
  - middleman-favicon-maker.gemspec
60
58
  - test/helper.rb
61
59
  - test/test_middleman-favicon-maker.rb
@@ -1 +0,0 @@
1
- require "middleman-favicon-maker"