foreman_export_hosts 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.
Files changed (43) hide show
  1. data/LICENSE +619 -0
  2. data/README.md +39 -0
  3. data/Rakefile +47 -0
  4. data/app/assets/javascripts/application.js +2 -0
  5. data/app/assets/javascripts/jquery.battatech.excelexport.js +180 -0
  6. data/app/controllers/foreman_hosts/hosts_controller.rb +17 -0
  7. data/app/controllers/foreman_hosts/syhostmodeldetails_controller.rb +83 -0
  8. data/app/controllers/foreman_hosts/syhostmodels_controller.rb +84 -0
  9. data/app/helpers/concerns/foreman_hosts/hosts_helper_extensions.rb +20 -0
  10. data/app/models/concerns/foreman_hosts/hosts_extensions.rb +19 -0
  11. data/app/models/foreman_hosts/syhostmodel.rb +8 -0
  12. data/app/models/foreman_hosts/syhostmodeldetail.rb +5 -0
  13. data/app/overrides/dashboard/index/sample_override.html.erb.deface +4 -0
  14. data/app/views/dashboard/_foreman_hosts_widget.html.erb +2 -0
  15. data/app/views/foreman_hosts/hosts/export.xlsx.axlsx +130 -0
  16. data/app/views/foreman_hosts/hosts/hosts/new_action.html.erb +1 -0
  17. data/app/views/foreman_hosts/hosts/report_index.html.erb +257 -0
  18. data/app/views/foreman_hosts/layouts/layouts/new_layout.html.erb +0 -0
  19. data/app/views/foreman_hosts/layouts/new_layout.html.erb +0 -0
  20. data/app/views/foreman_hosts/syhostmodels/_form.html.erb +30 -0
  21. data/app/views/foreman_hosts/syhostmodels/_list.html.erb +41 -0
  22. data/app/views/foreman_hosts/syhostmodels/_report.html.erb +258 -0
  23. data/app/views/foreman_hosts/syhostmodels/_sub.html.erb +37 -0
  24. data/app/views/foreman_hosts/syhostmodels/edit.html.erb +1 -0
  25. data/app/views/foreman_hosts/syhostmodels/index.html.erb +5 -0
  26. data/app/views/foreman_hosts/syhostmodels/new.html.erb +1 -0
  27. data/app/views/foreman_hosts/syhostmodels/show.html.erb +72 -0
  28. data/bin/foreman-hosts +5 -0
  29. data/config/routes.rb +8 -0
  30. data/db/migrate/20151015022411_create_syhostmodels.rb +10 -0
  31. data/db/migrate/20151015050239_create_syhostmodeldetails.rb +13 -0
  32. data/lib/foreman_hosts/engine.rb +92 -0
  33. data/lib/foreman_hosts/version.rb +3 -0
  34. data/lib/foreman_hosts.rb +4 -0
  35. data/lib/tasks/foreman_hosts_tasks.rake +49 -0
  36. data/locale/Makefile +62 -0
  37. data/locale/en/foreman_hosts.po +19 -0
  38. data/locale/foreman_hosts.pot +19 -0
  39. data/locale/gemspec.rb +2 -0
  40. data/test/factories/foreman_hosts_factories.rb +5 -0
  41. data/test/test_plugin_helper.rb +6 -0
  42. data/test/unit/foreman_hosts_test.rb +11 -0
  43. metadata +154 -0
