calatrava 0.0.1 → 0.5.0
Sign up to get free protection for your applications and to get access to all the features.
- data/Rakefile +7 -1
- data/calatrava.gemspec +2 -2
- data/features/sample_app.feature +27 -0
- data/features/step_definitions/app_steps.rb +3 -0
- data/features/support/calatrava_app.rb +31 -0
- data/features/support/env.rb +18 -0
- data/lib/calatrava/project.rb +5 -2
- data/lib/calatrava/tasks/apache.rb +20 -10
- data/lib/calatrava/tasks/droid.rb +1 -1
- data/lib/calatrava/tasks/web.rb +5 -0
- data/lib/calatrava/templates/droid/app/bridge.coffee +21 -120
- data/lib/calatrava/templates/droid/calatrava/{src/com/CALATRAVA_TMPL → CALATRAVA_TMPL}/AndroidManifest.xml.calatrava +2 -2
- data/lib/calatrava/templates/droid/calatrava/{calatrava-build.xml → CALATRAVA_TMPL/build.xml.calatrava} +1 -1
- data/lib/calatrava/templates/droid/calatrava/src/com/CALATRAVA_TMPL/ConversionForm.java.calatrava +4 -4
- data/lib/calatrava/templates/droid/calatrava/src/com/CALATRAVA_TMPL/Title.java.calatrava +2 -2
- data/lib/calatrava/templates/droid/calatrava/src/com/calatrava/bridge/KernelBridge.java +1 -0
- data/lib/calatrava/templates/droid/calatrava/src/com/calatrava/bridge/PageRegistry.java +13 -1
- data/lib/calatrava/templates/droid/calatrava/src/com/calatrava/bridge/RegisteredActivity.java +7 -1
- data/lib/calatrava/templates/droid/calatrava/src/com/calatrava/bridge/RhinoService.java +12 -7
- data/lib/calatrava/templates/droid/calatrava/src/com/calatrava/shell/WebViewActivity.java +2 -4
- data/lib/calatrava/templates/ios/src/ConversionFormViewController.h +4 -0
- data/lib/calatrava/templates/ios/src/ConversionFormViewController.m +36 -3
- data/lib/calatrava/templates/ios/src/ConversionFormViewController.xib +144 -20
- data/lib/calatrava/templates/kernel/app/calatrava.coffee +171 -3
- data/lib/calatrava/templates/kernel/app/converter/controller.converter.coffee +37 -42
- data/lib/calatrava/templates/kernel/app/converter/init.converter.coffee +4 -4
- data/lib/calatrava/templates/kernel/spec/converter/controller.converter.spec.coffee +6 -6
- data/lib/calatrava/templates/kernel/spec/stubView.coffee +18 -2
- data/lib/calatrava/templates/package.json +0 -1
- data/lib/calatrava/templates/shell/pages/converter/conversionForm.haml +6 -4
- data/lib/calatrava/templates/shell/pages/converter/page.conversionForm.coffee +18 -24
- data/lib/calatrava/templates/shell/stylesheets/shell.scss +0 -0
- data/lib/calatrava/templates/web/app/source/bridge.coffee +61 -93
- data/lib/calatrava/version.rb +1 -1
- metadata +39 -34
- data/lib/calatrava/templates/ios/res/js/bridge.js +0 -249
- data/lib/calatrava/templates/shell/shell.scss +0 -1
@@ -4,8 +4,8 @@ example.converter ?= {}
|
|
4
4
|
example.converter.start = ->
|
5
5
|
example.converter.controller
|
6
6
|
views:
|
7
|
-
conversionForm:
|
8
|
-
changePage:
|
9
|
-
ajax:
|
7
|
+
conversionForm: calatrava.bridge.pages.pageNamed "conversionForm"
|
8
|
+
changePage: calatrava.bridge.changePage
|
9
|
+
ajax: calatrava.bridge.request
|
10
10
|
|
11
|
-
|
11
|
+
calatrava.bridge.changePage "conversionForm"
|
@@ -27,11 +27,11 @@ describe 'converter controller', ->
|
|
27
27
|
describe 'converting', ->
|
28
28
|
|
29
29
|
beforeEach ->
|
30
|
+
views.conversionForm.fieldContains 'in_currency', 'USD'
|
31
|
+
views.conversionForm.fieldContains 'out_currency', 'AUD'
|
32
|
+
views.conversionForm.fieldContains 'in_amount', 100
|
30
33
|
views.conversionForm.trigger 'convert'
|
31
34
|
|
32
|
-
it 'should
|
33
|
-
expect(views.conversionForm.
|
34
|
-
|
35
|
-
expect(views.conversionForm.get).toHaveBeenCalledWith('start_currency')
|
36
|
-
it 'should get the ending currency', ->
|
37
|
-
expect(views.conversionForm.get).toHaveBeenCalledWith('end_currency')
|
35
|
+
it 'should render the correctly converted amount', ->
|
36
|
+
expect(views.conversionForm.render).toHaveBeenCalledWith
|
37
|
+
out_amount: 96
|
@@ -3,15 +3,31 @@ stubView ?= {}
|
|
3
3
|
stubView =
|
4
4
|
create: (name) ->
|
5
5
|
boundEvents: {}
|
6
|
+
fieldValues: {}
|
6
7
|
trigger: (event) ->
|
7
8
|
@boundEvents[event]()
|
8
9
|
|
9
10
|
bind: (event, handler) ->
|
10
11
|
@boundEvents[event] = handler
|
11
12
|
|
12
|
-
render: (
|
13
|
+
render: jasmine.createSpy("#{name} render")
|
14
|
+
|
15
|
+
fieldContains: (name, value) -> @fieldValues[name] = value
|
16
|
+
get: (name, callback) ->
|
17
|
+
callback(@fieldValues[name])
|
18
|
+
|
19
|
+
getMany: (fields, callback) ->
|
20
|
+
results = {}
|
21
|
+
getManyPrime = (remaining) =>
|
22
|
+
if (remaining.length > 0)
|
23
|
+
field = _.first(remaining)
|
24
|
+
@get field, (fieldValue) ->
|
25
|
+
results[field] = fieldValue
|
26
|
+
getManyPrime(_.rest(remaining))
|
27
|
+
else
|
28
|
+
callback(results)
|
29
|
+
getManyPrime(fields)
|
13
30
|
|
14
|
-
get: jasmine.createSpy('get')
|
15
31
|
|
16
32
|
hideErrors: ()->
|
17
33
|
|
@@ -6,7 +6,9 @@
|
|
6
6
|
{{/currencies}}
|
7
7
|
|
8
8
|
%h3 THE BEST CURRENCY CONVERTER EVER
|
9
|
-
%select
|
10
|
-
%input
|
11
|
-
%select
|
12
|
-
%
|
9
|
+
%select#in_currency
|
10
|
+
%input#in_amount(type='number' placeholder='amount')
|
11
|
+
%select#out_currency
|
12
|
+
%br
|
13
|
+
%button#convert GO
|
14
|
+
%input#out_amount(placeholder='no result' readonly="true" )
|
@@ -4,39 +4,33 @@ calatrava.pageView.conversionForm = ->
|
|
4
4
|
|
5
5
|
#TODO: refactor out
|
6
6
|
$page = $('#conversionForm')
|
7
|
-
$p = (sel)-> $(sel
|
8
|
-
|
9
|
-
eventHandlers = {}
|
10
|
-
|
11
|
-
trigger = (event, args...) ->
|
12
|
-
eventHandlers[event](args...)
|
7
|
+
$p = (sel)-> $(sel, $page)
|
13
8
|
|
14
9
|
renderCurrencyDropdown = ($select, currencies)->
|
15
10
|
$select.empty().html ich.currencyDropdownTmpl
|
16
11
|
currencies: currencies
|
17
12
|
|
18
|
-
renderSection = (key,data) ->
|
13
|
+
renderSection = (key, data) ->
|
19
14
|
switch key
|
20
|
-
when 'inCurrencies' then renderCurrencyDropdown(
|
21
|
-
when 'outCurrencies' then renderCurrencyDropdown(
|
22
|
-
else
|
23
|
-
|
24
|
-
|
25
|
-
$p(".out_currency").on 'change', ->
|
26
|
-
selectedCurrencyCode = $(this).val()
|
27
|
-
trigger("selectedOutCurrency", selectedCurrencyCode)
|
28
|
-
$p(".in_currency").on 'change', ->
|
29
|
-
selectedCurrencyCode = $(this).val()
|
30
|
-
trigger("selectedInCurrency", selectedCurrencyCode)
|
15
|
+
when 'inCurrencies' then renderCurrencyDropdown($p('#in_currency'), data)
|
16
|
+
when 'outCurrencies' then renderCurrencyDropdown($p('#out_currency'), data)
|
17
|
+
else $p("#" + key).val(data)
|
31
18
|
|
32
19
|
bind: (event, handler) ->
|
33
|
-
|
20
|
+
console.log "event: #{event}"
|
21
|
+
switch event
|
22
|
+
when 'selectedInCurrency' then $p("#in_currency").off('change').on 'change', handler
|
23
|
+
when 'selectedOutCurrency' then $p("#out_currency").off('change').on 'change', handler
|
24
|
+
else
|
25
|
+
$p("#" + event).off('click').on 'click', handler
|
34
26
|
|
35
27
|
render: (message) ->
|
36
28
|
console.log('rendering...', message)
|
37
|
-
renderSection(section,data) for own section,data of message
|
29
|
+
renderSection(section, data) for own section,data of message
|
30
|
+
|
31
|
+
get: (field) ->
|
32
|
+
console.log('getting...', field)
|
33
|
+
$page.find("#" + field).val()
|
38
34
|
|
39
|
-
|
40
|
-
|
41
|
-
show: -> console.log( 'showing...' )
|
42
|
-
hide: -> console.log( 'hiding...' )
|
35
|
+
show: -> console.log('showing...')
|
36
|
+
hide: -> console.log('hiding...')
|
File without changes
|
@@ -1,101 +1,13 @@
|
|
1
|
-
|
2
|
-
|
1
|
+
calatrava ?= {}
|
2
|
+
calatrava.bridge = calatrava.bridge ? {}
|
3
|
+
calatrava.bridge.web = calatrava.bridge.web ? {}
|
3
4
|
|
4
|
-
|
5
|
+
calatrava.bridge.environment = () ->
|
5
6
|
sessionTimeout: 600
|
6
7
|
serviceEndpoint: ""
|
7
8
|
apiEndpoint: ""
|
8
9
|
|
9
|
-
|
10
|
-
handlers = {}
|
11
|
-
methods =
|
12
|
-
bind: (event, callback) ->
|
13
|
-
if event == 'pageOpened'
|
14
|
-
handlers.pageOpened = callback
|
15
|
-
else
|
16
|
-
real.bind(event, callback)
|
17
|
-
|
18
|
-
trigger: (event) ->
|
19
|
-
handlers[event]() if handlers[event]?
|
20
|
-
|
21
|
-
get: (field) -> String(real.get(field))
|
22
|
-
|
23
|
-
# Most functions just route through to the original
|
24
|
-
_.each ['render', 'show', 'hide', 'showDialog'], (method) ->
|
25
|
-
methods[method] = () -> real[method].apply(real, arguments)
|
26
|
-
|
27
|
-
methods
|
28
|
-
|
29
|
-
class tw.bridge.pages
|
30
|
-
pageObjects = {}
|
31
|
-
|
32
|
-
pages.pageNamed = (pageName) ->
|
33
|
-
if !pageObjects[pageName]
|
34
|
-
pageView = calatrava.pageView[pageName]()
|
35
|
-
pageObjects[pageName] = tw.bridge.pageProxy(pageName, pageView)
|
36
|
-
pageObjects[pageName]
|
37
|
-
|
38
|
-
tw.bridge.changePage = (page, options = {}) ->
|
39
|
-
pageObject = tw.bridge.pages.pageNamed page
|
40
|
-
if !options.back
|
41
|
-
history.pushState({page: page}, "", "")
|
42
|
-
tw.currentPage.hide() if tw.currentPage
|
43
|
-
pageObject.show()
|
44
|
-
tw.currentPage = pageObject
|
45
|
-
pageObject.trigger 'pageOpened'
|
46
|
-
page
|
47
|
-
|
48
|
-
tw.bridge.widgets = (() ->
|
49
|
-
displayDateWidget = (options, callback) ->
|
50
|
-
options["month"] = Number(options["month"])+1
|
51
|
-
_.each ["year", "month", "day"], (val) -> $("#dummy_" + val).val(options[val]) if !$("#dummy_" + val).val()
|
52
|
-
$("#dummy_date_picker").show()
|
53
|
-
|
54
|
-
$("#dummy_date_button").unbind().bind 'click', () ->
|
55
|
-
$("#dummy_date_picker").hide()
|
56
|
-
callback $("#dummy_year").val(), $("#dummy_month").val() - 1, $("#dummy_day").val()
|
57
|
-
|
58
|
-
displayAirportWidget = (callback) ->
|
59
|
-
$("#dummy_airport_select_widget").show()
|
60
|
-
|
61
|
-
$("#dummy_airport_set_button").unbind().bind 'click', () ->
|
62
|
-
$("#dummy_airport_select_widget").hide()
|
63
|
-
airportCode = $("#dummy_airport_code").val()
|
64
|
-
airportMap = {ORD: "Chicago", ATL: "Atlanta", DEL: "Delhi", BOM: "Mumbai"}
|
65
|
-
callback airportCode, airportMap[airportCode]
|
66
|
-
|
67
|
-
|
68
|
-
display: (widget, options, callback) ->
|
69
|
-
if widget == "date"
|
70
|
-
displayDateWidget options.selectedDate, callback
|
71
|
-
else if widget == "airport"
|
72
|
-
displayAirportWidget callback
|
73
|
-
)()
|
74
|
-
|
75
|
-
tw.bridge.alert = (msg) -> alert(msg)
|
76
|
-
|
77
|
-
tw.bridge.openUrl = (url) ->
|
78
|
-
window.open(url)
|
79
|
-
|
80
|
-
tw.bridge.trackEvent = (pageName, channel, eventName, variables, properties) ->
|
81
|
-
describedKeyValuePairs = (pairs) -> _.map(pairs, (val, key) -> "#{key}: '#{val}'").join('; ')
|
82
|
-
console.log "Omniture track event: page: '#{pageName}'; channel: '#{channel}'; events: '#{eventName}'"
|
83
|
-
console.log "Omniture variables: #{describedKeyValuePairs(variables)}"
|
84
|
-
console.log "Omniture properties: #{describedKeyValuePairs(properties)}"
|
85
|
-
|
86
|
-
tw.bridge.timers = (() ->
|
87
|
-
start: (timeout, callback) ->
|
88
|
-
window.setTimeout(callback, timeout * 1000)
|
89
|
-
|
90
|
-
clearTimer: (timerId) ->
|
91
|
-
)()
|
92
|
-
|
93
|
-
tw.bridge.dialog = (() ->
|
94
|
-
display: (dialogName) ->
|
95
|
-
tw.currentPage.showDialog dialogName
|
96
|
-
)()
|
97
|
-
|
98
|
-
tw.bridge.request = (options) ->
|
10
|
+
calatrava.bridge.web.ajax = (options) ->
|
99
11
|
loader = $("#loader")
|
100
12
|
|
101
13
|
errorHandler = () ->
|
@@ -156,3 +68,59 @@ tw.bridge.request = (options) ->
|
|
156
68
|
showLoader()
|
157
69
|
options.failure()
|
158
70
|
complete: hideLoader
|
71
|
+
|
72
|
+
calatrava.bridge.web.page = (pageName, proxyId) ->
|
73
|
+
real = calatrava.pageView[pageName]()
|
74
|
+
handlers = {}
|
75
|
+
methods =
|
76
|
+
bind: (event, callback) ->
|
77
|
+
if event == 'pageOpened'
|
78
|
+
handlers.pageOpened = callback
|
79
|
+
else
|
80
|
+
real.bind(event, callback)
|
81
|
+
|
82
|
+
trigger: (event) ->
|
83
|
+
handlers[event]() if handlers[event]?
|
84
|
+
|
85
|
+
get: (field, getId) ->
|
86
|
+
calatrava.inbound.fieldRead(proxyId, getId, String(real.get(field)))
|
87
|
+
|
88
|
+
# Most functions just route through to the original
|
89
|
+
_.each ['render', 'show', 'hide'], (method) ->
|
90
|
+
methods[method] = () -> real[method].apply(real, arguments)
|
91
|
+
|
92
|
+
methods
|
93
|
+
|
94
|
+
calatrava.bridge.runtime = (() ->
|
95
|
+
|
96
|
+
pages = {}
|
97
|
+
pagesNamed = {}
|
98
|
+
currentPage = null
|
99
|
+
|
100
|
+
registerProxyForPage: (proxyId, pageName) ->
|
101
|
+
pages[proxyId] = calatrava.bridge.web.page(pageName, proxyId)
|
102
|
+
pagesNamed[pageName] = pages[proxyId]
|
103
|
+
|
104
|
+
changePage: (page, options = {}) ->
|
105
|
+
pageObject = pagesNamed[page]
|
106
|
+
if !options.back
|
107
|
+
history.pushState({page: page}, "", "")
|
108
|
+
currentPage.hide() if currentPage
|
109
|
+
pageObject.show()
|
110
|
+
currentPage = pageObject
|
111
|
+
pageObject.trigger 'pageOpened'
|
112
|
+
|
113
|
+
attachProxyEventHandler: (proxyId, event) ->
|
114
|
+
pages[proxyId].bind event, () ->
|
115
|
+
args = [proxyId, event].concat(_.toArray(arguments))
|
116
|
+
calatrava.inbound.dispatchEvent.apply(calatrava.inbound, args)
|
117
|
+
|
118
|
+
valueOfProxyField: (proxyId, field, getId) -> pages[proxyId].get(field, getId)
|
119
|
+
renderProxy: (viewObject, proxyId) -> pages[proxyId].render(viewObject)
|
120
|
+
issueRequest: calatrava.bridge.web.ajax
|
121
|
+
openUrl: (url) -> window.open(url)
|
122
|
+
log: (message) -> console.log(message)
|
123
|
+
|
124
|
+
startTimerWithTimeout: (timerId, timeout) ->
|
125
|
+
window.setTimeout((() -> calatrava.inbound.fireTimer(timerId)), timeout * 1000)
|
126
|
+
)()
|
data/lib/calatrava/version.rb
CHANGED
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: calatrava
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0
|
4
|
+
version: 0.5.0
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,11 +9,11 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2012-
|
12
|
+
date: 2012-10-02 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: rspec
|
16
|
-
requirement: &
|
16
|
+
requirement: &70314197260240 !ruby/object:Gem::Requirement
|
17
17
|
none: false
|
18
18
|
requirements:
|
19
19
|
- - ! '>='
|
@@ -21,10 +21,10 @@ dependencies:
|
|
21
21
|
version: '0'
|
22
22
|
type: :development
|
23
23
|
prerelease: false
|
24
|
-
version_requirements: *
|
24
|
+
version_requirements: *70314197260240
|
25
25
|
- !ruby/object:Gem::Dependency
|
26
26
|
name: aruba
|
27
|
-
requirement: &
|
27
|
+
requirement: &70314197259820 !ruby/object:Gem::Requirement
|
28
28
|
none: false
|
29
29
|
requirements:
|
30
30
|
- - ! '>='
|
@@ -32,10 +32,10 @@ dependencies:
|
|
32
32
|
version: '0'
|
33
33
|
type: :development
|
34
34
|
prerelease: false
|
35
|
-
version_requirements: *
|
35
|
+
version_requirements: *70314197259820
|
36
36
|
- !ruby/object:Gem::Dependency
|
37
37
|
name: rake
|
38
|
-
requirement: &
|
38
|
+
requirement: &70314197259400 !ruby/object:Gem::Requirement
|
39
39
|
none: false
|
40
40
|
requirements:
|
41
41
|
- - ! '>='
|
@@ -43,10 +43,10 @@ dependencies:
|
|
43
43
|
version: '0'
|
44
44
|
type: :runtime
|
45
45
|
prerelease: false
|
46
|
-
version_requirements: *
|
46
|
+
version_requirements: *70314197259400
|
47
47
|
- !ruby/object:Gem::Dependency
|
48
48
|
name: thor
|
49
|
-
requirement: &
|
49
|
+
requirement: &70314197258980 !ruby/object:Gem::Requirement
|
50
50
|
none: false
|
51
51
|
requirements:
|
52
52
|
- - ! '>='
|
@@ -54,10 +54,10 @@ dependencies:
|
|
54
54
|
version: '0'
|
55
55
|
type: :runtime
|
56
56
|
prerelease: false
|
57
|
-
version_requirements: *
|
57
|
+
version_requirements: *70314197258980
|
58
58
|
- !ruby/object:Gem::Dependency
|
59
59
|
name: haml
|
60
|
-
requirement: &
|
60
|
+
requirement: &70314197258560 !ruby/object:Gem::Requirement
|
61
61
|
none: false
|
62
62
|
requirements:
|
63
63
|
- - ! '>='
|
@@ -65,10 +65,10 @@ dependencies:
|
|
65
65
|
version: '0'
|
66
66
|
type: :runtime
|
67
67
|
prerelease: false
|
68
|
-
version_requirements: *
|
68
|
+
version_requirements: *70314197258560
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
70
|
name: sass
|
71
|
-
requirement: &
|
71
|
+
requirement: &70314197258140 !ruby/object:Gem::Requirement
|
72
72
|
none: false
|
73
73
|
requirements:
|
74
74
|
- - ! '>='
|
@@ -76,10 +76,10 @@ dependencies:
|
|
76
76
|
version: '0'
|
77
77
|
type: :runtime
|
78
78
|
prerelease: false
|
79
|
-
version_requirements: *
|
79
|
+
version_requirements: *70314197258140
|
80
80
|
- !ruby/object:Gem::Dependency
|
81
81
|
name: mustache
|
82
|
-
requirement: &
|
82
|
+
requirement: &70314197257720 !ruby/object:Gem::Requirement
|
83
83
|
none: false
|
84
84
|
requirements:
|
85
85
|
- - ! '>='
|
@@ -87,10 +87,10 @@ dependencies:
|
|
87
87
|
version: '0'
|
88
88
|
type: :runtime
|
89
89
|
prerelease: false
|
90
|
-
version_requirements: *
|
90
|
+
version_requirements: *70314197257720
|
91
91
|
- !ruby/object:Gem::Dependency
|
92
92
|
name: xcoder
|
93
|
-
requirement: &
|
93
|
+
requirement: &70314197257300 !ruby/object:Gem::Requirement
|
94
94
|
none: false
|
95
95
|
requirements:
|
96
96
|
- - ! '>='
|
@@ -98,10 +98,10 @@ dependencies:
|
|
98
98
|
version: '0'
|
99
99
|
type: :runtime
|
100
100
|
prerelease: false
|
101
|
-
version_requirements: *
|
101
|
+
version_requirements: *70314197257300
|
102
102
|
- !ruby/object:Gem::Dependency
|
103
103
|
name: xcodeproj
|
104
|
-
requirement: &
|
104
|
+
requirement: &70314197256880 !ruby/object:Gem::Requirement
|
105
105
|
none: false
|
106
106
|
requirements:
|
107
107
|
- - ! '>='
|
@@ -109,10 +109,10 @@ dependencies:
|
|
109
109
|
version: '0'
|
110
110
|
type: :runtime
|
111
111
|
prerelease: false
|
112
|
-
version_requirements: *
|
112
|
+
version_requirements: *70314197256880
|
113
113
|
- !ruby/object:Gem::Dependency
|
114
114
|
name: cucumber
|
115
|
-
requirement: &
|
115
|
+
requirement: &70314197256460 !ruby/object:Gem::Requirement
|
116
116
|
none: false
|
117
117
|
requirements:
|
118
118
|
- - ! '>='
|
@@ -120,10 +120,10 @@ dependencies:
|
|
120
120
|
version: '0'
|
121
121
|
type: :runtime
|
122
122
|
prerelease: false
|
123
|
-
version_requirements: *
|
123
|
+
version_requirements: *70314197256460
|
124
124
|
- !ruby/object:Gem::Dependency
|
125
125
|
name: frank-cucumber
|
126
|
-
requirement: &
|
126
|
+
requirement: &70314197256040 !ruby/object:Gem::Requirement
|
127
127
|
none: false
|
128
128
|
requirements:
|
129
129
|
- - ! '>='
|
@@ -131,10 +131,10 @@ dependencies:
|
|
131
131
|
version: '0'
|
132
132
|
type: :runtime
|
133
133
|
prerelease: false
|
134
|
-
version_requirements: *
|
134
|
+
version_requirements: *70314197256040
|
135
135
|
- !ruby/object:Gem::Dependency
|
136
136
|
name: watir-webdriver
|
137
|
-
requirement: &
|
137
|
+
requirement: &70314197255620 !ruby/object:Gem::Requirement
|
138
138
|
none: false
|
139
139
|
requirements:
|
140
140
|
- - ! '>='
|
@@ -142,10 +142,10 @@ dependencies:
|
|
142
142
|
version: '0'
|
143
143
|
type: :runtime
|
144
144
|
prerelease: false
|
145
|
-
version_requirements: *
|
145
|
+
version_requirements: *70314197255620
|
146
146
|
- !ruby/object:Gem::Dependency
|
147
147
|
name: cocoapods
|
148
|
-
requirement: &
|
148
|
+
requirement: &70314197255200 !ruby/object:Gem::Requirement
|
149
149
|
none: false
|
150
150
|
requirements:
|
151
151
|
- - ! '>='
|
@@ -153,11 +153,11 @@ dependencies:
|
|
153
153
|
version: '0'
|
154
154
|
type: :runtime
|
155
155
|
prerelease: false
|
156
|
-
version_requirements: *
|
156
|
+
version_requirements: *70314197255200
|
157
157
|
description: A framework to build cross-platform mobile apps with high quality native
|
158
158
|
UIs.
|
159
159
|
email:
|
160
|
-
-
|
160
|
+
- giles.alexander@gmail.com
|
161
161
|
executables:
|
162
162
|
- calatrava
|
163
163
|
extensions: []
|
@@ -174,7 +174,10 @@ files:
|
|
174
174
|
- calatrava.gemspec
|
175
175
|
- features/cli.feature
|
176
176
|
- features/project.feature
|
177
|
+
- features/sample_app.feature
|
178
|
+
- features/step_definitions/app_steps.rb
|
177
179
|
- features/step_definitions/template_steps.rb
|
180
|
+
- features/support/calatrava_app.rb
|
178
181
|
- features/support/env.rb
|
179
182
|
- lib/calatrava.rb
|
180
183
|
- lib/calatrava/app.rb
|
@@ -209,11 +212,11 @@ files:
|
|
209
212
|
- lib/calatrava/templates/config/templates/env.coffee.erb
|
210
213
|
- lib/calatrava/templates/config/templates/httpd.conf.erb
|
211
214
|
- lib/calatrava/templates/droid/app/bridge.coffee
|
215
|
+
- lib/calatrava/templates/droid/calatrava/CALATRAVA_TMPL/AndroidManifest.xml.calatrava
|
216
|
+
- lib/calatrava/templates/droid/calatrava/CALATRAVA_TMPL/build.xml.calatrava
|
212
217
|
- lib/calatrava/templates/droid/calatrava/ant/calatrava.xml
|
213
|
-
- lib/calatrava/templates/droid/calatrava/calatrava-build.xml
|
214
218
|
- lib/calatrava/templates/droid/calatrava/ivy.xml
|
215
219
|
- lib/calatrava/templates/droid/calatrava/ivysettings.xml
|
216
|
-
- lib/calatrava/templates/droid/calatrava/src/com/CALATRAVA_TMPL/AndroidManifest.xml.calatrava
|
217
220
|
- lib/calatrava/templates/droid/calatrava/src/com/CALATRAVA_TMPL/ConversionForm.java.calatrava
|
218
221
|
- lib/calatrava/templates/droid/calatrava/src/com/CALATRAVA_TMPL/Title.java.calatrava
|
219
222
|
- lib/calatrava/templates/droid/calatrava/src/com/calatrava/CalatravaPage.java
|
@@ -229,7 +232,6 @@ files:
|
|
229
232
|
- lib/calatrava/templates/droid/manifest.yml
|
230
233
|
- lib/calatrava/templates/ios/Podfile.calatrava
|
231
234
|
- lib/calatrava/templates/ios/manifest.yml
|
232
|
-
- lib/calatrava/templates/ios/res/js/bridge.js
|
233
235
|
- lib/calatrava/templates/ios/res/xibs/ProgressViewController.xib
|
234
236
|
- lib/calatrava/templates/ios/res/xibs/WebViewController.xib
|
235
237
|
- lib/calatrava/templates/ios/src/AppDelegate.h
|
@@ -262,7 +264,7 @@ files:
|
|
262
264
|
- lib/calatrava/templates/shell/layouts/single_page.haml
|
263
265
|
- lib/calatrava/templates/shell/pages/converter/conversionForm.haml
|
264
266
|
- lib/calatrava/templates/shell/pages/converter/page.conversionForm.coffee
|
265
|
-
- lib/calatrava/templates/shell/shell.scss
|
267
|
+
- lib/calatrava/templates/shell/stylesheets/shell.scss
|
266
268
|
- lib/calatrava/templates/shell/support/shell.coffee
|
267
269
|
- lib/calatrava/templates/web/apache/conf/mime.types
|
268
270
|
- lib/calatrava/templates/web/app/source/bridge.coffee
|
@@ -271,7 +273,7 @@ files:
|
|
271
273
|
- lib/calatrava/templates/web/deploy/instance.sh
|
272
274
|
- lib/calatrava/templates/web/manifest.yml
|
273
275
|
- lib/calatrava/version.rb
|
274
|
-
homepage:
|
276
|
+
homepage: http://calatrava.github.com
|
275
277
|
licenses: []
|
276
278
|
post_install_message:
|
277
279
|
rdoc_options: []
|
@@ -298,5 +300,8 @@ summary: Cross-platform mobile apps with native UIs
|
|
298
300
|
test_files:
|
299
301
|
- features/cli.feature
|
300
302
|
- features/project.feature
|
303
|
+
- features/sample_app.feature
|
304
|
+
- features/step_definitions/app_steps.rb
|
301
305
|
- features/step_definitions/template_steps.rb
|
306
|
+
- features/support/calatrava_app.rb
|
302
307
|
- features/support/env.rb
|