slugable_daniel_test 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/lib/slugable_daniel_test.rb +40 -0
- metadata +44 -0
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: ba5aca20985580181444391c5fe14e2488632c9c
|
4
|
+
data.tar.gz: 22999271bee506ec72c97fd606f06d85b9c2785b
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: 0a9a7aa7576a5276d6fe68bee06f9c3b1eee615b55c7c5c47ae41594ae0a3ce168d1e40b5706ba34511626c1fd4096d723ea2c00f8843cd63bbf3fe27d1c6e91
|
7
|
+
data.tar.gz: c9a976ce6228afdfae9726acc6b52a492bfd4634e0258396bb290f7a4cd31fb6a890cb98ee374907daa1695ea8e75b3482a4a2f7c5797d97176c2a4c0967ef0f
|
@@ -0,0 +1,40 @@
|
|
1
|
+
module SlugableDanielTest
|
2
|
+
extend ActiveSupport::Concern
|
3
|
+
|
4
|
+
included do
|
5
|
+
before_save :generate_slug
|
6
|
+
class_attribute :slug_column, instance_accessor: false
|
7
|
+
end
|
8
|
+
|
9
|
+
def generate_slug
|
10
|
+
self.slug = slug_uniqueize( self, options: { column_name: self.class.slug_column.to_sym, count: -1 })
|
11
|
+
end
|
12
|
+
|
13
|
+
def slug_uniqueize(obj, options: {} )
|
14
|
+
the_slug = generate_slug_prefix(obj, options[:column_name]) + generate_slug_suffix(options[:count])
|
15
|
+
record = obj.class.find_by slug: the_slug
|
16
|
+
if record && record != obj # the_slug has already been used by the others.
|
17
|
+
options[:count] += 1
|
18
|
+
return slug_uniqueize(obj, options: options)
|
19
|
+
end
|
20
|
+
the_slug
|
21
|
+
end
|
22
|
+
|
23
|
+
def generate_slug_suffix(count)
|
24
|
+
(count + 1) == 0 ? "" : "-"+(count + 1).to_s
|
25
|
+
end
|
26
|
+
|
27
|
+
def generate_slug_prefix(obj, column_name)
|
28
|
+
#obj[column_name].gsub(/\W/," ").split.join("-").downcase
|
29
|
+
obj[column_name].gsub(/\s*[^A-Za-z0-9]\s*/," ").split.join("-").downcase
|
30
|
+
end
|
31
|
+
|
32
|
+
module ClassMethods
|
33
|
+
def slugable_column column_name
|
34
|
+
#puts self
|
35
|
+
self.slug_column = column_name
|
36
|
+
#puts "okokokokokokokokokokokok"
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
metadata
ADDED
@@ -0,0 +1,44 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: slugable_daniel_test
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.0.1
|
5
|
+
platform: ruby
|
6
|
+
authors:
|
7
|
+
- Daniel
|
8
|
+
autorequire:
|
9
|
+
bindir: bin
|
10
|
+
cert_chain: []
|
11
|
+
date: 2014-12-19 00:00:00.000000000 Z
|
12
|
+
dependencies: []
|
13
|
+
description: A simple gem which is used to generate slug
|
14
|
+
email: daniel@example.com
|
15
|
+
executables: []
|
16
|
+
extensions: []
|
17
|
+
extra_rdoc_files: []
|
18
|
+
files:
|
19
|
+
- lib/slugable_daniel_test.rb
|
20
|
+
homepage: http://github.com
|
21
|
+
licenses:
|
22
|
+
- MIT
|
23
|
+
metadata: {}
|
24
|
+
post_install_message:
|
25
|
+
rdoc_options: []
|
26
|
+
require_paths:
|
27
|
+
- lib
|
28
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
29
|
+
requirements:
|
30
|
+
- - '>='
|
31
|
+
- !ruby/object:Gem::Version
|
32
|
+
version: '0'
|
33
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
34
|
+
requirements:
|
35
|
+
- - '>='
|
36
|
+
- !ruby/object:Gem::Version
|
37
|
+
version: '0'
|
38
|
+
requirements: []
|
39
|
+
rubyforge_project:
|
40
|
+
rubygems_version: 2.4.5
|
41
|
+
signing_key:
|
42
|
+
specification_version: 4
|
43
|
+
summary: slugable_daniel_test
|
44
|
+
test_files: []
|