@@ -0,0 +1,257 @@
1
+ <div class="four wide right column">
2
+ <button class='btn btn-info' type='button'><a href="javascript:void(0);" class="ui green button icon mini" id="btnExport" onclick="export_excel();">Export</a></button>
3
+
4
+ </div>
5
+ <%= javascript "jquery.cookie", "host_checkbox" %>
6
+ <% title header ||= "" %>
7
+
8
+ <table class="table table-bordered table-striped table-condensed" id="tblExport">
9
+ <thead>
10
+ <tr>
11
+ <th class=''><%= sort :name, :as => _('Name') %></th>
12
+ <% fact_name_no1 = 1 %>
13
+ <% @fact_names.each do |fact_name| %>
14
+
15
+ <th id="td<%= fact_name_no1 %>"><%= fact_name.name %>
16
+ <br />
17
+ <button type='button'><a href="javascript:void(0);" onclick="DeleteSignColumn(<%= fact_name_no1 %>);"><span class="glyphicon glyphicon-remove" aria-hidden="true"></span></a></button></th>
18
+ <% fact_name_no1 += 1 %>
19
+ <% end %>
20
+ </tr>
21
+ </thead>
22
+ <tbody>
23
+ <% @hosts.each do |host| %>
24
+ <tr>
25
+ <td class='ellipsis'><%= name_column(host) %></td>
26
+
27
+ <% @fact_names.each do |fact_name| %>
28
+ <td>
29
+ <%= FactValue.where(host_id: host.id, fact_name_id: fact_name.id).last.value rescue nil%>
30
+ </td>
31
+ <% end %>
32
+
33
+
34
+
35
+ </tr>
36
+ <% end %>
37
+ </tbody>
38
+ </table>
39
+
40
+
41
+
42
+
43
+
44
+
45
+ <script type="text/javascript">
46
+ function export_excel(){
47
+ var uri = $("#tblExport").battatech_excelexport({
48
+ containerid: "tblExport",
49
+ datatype: 'table',
50
+ returnUri: true
51
+ });
52
+ $("#btnExport").attr('download', 'hosts.xlsx').attr('href', uri).attr('target', '_blank');
53
+ }
54
+
55
+ function DeleteSignColumn(tid) {
56
+ var tab = document.getElementById("tblExport");
57
+ var columnLength = tab.rows[0].cells.length;
58
+ var tr1 = tab.rows[0];
59
+ var columnId = 0;
60
+ tid= "td" + tid
61
+ for(var j=0;j<tr1.cells.length;j++)//取得第几行下面的td个数,再次循环遍历该行下面的td元素
62
+ {
63
+ var cell = tr1.cells[j];//获取某行下面的某个td元素
64
+ if (cell.id == tid) {
65
+ columnId = columnId + j;
66
+ }
67
+ }
68
+ //删除指定单元格
69
+ if (columnId > 0){
70
+ for (var i = 0; i < tab.rows.length; i++) {
71
+ tab.rows[i].deleteCell(columnId);
72
+ }
73
+ }
74
+
75
+ }
76
+ /*
77
+ * jQuery Client Side Excel Export Plugin Library
78
+ * http://www.battatech.com/
79
+ *
80
+ * Copyright (c) 2013 Batta Tech Private Limited
81
+ * Licensed under https://github.com/battatech/battatech_excelexport/blob/master/LICENSE.txt
82
+ */
83
+
84
+ (function ($) {
85
+ var $defaults = {
86
+ containerid: null
87
+ , datatype: 'table'
88
+ , dataset: null
89
+ , columns: null
90
+ , returnUri: false
91
+ , worksheetName: "Sheet1"
92
+ , encoding: "utf-8"
93
+ };
94
+
95
+ var $settings = $defaults;
96
+
97
+ $.fn.battatech_excelexport = function (options) {
98
+ $settings = $.extend({}, $defaults, options);
99
+
100
+ var gridData = [];
101
+ var excelData;
102
+
103
+ return Initialize();
104
+
105
+ function Initialize() {
106
+ var type = $settings.datatype.toLowerCase();
107
+
108
+ BuildDataStructure(type);
109
+
110
+ switch (type) {
111
+ case 'table':
112
+ excelData = Export(ConvertFromTable());
113
+ break;
114
+ case 'json':
115
+ excelData = Export(ConvertDataStructureToTable());
116
+ break;
117
+ case 'xml':
118
+ excelData = Export(ConvertDataStructureToTable());
119
+ break;
120
+ case 'jqgrid':
121
+ excelData = Export(ConvertDataStructureToTable());
122
+ break;
123
+ }
124
+
125
+ if ($settings.returnUri) {
126
+ return excelData;
127
+ }
128
+ else {
129
+ window.open(excelData);
130
+ }
131
+ }
132
+
133
+ function BuildDataStructure(type) {
134
+ switch (type) {
135
+ case 'table':
136
+ break;
137
+ case 'json':
138
+ gridData = $settings.dataset;
139
+ break;
140
+ case 'xml':
141
+ $($settings.dataset).find("row").each(function (key, value) {
142
+ var item = {};
143
+
144
+ if (this.attributes != null && this.attributes.length > 0) {
145
+ $(this.attributes).each(function () {
146
+ item[this.name] = this.value;
147
+ });
148
+
149
+ gridData.push(item);
150
+ }
151
+ });
152
+ break;
153
+ case 'jqgrid':
154
+ $($settings.dataset).find("rows > row").each(function (key, value) {
155
+ var item = {};
156
+
157
+ if (this.children != null && this.children.length > 0) {
158
+ $(this.children).each(function () {
159
+ item[this.tagName] = $(this).text();
160
+ });
161
+
162
+ gridData.push(item);
163
+ }
164
+ });
165
+ break;
166
+ }
167
+ }
168
+
169
+ function ConvertFromTable() {
170
+ var result = $('<div>').append($('#' + $settings.containerid).clone()).html();
171
+ return result;
172
+ }
173
+
174
+ function ConvertDataStructureToTable() {
175
+ var result = "<table>";
176
+
177
+ result += "<thead><tr>";
178
+ $($settings.columns).each(function (key, value) {
179
+ if (this.ishidden != true) {
180
+ result += "<th";
181
+ if (this.width != null) {
182
+ result += " style='width: " + this.width + "'";
183
+ }
184
+ result += ">";
185
+ result += this.headertext;
186
+ result += "</th>";
187
+ }
188
+ });
189
+ result += "</tr></thead>";
190
+
191
+ result += "<tbody>";
192
+ $(gridData).each(function (key, value) {
193
+ result += "<tr>";
194
+ $($settings.columns).each(function (k, v) {
195
+ if (value.hasOwnProperty(this.datafield)) {
196
+ if (this.ishidden != true) {
197
+ result += "<td";
198
+ if (this.width != null) {
199
+ result += " style='width: " + this.width + "'";
200
+ }
201
+ result += ">";
202
+ result += value[this.datafield];
203
+ result += "</td>";
204
+ }
205
+ }
206
+ });
207
+ result += "</tr>";
208
+ });
209
+ result += "</tbody>";
210
+
211
+ result += "</table>";
212
+ return result;
213
+ }
214
+
215
+ function Export(htmltable) {
216
+ var excelFile = "<html xmlns:o='urn:schemas-microsoft-com:office:office' xmlns:x='urn:schemas-microsoft-com:office:excel' xmlns='http://www.w3.org/TR/REC-html40'>";
217
+ excelFile += "<head>";
218
+ excelFile += '<meta http-equiv="Content-type" content="text/html;charset=' + $defaults.encoding + '" />';
219
+ excelFile += "<!--[if gte mso 9]>";
220
+ excelFile += "<xml>";
221
+ excelFile += "<x:ExcelWorkbook>";
222
+ excelFile += "<x:ExcelWorksheets>";
223
+ excelFile += "<x:ExcelWorksheet>";
224
+ excelFile += "<x:Name>";
225
+ excelFile += "{worksheet}";
226
+ excelFile += "</x:Name>";
227
+ excelFile += "<x:WorksheetOptions>";
228
+ excelFile += "<x:DisplayGridlines/>";
229
+ excelFile += "</x:WorksheetOptions>";
230
+ excelFile += "</x:ExcelWorksheet>";
231
+ excelFile += "</x:ExcelWorksheets>";
232
+ excelFile += "</x:ExcelWorkbook>";
233
+ excelFile += "</xml>";
234
+ excelFile += "<![endif]-->";
235
+ excelFile += "</head>";
236
+ excelFile += "<body>";
237
+ excelFile += htmltable.replace(/"/g, '\'');
238
+ excelFile += "</body>";
239
+ excelFile += "</html>";
240
+
241
+ var uri = "data:application/vnd.ms-excel;base64,";
242
+ var ctx = { worksheet: $settings.worksheetName, table: htmltable };
243
+
244
+ return (uri + base64(format(excelFile, ctx)));
245
+ }
246
+
247
+ function base64(s) {
248
+ return window.btoa(unescape(encodeURIComponent(s)));
249
+ }
250
+
251
+ function format(s, c) {
252
+ return s.replace(/{(\w+)}/g, function (m, p) { return c[p]; });
253
+ }
254
+ };
255
+ })(jQuery);
256
+
257
+ </script>
@@ -0,0 +1,30 @@
1
+ <%= javascript 'syhostmodels', 'syhostmodel_edit', 'syhostmodel_edit_interfaces', 'class_edit', 'compute_resource', 'lookup_keys'%>
2
+
3
+ <%= nested_form_for @syhostmodel, :html => {:data => {:id => @syhostmodel.try(:id), :submit => 'progress_bar'}} do |f| %>
4
+ <%= base_errors_for @syhostmodel %>
5
+ <div class="row clearfix">
6
+ <div class="row">
7
+ <div class="form-group col-md-12">
8
+ <label>name</label>
9
+ <%= f.text_field :name, :size => "col-md-12", placeholder: "填写name", class: "form-control" %>
10
+ </div>
11
+ </div>
12
+ <div class="row">
13
+ <div class="form-group col-md-12">
14
+ <label>remark</label>
15
+ <%= f.text_field :remark, :size => "col-md-12", placeholder: "填写remark", class: "form-control" %>
16
+ </div>
17
+ </div>
18
+ <div class="row">
19
+ <div class="col-md-12 column">
20
+ <%#= render partial: "foreman_hosts/syhostmodels/sub", locals: { f: f, object: @syhostmodel } %>
21
+ </div>
22
+ </div>
23
+ <div class="row">
24
+ <div class="actions">
25
+ <%= f.submit "提交", class: "btn btn-success" %>
26
+ <%= link_to '返回', foreman_hosts_syhostmodels_path, class: "btn btn-primary" %>
27
+ </div>
28
+ </div>
29
+ </div>
30
+ <% end %>
@@ -0,0 +1,41 @@
1
+ <%= javascript "jquery.cookie" %>
2
+ <% title header ||= "" %>
3
+ <table class="table table-bordered table-striped table-condensed" >
4
+ <thead>
5
+ <tr>
6
+ <th class=''>name</th>
7
+ <th class="hidden-xs">remark</th>
8
+ <th>操作</th>
9
+ </tr>
10
+ </thead>
11
+ <tbody>
12
+ <% syhostmodels.each do |syhostmodel| %>
13
+ <tr>
14
+ <td class=''><%= syhostmodel.name %></td>
15
+ <td class="hidden-xs"><%= syhostmodel.remark %></td>
16
+ <td>
17
+ <%= link_to '查看', syhostmodel %>
18
+ <%= link_to '编辑', edit_foreman_hosts_syhostmodel_path(syhostmodel) %>
19
+ <%= link_to '删除', syhostmodel, method: :delete, data: { confirm: 'Are you sure?' } %>
20
+ </td>
21
+ </tr>
22
+ <% end %>
23
+ </tbody>
24
+ </table>
25
+ <div id="confirmation-modal" class="modal fade">
26
+ <div class="modal-dialog">
27
+ <div class="modal-content">
28
+ <div class="modal-header">
29
+ <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
30
+ <h4 class="modal-title"><%= _('Please Confirm') %></h4>
31
+ </div>
32
+ <div class="modal-body">
33
+ </div>
34
+ <div class="modal-footer">
35
+ <button type="button" class="btn btn-default" data-dismiss="modal"><%= _('Cancel') %></button>
36
+ <button type="button" class="btn btn-primary" onclick="submit_modal_form()"><%= _('Submit') %></button>
37
+ </div>
38
+ </div><!-- /.modal-content -->
39
+ </div><!-- /.modal-dialog -->
40
+ </div><!-- /.modal -->
41
+ <%= will_paginate_with_info syhostmodels, :more => " - "+_("<b class='select_count'>0</b> selected") %>
@@ -0,0 +1,258 @@
1
+ <div class="four wide right column">
2
+ <button class='btn btn-info' type='button'><a href="javascript:void(0);" class="ui green button icon mini" id="btnExport" onclick="export_excel();">Export</a></button>
3
+
4
+ </div>
5
+ <%= javascript "jquery.cookie", "host_checkbox" %>
6
+ <% title header ||= "" %>
7
+
8
+ <table class="table table-bordered table-striped table-condensed" id="tblExport">
9
+ <thead>
10
+ <tr>
11
+ <th class=''><%= sort :name, :as => _('Name') %></th>
12
+ <% detail_name_no1 = 1 %>
13
+ <% details.each do |detail| %>
14
+
15
+ <th id="td<%= detail_name_no1 %>"><%#= detail.fact_name.name %>
16
+ <br />
17
+ <button type='button'><a href="javascript:void(0);" onclick="DeleteSignColumn(<%= detail_name_no1 %>);"><span class="glyphicon glyphicon-remove" aria-hidden="true"></span></a></button></th>
18
+ <% detail_name_no1 += 1 %>
19
+ <% end %>
20
+ </tr>
21
+ </thead>
22
+ <tbody>
23
+ <% #Host.all.each do |host| %>
24
+ <tr>
25
+ <td class='ellipsis'><%#= name_column(host) %></td>
26
+
27
+ <!-- <% #details.each do |detail| %> -->
28
+ <td>
29
+ <%#= FactValue.where(host_id: host.id, fact_name_id: detail.fact_name_id).last.value rescue nil%>
30
+
31
+
32
+ <%#= get_detail_value(host, detail_name) %>
33
+ </td>
34
+ <%# end %>
35
+
36
+ </tr>
37
+ <% end %>
38
+ </tbody>
39
+ </table>
40
+
41
+
42
+
43
+
44
+
45
+
46
+ <script type="text/javascript">
47
+ function export_excel(){
48
+ var uri = $("#tblExport").battatech_excelexport({
49
+ containerid: "tblExport",
50
+ datatype: 'table',
51
+ returnUri: true
52
+ });
53
+ $("#btnExport").attr('download', 'hosts.xlsx').attr('href', uri).attr('target', '_blank');
54
+ }
55
+
56
+ function DeleteSignColumn(tid) {
57
+ var tab = document.getElementById("tblExport");
58
+ var columnLength = tab.rows[0].cells.length;
59
+ var tr1 = tab.rows[0];
60
+ var columnId = 0;
61
+ tid= "td" + tid
62
+ for(var j=0;j<tr1.cells.length;j++)//取得第几行下面的td个数,再次循环遍历该行下面的td元素
63
+ {
64
+ var cell = tr1.cells[j];//获取某行下面的某个td元素
65
+ if (cell.id == tid) {
66
+ columnId = columnId + j;
67
+ }
68
+ }
69
+ //删除指定单元格
70
+ if (columnId > 0){
71
+ for (var i = 0; i < tab.rows.length; i++) {
72
+ tab.rows[i].deleteCell(columnId);
73
+ }
74
+ }
75
+
76
+ }
77
+ /*
78
+ * jQuery Client Side Excel Export Plugin Library
79
+ * http://www.battatech.com/
80
+ *
81
+ * Copyright (c) 2013 Batta Tech Private Limited
82
+ * Licensed under https://github.com/battatech/battatech_excelexport/blob/master/LICENSE.txt
83
+ */
84
+
85
+ (function ($) {
86
+ var $defaults = {
87
+ containerid: null
88
+ , datatype: 'table'
89
+ , dataset: null
90
+ , columns: null
91
+ , returnUri: false
92
+ , worksheetName: "Sheet1"
93
+ , encoding: "utf-8"
94
+ };
95
+
96
+ var $settings = $defaults;
97
+
98
+ $.fn.battatech_excelexport = function (options) {
99
+ $settings = $.extend({}, $defaults, options);
100
+
101
+ var gridData = [];
102
+ var excelData;
103
+
104
+ return Initialize();
105
+
106
+ function Initialize() {
107
+ var type = $settings.datatype.toLowerCase();
108
+
109
+ BuildDataStructure(type);
110
+
111
+ switch (type) {
112
+ case 'table':
113
+ excelData = Export(ConvertFromTable());
114
+ break;
115
+ case 'json':
116
+ excelData = Export(ConvertDataStructureToTable());
117
+ break;
118
+ case 'xml':
119
+ excelData = Export(ConvertDataStructureToTable());
120
+ break;
121
+ case 'jqgrid':
122
+ excelData = Export(ConvertDataStructureToTable());
123
+ break;
124
+ }
125
+
126
+ if ($settings.returnUri) {
127
+ return excelData;
128
+ }
129
+ else {
130
+ window.open(excelData);
131
+ }
132
+ }
133
+
134
+ function BuildDataStructure(type) {
135
+ switch (type) {
136
+ case 'table':
137
+ break;
138
+ case 'json':
139
+ gridData = $settings.dataset;
140
+ break;
141
+ case 'xml':
142
+ $($settings.dataset).find("row").each(function (key, value) {
143
+ var item = {};
144
+
145
+ if (this.attributes != null && this.attributes.length > 0) {
146
+ $(this.attributes).each(function () {
147
+ item[this.name] = this.value;
148
+ });
149
+
150
+ gridData.push(item);
151
+ }
152
+ });
153
+ break;
154
+ case 'jqgrid':
155
+ $($settings.dataset).find("rows > row").each(function (key, value) {
156
+ var item = {};
157
+
158
+ if (this.children != null && this.children.length > 0) {
159
+ $(this.children).each(function () {
160
+ item[this.tagName] = $(this).text();
161
+ });
162
+
163
+ gridData.push(item);
164
+ }
165
+ });
166
+ break;
167
+ }
168
+ }
169
+
170
+ function ConvertFromTable() {
171
+ var result = $('<div>').append($('#' + $settings.containerid).clone()).html();
172
+ return result;
173
+ }
174
+
175
+ function ConvertDataStructureToTable() {
176
+ var result = "<table>";
177
+
178
+ result += "<thead><tr>";
179
+ $($settings.columns).each(function (key, value) {
180
+ if (this.ishidden != true) {
181
+ result += "<th";
182
+ if (this.width != null) {
183
+ result += " style='width: " + this.width + "'";
184
+ }
185
+ result += ">";
186
+ result += this.headertext;
187
+ result += "</th>";
188
+ }
189
+ });
190
+ result += "</tr></thead>";
191
+
192
+ result += "<tbody>";
193
+ $(gridData).each(function (key, value) {
194
+ result += "<tr>";
195
+ $($settings.columns).each(function (k, v) {
196
+ if (value.hasOwnProperty(this.datafield)) {
197
+ if (this.ishidden != true) {
198
+ result += "<td";
199
+ if (this.width != null) {
200
+ result += " style='width: " + this.width + "'";
201
+ }
202
+ result += ">";
203
+ result += value[this.datafield];
204
+ result += "</td>";
205
+ }
206
+ }
207
+ });
208
+ result += "</tr>";
209
+ });
210
+ result += "</tbody>";
211
+
212
+ result += "</table>";
213
+ return result;
214
+ }
215
+
216
+ function Export(htmltable) {
217
+ var excelFile = "<html xmlns:o='urn:schemas-microsoft-com:office:office' xmlns:x='urn:schemas-microsoft-com:office:excel' xmlns='http://www.w3.org/TR/REC-html40'>";
218
+ excelFile += "<head>";
219
+ excelFile += '<meta http-equiv="Content-type" content="text/html;charset=' + $defaults.encoding + '" />';
220
+ excelFile += "<!--[if gte mso 9]>";
221
+ excelFile += "<xml>";
222
+ excelFile += "<x:ExcelWorkbook>";
223
+ excelFile += "<x:ExcelWorksheets>";
224
+ excelFile += "<x:ExcelWorksheet>";
225
+ excelFile += "<x:Name>";
226
+ excelFile += "{worksheet}";
227
+ excelFile += "</x:Name>";
228
+ excelFile += "<x:WorksheetOptions>";
229
+ excelFile += "<x:DisplayGridlines/>";
230
+ excelFile += "</x:WorksheetOptions>";
231
+ excelFile += "</x:ExcelWorksheet>";
232
+ excelFile += "</x:ExcelWorksheets>";
233
+ excelFile += "</x:ExcelWorkbook>";
234
+ excelFile += "</xml>";
235
+ excelFile += "<![endif]-->";
236
+ excelFile += "</head>";
237
+ excelFile += "<body>";
238
+ excelFile += htmltable.replace(/"/g, '\'');
239
+ excelFile += "</body>";
240
+ excelFile += "</html>";
241
+
242
+ var uri = "data:application/vnd.ms-excel;base64,";
243
+ var ctx = { worksheet: $settings.worksheetName, table: htmltable };
244
+
245
+ return (uri + base64(format(excelFile, ctx)));
246
+ }
247
+
248
+ function base64(s) {
249
+ return window.btoa(unescape(encodeURIComponent(s)));
250
+ }
251
+
252
+ function format(s, c) {
253
+ return s.replace(/{(\w+)}/g, function (m, p) { return c[p]; });
254
+ }
255
+ };
256
+ })(jQuery);
257
+
258
+ </script>
@@ -0,0 +1,37 @@
1
+ <div id="syhostmodeldetails">
2
+ <%= f.fields_for :syhostmodeldetails do |f| %>
3
+ <div class="row">
4
+ <div class="col-md-3 column form-group">
5
+ <label>no</label>
6
+ <%= f.text_field :no, class: "form_datetime form-control" %>
7
+ </div>
8
+ <div class="col-md-3 column form-group">
9
+ <label>status</label>
10
+ <%= f.select :status, [['please select', nil],"true", "false"], placeholder: "status", control_label: 'status', class: "col-md-3 column form-control"%>
11
+ <%#= f.text_field :status, class: "form_datetime form-control" %>
12
+ </div>
13
+
14
+ <div class="col-md-3 column form-group">
15
+ <label>fact_name_id</label><br />
16
+ <%#= f.select :fact_name_id, FactName.all.collect { |p| [ p.name, p.id ] }, include_blank: true , class: "col-md-3 column form-control"%>
17
+
18
+ <%#= f.text_field :fact_name_id, class: "form_datetime form-control" %>
19
+ </div>
20
+ <div class="col-md-1 column form-group">
21
+ <label>delete</label>
22
+ <%= f.link_to_remove "删除", class: "btn btn-danger" %>
23
+ </div>
24
+ </div>
25
+ <%= f.hidden_field :syhostmodel_id, value: object.id %>
26
+ <%= f.hidden_field :syhostmodel_type, value: object.class.to_s %>
27
+ <% end %>
28
+ </div>
29
+ <div class="row">
30
+ <div class="col-md-9 column form-group">
31
+
32
+ </div>
33
+ <div class="col-md-1 column form-group">
34
+ <label></label>
35
+ <%= f.link_to_add "新增", :syhostmodeldetails, :data => { :target => "#syhostmodeldetails" }, class: "btn btn-primary" %>
36
+ </div>
37
+ </div>
@@ -0,0 +1 @@
1
+ <%= render 'form' %>
@@ -0,0 +1,5 @@
1
+ <% if authorized? %>
2
+ <% title_actions button_group(link_to "新增", new_foreman_hosts_syhostmodel_path) %>
3
+ <% end %>
4
+
5
+ <%= render 'list', :syhostmodels => @syhostmodels, :header => @title || _("ExportTemplates") %>
@@ -0,0 +1 @@
1
+ <%= render 'form' %>