diff options
author | ivan <ivan> | 2008-12-09 01:46:53 +0000 |
---|---|---|
committer | ivan <ivan> | 2008-12-09 01:46:53 +0000 |
commit | de1e1a1c2563a9741a5be44f997889f7c37c36ed (patch) | |
tree | a2a9f5df86d825cf706a82d30995a96710a38800 /httemplate | |
parent | 6115c160d19e6c82e3f713d0d79128fbf45e46da (diff) |
use common base for inventory import too, fixes problems with errors due to dos line endings and allows Excel upload, RT#4346
Diffstat (limited to 'httemplate')
-rw-r--r-- | httemplate/misc/inventory_item-import.html | 56 | ||||
-rw-r--r-- | httemplate/misc/process/inventory_item-import.html | 17 |
2 files changed, 52 insertions, 21 deletions
diff --git a/httemplate/misc/inventory_item-import.html b/httemplate/misc/inventory_item-import.html index f3636c0e7..65a123e2a 100644 --- a/httemplate/misc/inventory_item-import.html +++ b/httemplate/misc/inventory_item-import.html @@ -1,14 +1,54 @@ -<% include("/elements/header.html", $inventory_class->classname. 's') %> +<% include("/elements/header.html", PL($inventory_class->classname)) %> -<FORM ACTION="process/inventory_item-import.html" METHOD="POST" ENCTYPE="multipart/form-data"> -<INPUT TYPE="hidden" NAME="classnum" VALUE="<% $classnum %>"> -Import a file containing <% $inventory_class->classname %>s, one per line.<BR><BR> +Import a file containing <% PL($inventory_class->classname) %>, one per line. +<BR><BR> -Filename: <INPUT TYPE="file" NAME="filename"><BR><BR> +<% include( '/elements/form-file_upload.html', + 'name' => 'InventoryItemImportForm', + 'action' => 'process/inventory_item-import.html', + 'num_files' => 1, + #'fields' => [ 'format', 'itembatch', 'classnum', ], + 'fields' => [ 'format', 'classnum', ], + 'message' => 'Inventory import successful', + #XXX redirect via $itembatch? or just back to class browse? + 'url' => $p."search/inventory_item.html?classnum=$classnum;avail=1", + ) +%> + +<% &ntable("#cccccc", 2) %> + + <INPUT TYPE="hidden" NAME="format" VALUE="default"> + + <INPUT TYPE="hidden" NAME="classnum" VALUE="<% $classnum %>"> + +%# <INPUT TYPE="hidden" NAME="itembatch" VALUE="<% $itembatch %>"> + + <% include( '/elements/file-upload.html', + 'field' => 'file', + 'label' => 'Filename', + ) + %> + + <TR> + <TD COLSPAN=2 ALIGN="center" STYLE="padding-top:6px"> + <INPUT TYPE = "submit" + ID = "submit" + VALUE = "Import file" + onClick = "document.InventoryItemImportForm.submit.disabled=true;" + > + </TD> + </TR> + +</TABLE> -<INPUT TYPE="submit" VALUE="Upload"> </FORM> +<BR> + +Upload file can be a text file or Excel spreadsheet. If an Excel spreadsheet, + should have an .XLS extension. +<BR><BR> + <% include('/elements/footer.html') %> <%init> @@ -20,4 +60,8 @@ $cgi->param =~ /^(\d+)$/ or errorpage("illegal classnum"); my $classnum = $1; my $inventory_class = qsearchs('inventory_class', { 'classnum' => $classnum } ); +#my $conf = new FS::Conf; +#my $itembatch = +# time2str('webimport-%Y/%m/%d-%T'. "-$$-". rand() * 2**32, time); + </%init> diff --git a/httemplate/misc/process/inventory_item-import.html b/httemplate/misc/process/inventory_item-import.html index 3aae202c7..377943fb1 100644 --- a/httemplate/misc/process/inventory_item-import.html +++ b/httemplate/misc/process/inventory_item-import.html @@ -1,22 +1,9 @@ -% if ( $error ) { -% errorpage($error); -% } else { - <% include("/elements/header.html",'Import successful') %> - <!-- XXX redirect to batch search like the payment entry... --> - <% include("/elements/footer.html",'Import successful') %> -% } +<% $server->process %> <%init> die "access denied" unless $FS::CurrentUser::CurrentUser->access_right('Import'); -my $fh = $cgi->upload('filename'); - -my $error = defined($fh) - ? FS::inventory_item::batch_import( { - 'filehandle' => $fh, - 'classnum' => $cgi->param('classnum'), - } ) - : 'No file'; +my $server = new FS::UI::Web::JSRPC 'FS::inventory_item::process_batch_import', $cgi; </%init> |