fastlane-plugin-droidicon 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 782e653f46a90a50c51d0f1828136b9d797f9f14
4
+ data.tar.gz: 4ddd581eb0878b2977110f1eb951ed0c973d2321
5
+ SHA512:
6
+ metadata.gz: fdd8a0be8f5fe05717de18d0e80fd31259bd812165c671870ee2feecbacb7f20e6455fc398164938da4141d54ae809758cbd011165e159d6bf701d40cc0fe832
7
+ data.tar.gz: 9d6bfe925eb8d4ff92cd0673735ce8c8b26b1e7a0be5e0dcc85a7e9c4731f67ef76c2a07d1ff5b52c8c3c3035b291c87f20322b5cd5ab53fdddfbaeca9c322cd
data/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2016 chihiro hashimoto
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,52 @@
1
+ # droidicon plugin
2
+
3
+ [![fastlane Plugin Badge](https://rawcdn.githack.com/fastlane/fastlane/master/fastlane/assets/plugin-badge.svg)](https://rubygems.org/gems/fastlane-plugin-droidicon)
4
+
5
+ ## Getting Started
6
+
7
+ This project is a [fastlane](https://github.com/fastlane/fastlane) plugin. To get started with `fastlane-plugin-droidicon`, add it to your project by running:
8
+
9
+ ```bash
10
+ fastlane add_plugin droidicon
11
+ ```
12
+
13
+ ## About droidicon
14
+
15
+ Generate required icon sizes and iconset from a master application icon
16
+
17
+ **Note to author:** Add a more detailed description about this plugin here. If your plugin contains multiple actions, make sure to mention them here.
18
+
19
+ ## Example
20
+
21
+ Check out the [example `Fastfile`](fastlane/Fastfile) to see how to use this plugin. Try it by cloning the repo, running `fastlane install_plugins` and `bundle exec fastlane test`.
22
+
23
+ **Note to author:** Please set up a sample project to make it easy for users to explore what your plugin does. Provide everything that is necessary to try out the plugin in this project (including a sample Xcode/Android project if necessary)
24
+
25
+ ## Run tests for this plugin
26
+
27
+ To run both the tests, and code style validation, run
28
+
29
+ ```
30
+ rake
31
+ ```
32
+
33
+ To automatically fix many of the styling issues, use
34
+ ```
35
+ rubocop -a
36
+ ```
37
+
38
+ ## Issues and Feedback
39
+
40
+ For any other issues and feedback about this plugin, please submit it to this repository.
41
+
42
+ ## Troubleshooting
43
+
44
+ If you have trouble using plugins, check out the [Plugins Troubleshooting](https://github.com/fastlane/fastlane/blob/master/fastlane/docs/PluginsTroubleshooting.md) doc in the main `fastlane` repo.
45
+
46
+ ## Using `fastlane` Plugins
47
+
48
+ For more information about how the `fastlane` plugin system works, check out the [Plugins documentation](https://github.com/fastlane/fastlane/blob/master/fastlane/docs/Plugins.md).
49
+
50
+ ## About `fastlane`
51
+
52
+ `fastlane` is the easiest way to automate building and releasing your iOS and Android apps. To learn more, check out [fastlane.tools](https://fastlane.tools).
@@ -0,0 +1,16 @@
1
+ require 'fastlane/plugin/droidicon/version'
2
+
3
+ module Fastlane
4
+ module Droidicon
5
+ # Return all .rb files inside the "actions" and "helper" directory
6
+ def self.all_classes
7
+ Dir[File.expand_path('**/{actions,helper}/*.rb', File.dirname(__FILE__))]
8
+ end
9
+ end
10
+ end
11
+
12
+ # By default we want to import all available actions and helpers
13
+ # A plugin can contain any number of actions and plugins
14
+ Fastlane::Droidicon.all_classes.each do |current|
15
+ require current
16
+ end
@@ -0,0 +1,76 @@
1
+ module Fastlane
2
+ module Actions
3
+ class DroidiconAction < Action
4
+ def self.needed_icons
5
+ {
6
+ android: {
7
+ 'mipmap-mdpi' => '48x48',
8
+ 'mipmap-hdpi' => '72x72',
9
+ 'mipmap-xhdpi' => '96x96',
10
+ 'mipmap-xxhdpi' => '144x144',
11
+ 'mipmap-xxxhdpi' => '192x192',
12
+ },
13
+ }
14
+ end
15
+ def self.run(params)
16
+ fname = params[:appicon_image_file]
17
+ basepath = Pathname.new("#{params[:res_path]}")
18
+
19
+ require 'mini_magick'
20
+ image = MiniMagick::Image.open(fname)
21
+
22
+ UI.user_error!("Minimum width of input image should be 1024") if image.width < 1024
23
+ UI.user_error!("Minimum height of input image should be 1024") if image.height < 1024
24
+ UI.user_error!("Input image should be square") if image.width != image.height
25
+
26
+ FileUtils.mkdir_p(basepath)
27
+
28
+ self.needed_icons[:android].each do |scale, size|
29
+ width, height = size.split('x').map { |v| v.to_f }
30
+
31
+ FileUtils.mkdir_p(File.join(basepath, scale))
32
+ image = MiniMagick::Image.open(fname)
33
+ image.format 'png'
34
+ image.resize "#{width}x#{height}"
35
+ image.write File.join(basepath, scale, params[:generated_file_name])
36
+ end
37
+
38
+ UI.success("Successfully stored app icon at '#{basepath}'")
39
+ end
40
+
41
+ def self.description
42
+ "Generate required icon sizes and iconset from a master application icon"
43
+ end
44
+
45
+ def self.authors
46
+ ["@chrhsmt"]
47
+ end
48
+
49
+ def self.available_options
50
+ [
51
+ FastlaneCore::ConfigItem.new(key: :appicon_image_file,
52
+ env_name: "APPICON_IMAGE_FILE",
53
+ description: "Path to a square image file, at least 1024x1024",
54
+ optional: false,
55
+ type: String),
56
+ FastlaneCore::ConfigItem.new(key: :generated_file_name,
57
+ env_name: "GENERATED_FILE_NAME",
58
+ default_value: "ic_launcher.png",
59
+ description: "Name of file generated",
60
+ optional: true,
61
+ type: String),
62
+ FastlaneCore::ConfigItem.new(key: :res_path,
63
+ env_name: "RES_PATH",
64
+ default_value: File.join("app", "src", "main", "res"),
65
+ description: "Path to the Resouce for the generated iconset",
66
+ optional: true,
67
+ type: String)
68
+ ]
69
+ end
70
+
71
+ def self.is_supported?(platform)
72
+ [:android].include?(platform)
73
+ end
74
+ end
75
+ end
76
+ end
@@ -0,0 +1,12 @@
1
+ module Fastlane
2
+ module Helper
3
+ class DroidiconHelper
4
+ # class methods that you define here become available in your action
5
+ # as `Helper::DroidiconHelper.your_method`
6
+ #
7
+ def self.show_message
8
+ UI.message("Hello from the droidicon plugin helper!")
9
+ end
10
+ end
11
+ end
12
+ end
@@ -0,0 +1,5 @@
1
+ module Fastlane
2
+ module Droidicon
3
+ VERSION = "0.1.0"
4
+ end
5
+ end
metadata ADDED
@@ -0,0 +1,147 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fastlane-plugin-droidicon
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - "@chrhsmt"
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2016-09-18 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: mini_magick
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: 4.5.1
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: 4.5.1
27
+ - !ruby/object:Gem::Dependency
28
+ name: pry
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: bundler
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rspec
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: rake
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: rubocop
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ">="
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ">="
95
+ - !ruby/object:Gem::Version
96
+ version: '0'
97
+ - !ruby/object:Gem::Dependency
98
+ name: fastlane
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - ">="
102
+ - !ruby/object:Gem::Version
103
+ version: 1.101.0
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - ">="
109
+ - !ruby/object:Gem::Version
110
+ version: 1.101.0
111
+ description:
112
+ email: chr@chrhsmt.com
113
+ executables: []
114
+ extensions: []
115
+ extra_rdoc_files: []
116
+ files:
117
+ - LICENSE
118
+ - README.md
119
+ - lib/fastlane/plugin/droidicon.rb
120
+ - lib/fastlane/plugin/droidicon/actions/droidicon_action.rb
121
+ - lib/fastlane/plugin/droidicon/helper/droidicon_helper.rb
122
+ - lib/fastlane/plugin/droidicon/version.rb
123
+ homepage: https://github.com/chrhsmt/fastlane-plugin-droidicon
124
+ licenses:
125
+ - MIT
126
+ metadata: {}
127
+ post_install_message:
128
+ rdoc_options: []
129
+ require_paths:
130
+ - lib
131
+ required_ruby_version: !ruby/object:Gem::Requirement
132
+ requirements:
133
+ - - ">="
134
+ - !ruby/object:Gem::Version
135
+ version: '0'
136
+ required_rubygems_version: !ruby/object:Gem::Requirement
137
+ requirements:
138
+ - - ">="
139
+ - !ruby/object:Gem::Version
140
+ version: '0'
141
+ requirements: []
142
+ rubyforge_project:
143
+ rubygems_version: 2.4.5
144
+ signing_key:
145
+ specification_version: 4
146
+ summary: Generate required icon sizes and iconset from a master application icon
147
+ test_files: []