fmsystem-commits
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Fmsystem-commits] [11821] Merge 11815:11820 from trunk


From: Sigurd Nes
Subject: [Fmsystem-commits] [11821] Merge 11815:11820 from trunk
Date: Fri, 14 Mar 2014 12:00:53 +0000

Revision: 11821
          http://svn.sv.gnu.org/viewvc/?view=rev&root=fmsystem&revision=11821
Author:   sigurdne
Date:     2014-03-14 12:00:52 +0000 (Fri, 14 Mar 2014)
Log Message:
-----------
Merge 11815:11820 from trunk

Modified Paths:
--------------
    branches/Version-1_0-branch/property/inc/class.bocommon.inc.php
    branches/Version-1_0-branch/property/inc/class.uiimport.inc.php
    
branches/Version-1_0-branch/property/inc/import/default/cvs_import_fiktiv_faktura_nlsh

Property Changed:
----------------
    branches/Version-1_0-branch/


Property changes on: branches/Version-1_0-branch
___________________________________________________________________
Modified: svn:mergeinfo
   - 
/trunk:6439-6441,6443,6445-6447,6449-6464,6466-6468,6470-6474,6476-6477,6479-6480,6483-6488,6490-6491,6493-6494,6496-6501,6503-6504,6506,6508,6510-6511,6513,6515-6516,6518,6520-6524,6526-6528,6533-6534,6536-6541,6543-6565,6567,6569,6571-6576,6578,6580-6586,6588-6596,6598-6600,6602-6604,6606-6607,6609-6611,6613-6625,6629-6639,6641-6643,6645-6646,6648,6650-6654,6656-6659,6661-6663,6665-6666,6668-6669,6672-6673,6675,6677-6678,6680,6682-6686,6688-6717,6719,6721-6722,6724-6728,6730,6732-6734,6736-6739,6741,6743,6745-6746,6748-6756,6758-6762,6764,6766-6788,6790,6792-6798,6800-6814,6816-6819,6821-6822,6824-6826,6828-6837,6839,6841,6843-6849,6851,6853-6869,6871-6874,6876-6877,6879,6881,6883,6885-6886,6888-6893,6895-6897,6899-6901,6903,6905-6907,6909,6911-6929,6931-6936,6938-6947,6949,6951,6953,6955-6956,6958-6959,6961-6968,6970-6971,6973-6974,6976-6978,6980,6982-7017,7019-7025,7027-7035,7037-7039,7041-7045,7047-7055,7057,7059-7065,7067-7069,7071,7073,7075-7076,7078,7080-7081,7083,7085,7087,7089-7097,7099-7102,7104-7105,7107-7111,7113-7120,7122-7124,7126-7129,7131,7133-7141,7143,7145-7146,7148-7150,7152-7153,7155-7158,7160-7164,7166-7167,7169-7170,7172,7174,7176,7178,7180-7181,7183,7185,7187-7188,7190,7192-7196,7198-7199,7201-7203,7205,7207,7209-7210,7212,7214,7216-7217,7219-7222,7224-7226,7228-7229,7231,7233-7234,7236-7238,7240-7241,7243-7244,7246,7248,7250,7252-7256,7258-7259,7261-7264,7266-7273,7275-7279,7281-7332,7334-7338,7340-7348,7350,7352-7353,7355-7361,7363-7366,7368-7370,7372,7374,7376,7378,7380-7386,7388-7400,7402,7404-7433,7435-7439,7441-7446,7448-7458,7460-7469,7471-7483,7485-7487,7489-7490,7492,7494,7496-7497,7499,7501-7502,7504,7506-7507,7509-7511,7513-7517,7519-7521,7523,7525,7527-7529,7531,7533,7535-7538,7540-7542,7544-7549,7551-7552,7554-7561,7563,7565,7567-7573,7575-7578,7580-7584,7586-7591,7593-7624,7627-7636,7638-7656,7658-7718,7720-7732,7734,7736,7738-7750,7754-7759,7761-7767,7769-7780,7782,7784-7809,7811-7812,7814-7835,7837-7847,7849-7887,7889-7895,7897,7899,7901,7903-7905,7907-7921,7923-7925,7927-7933,7935,7937-7952,7954-7968,7970-7974,7976,7978-7979,7981-7982,7984-7988,7990-7992,7994-8041,8043-8066,8068-8087,8089,8091-8108,8110-8124,8126-8129,8131,8133-8150,8152-8154,8156-8162,8164-8167,8169-8170,8172-8179,8181,8183-8196,8198-8207,8209-8211,8213-8214,8216-8217,8219-8220,8222,8224-8225,8227-8247,8249,8251,8253-8282,8284-8352,8354-8368,8370-8396,8398-8430,8432,8434-8440,8442-8445,8447-8453,8455-8456,8458,8460,8462-8464,8466-8473,8475-8479,8481,8483-8501,8503-8523,8525,8527-8531,8533,8535-8536,8538-8550,8552-8554,8556-8557,8559-8579,8581-8587,8589,8591-8592,8594-8595,8597-8601,8603-8610,8612-8613,8615,8617,8619-8645,8647-8650,8652-8661,8663-8666,8668-8669,8671-8683,8685-8691,8693-8730,8732-8737,8739,8741-8767,8769,8771-8772,8774,8776-8797,8799-8812,8814-8819,8821,8823-8833,8835-8837,8839,8841,8843-8849,8852-8858,8860-8867,8869-8870,8872,8874-8877,8879,8881,8883-8888,8890,8892-8901,8903-8911,8913-8917,8920-8923,8925-8933,8935-8938,8940-8943,8945,8947-8948,8950,8952-8953,8955-8962,8964,8966,8968-8970,8972-8975,8977-8983,8985-8993,8995-9001,9003,9005,9007,9009,9011-9019,9021-9023,9025,9027-9028,9030-9044,9046-9047,9049-9050,9052-9056,9058-9059,9061,9063-9064,9066-9068,9071-9092,9094-9112,9114-9117,9119,9121-9160,9162-9166,9169-9207,9209-9211,9213-9215,9217,9219,9221-9253,9255,9257,9259-9260,9262,9264-9269,9271-9273,9275,9277-9278,9280,9282-9283,9285-9289,9291-9299,9301-9310,9312-9313,9315-9320,9322-9324,9326-9338,9340-9342,9344,9346-9348,9350-9358,9360-9362,9364-9366,9368-9374,9376-9382,9384,9386,9388-9390,9392-9396,9398-9402,9404-9410,9412,9414,9416-9417,9419-9425,9427,9429-9430,9432,9434-9463,9465-9502,9504-9506,9508-9521,9523-9526,9528,9530-9537,9539,9541-9551,9553,9555-9556,9558-9578,9580-9581,9583,9585,9587,9589,9591-9624,9626-9655,9657-9700,9702-9726,9728-9729,9731-9749,9751,9753-9754,9756-9832,9834-9836,9838-9839,9841-9846,9848-9850,9852-9858,9860-9863,9865,9867,9869-9871,9873-9893,9895,9897-9912,9914-9919,9921-9928,9930-9952,9954,9956,9958-9963,9965-9993,9995-9997,9999-10001,10003-10004,10006-10007,10009-10012,10014-10031,10033-10073,10075-10107,10109-10165,10167-10210,10222-10226,10228-10311,10313-10378,10380,10382,10384-10393,10395-10478,10480-10482,10484-10494,10496-10503,10505,10507,10509-10521,10523,10525-10528,10530-10540,10542-10543,10545-10568,10570-10584,10586-10590,10592-10594,10596,10598-10599,10601-10611,10613,10615,10617-10626,10628-10636,10638,10640-10654,10656-10658,10660,10662-10672,10674,10676-10682,10684,10686,10688-10690,10692-10694,10696-10697,10699-10701,10703,10705-10706,10708-10724,10726-10731,10734,10736-10748,10750-10796,10798-10939,10941,10943,10945,10947-10953,10955,10957-10961,10963,10965-10966,10968-11001,11003-11030,11032-11034,11036,11038,11040,11042-11053,11055-11059,11061-11062,11064-11068,11070-11073,11075-11077,11079-11083,11085,11087-11088,11090-11093,11095-11108,11110-11111,11113,11115-11116,11118-11120,11122,11124-11129,11131-11132,11134,11136,11138,11140-11151,11153-11161,11163-11185,11187-11189,11191-11229,11231,11233,11235-11264,11266-11267,11269-11278,11280-11282,11284-11291,11293-11295,11297,11299-11302,11304,11306,11309,11311,11313-11316,11318-11323,11325-11332,11334,11336-11344,11346,11348-11354,11356,11358-11360,11363-11386,11388-11389,11391-11392,11394,11396-11403,11405-11406,11408,11410,11412,11415,11417,11419-11420,11422,11424-11429,11431-11442,11444-11445,11447-11460,11462-11464,11466-11470,11472-11475,11477-11478,11480-11487,11489-11492,11494,11496,11498,11500-11502,11504-11506,11508,11510-11511,11513,11515,11517-11523,11525-11526,11528-11531,11533,11535-11538,11540-11546,11548-11560,11563-11572,11574,11576,11578,11580-11581,11583,11585,11587,11589-11592,11594-11595,11597,11599,11601,11603,11605-11607,11609-11611,11613,11615-11619,11621-11622,11624-11630,11632,11634-11635,11637,11639-11640,11642,11644-11655,11657-11659,11661-11675,11677-11679,11681-11684,11686,11688,11690-11691,11693-11706,11708-11709,11711-11714,11716-11718,11720-11728,11730,11732,11734-11739,11741-11757,11759-11760,11762-11766,11768,11770-11771,11773,11775,11777,11779-11780,11782,11784,11786,11788,11790,11792-11793,11795,11797,11799,11801,11803-11804,11806-11807,11809,11811-11814
   + 
/trunk:6439-6441,6443,6445-6447,6449-6464,6466-6468,6470-6474,6476-6477,6479-6480,6483-6488,6490-6491,6493-6494,6496-6501,6503-6504,6506,6508,6510-6511,6513,6515-6516,6518,6520-6524,6526-6528,6533-6534,6536-6541,6543-6565,6567,6569,6571-6576,6578,6580-6586,6588-6596,6598-6600,6602-6604,6606-6607,6609-6611,6613-6625,6629-6639,6641-6643,6645-6646,6648,6650-6654,6656-6659,6661-6663,6665-6666,6668-6669,6672-6673,6675,6677-6678,6680,6682-6686,6688-6717,6719,6721-6722,6724-6728,6730,6732-6734,6736-6739,6741,6743,6745-6746,6748-6756,6758-6762,6764,6766-6788,6790,6792-6798,6800-6814,6816-6819,6821-6822,6824-6826,6828-6837,6839,6841,6843-6849,6851,6853-6869,6871-6874,6876-6877,6879,6881,6883,6885-6886,6888-6893,6895-6897,6899-6901,6903,6905-6907,6909,6911-6929,6931-6936,6938-6947,6949,6951,6953,6955-6956,6958-6959,6961-6968,6970-6971,6973-6974,6976-6978,6980,6982-7017,7019-7025,7027-7035,7037-7039,7041-7045,7047-7055,7057,7059-7065,7067-7069,7071,7073,7075-7076,7078,7080-7081,7083,7085,7087,7089-7097,7099-7102,7104-7105,7107-7111,7113-7120,7122-7124,7126-7129,7131,7133-7141,7143,7145-7146,7148-7150,7152-7153,7155-7158,7160-7164,7166-7167,7169-7170,7172,7174,7176,7178,7180-7181,7183,7185,7187-7188,7190,7192-7196,7198-7199,7201-7203,7205,7207,7209-7210,7212,7214,7216-7217,7219-7222,7224-7226,7228-7229,7231,7233-7234,7236-7238,7240-7241,7243-7244,7246,7248,7250,7252-7256,7258-7259,7261-7264,7266-7273,7275-7279,7281-7332,7334-7338,7340-7348,7350,7352-7353,7355-7361,7363-7366,7368-7370,7372,7374,7376,7378,7380-7386,7388-7400,7402,7404-7433,7435-7439,7441-7446,7448-7458,7460-7469,7471-7483,7485-7487,7489-7490,7492,7494,7496-7497,7499,7501-7502,7504,7506-7507,7509-7511,7513-7517,7519-7521,7523,7525,7527-7529,7531,7533,7535-7538,7540-7542,7544-7549,7551-7552,7554-7561,7563,7565,7567-7573,7575-7578,7580-7584,7586-7591,7593-7624,7627-7636,7638-7656,7658-7718,7720-7732,7734,7736,7738-7750,7754-7759,7761-7767,7769-7780,7782,7784-7809,7811-7812,7814-7835,7837-7847,7849-7887,7889-7895,7897,7899,7901,7903-7905,7907-7921,7923-7925,7927-7933,7935,7937-7952,7954-7968,7970-7974,7976,7978-7979,7981-7982,7984-7988,7990-7992,7994-8041,8043-8066,8068-8087,8089,8091-8108,8110-8124,8126-8129,8131,8133-8150,8152-8154,8156-8162,8164-8167,8169-8170,8172-8179,8181,8183-8196,8198-8207,8209-8211,8213-8214,8216-8217,8219-8220,8222,8224-8225,8227-8247,8249,8251,8253-8282,8284-8352,8354-8368,8370-8396,8398-8430,8432,8434-8440,8442-8445,8447-8453,8455-8456,8458,8460,8462-8464,8466-8473,8475-8479,8481,8483-8501,8503-8523,8525,8527-8531,8533,8535-8536,8538-8550,8552-8554,8556-8557,8559-8579,8581-8587,8589,8591-8592,8594-8595,8597-8601,8603-8610,8612-8613,8615,8617,8619-8645,8647-8650,8652-8661,8663-8666,8668-8669,8671-8683,8685-8691,8693-8730,8732-8737,8739,8741-8767,8769,8771-8772,8774,8776-8797,8799-8812,8814-8819,8821,8823-8833,8835-8837,8839,8841,8843-8849,8852-8858,8860-8867,8869-8870,8872,8874-8877,8879,8881,8883-8888,8890,8892-8901,8903-8911,8913-8917,8920-8923,8925-8933,8935-8938,8940-8943,8945,8947-8948,8950,8952-8953,8955-8962,8964,8966,8968-8970,8972-8975,8977-8983,8985-8993,8995-9001,9003,9005,9007,9009,9011-9019,9021-9023,9025,9027-9028,9030-9044,9046-9047,9049-9050,9052-9056,9058-9059,9061,9063-9064,9066-9068,9071-9092,9094-9112,9114-9117,9119,9121-9160,9162-9166,9169-9207,9209-9211,9213-9215,9217,9219,9221-9253,9255,9257,9259-9260,9262,9264-9269,9271-9273,9275,9277-9278,9280,9282-9283,9285-9289,9291-9299,9301-9310,9312-9313,9315-9320,9322-9324,9326-9338,9340-9342,9344,9346-9348,9350-9358,9360-9362,9364-9366,9368-9374,9376-9382,9384,9386,9388-9390,9392-9396,9398-9402,9404-9410,9412,9414,9416-9417,9419-9425,9427,9429-9430,9432,9434-9463,9465-9502,9504-9506,9508-9521,9523-9526,9528,9530-9537,9539,9541-9551,9553,9555-9556,9558-9578,9580-9581,9583,9585,9587,9589,9591-9624,9626-9655,9657-9700,9702-9726,9728-9729,9731-9749,9751,9753-9754,9756-9832,9834-9836,9838-9839,9841-9846,9848-9850,9852-9858,9860-9863,9865,9867,9869-9871,9873-9893,9895,9897-9912,9914-9919,9921-9928,9930-9952,9954,9956,9958-9963,9965-9993,9995-9997,9999-10001,10003-10004,10006-10007,10009-10012,10014-10031,10033-10073,10075-10107,10109-10165,10167-10210,10222-10226,10228-10311,10313-10378,10380,10382,10384-10393,10395-10478,10480-10482,10484-10494,10496-10503,10505,10507,10509-10521,10523,10525-10528,10530-10540,10542-10543,10545-10568,10570-10584,10586-10590,10592-10594,10596,10598-10599,10601-10611,10613,10615,10617-10626,10628-10636,10638,10640-10654,10656-10658,10660,10662-10672,10674,10676-10682,10684,10686,10688-10690,10692-10694,10696-10697,10699-10701,10703,10705-10706,10708-10724,10726-10731,10734,10736-10748,10750-10796,10798-10939,10941,10943,10945,10947-10953,10955,10957-10961,10963,10965-10966,10968-11001,11003-11030,11032-11034,11036,11038,11040,11042-11053,11055-11059,11061-11062,11064-11068,11070-11073,11075-11077,11079-11083,11085,11087-11088,11090-11093,11095-11108,11110-11111,11113,11115-11116,11118-11120,11122,11124-11129,11131-11132,11134,11136,11138,11140-11151,11153-11161,11163-11185,11187-11189,11191-11229,11231,11233,11235-11264,11266-11267,11269-11278,11280-11282,11284-11291,11293-11295,11297,11299-11302,11304,11306,11309,11311,11313-11316,11318-11323,11325-11332,11334,11336-11344,11346,11348-11354,11356,11358-11360,11363-11386,11388-11389,11391-11392,11394,11396-11403,11405-11406,11408,11410,11412,11415,11417,11419-11420,11422,11424-11429,11431-11442,11444-11445,11447-11460,11462-11464,11466-11470,11472-11475,11477-11478,11480-11487,11489-11492,11494,11496,11498,11500-11502,11504-11506,11508,11510-11511,11513,11515,11517-11523,11525-11526,11528-11531,11533,11535-11538,11540-11546,11548-11560,11563-11572,11574,11576,11578,11580-11581,11583,11585,11587,11589-11592,11594-11595,11597,11599,11601,11603,11605-11607,11609-11611,11613,11615-11619,11621-11622,11624-11630,11632,11634-11635,11637,11639-11640,11642,11644-11655,11657-11659,11661-11675,11677-11679,11681-11684,11686,11688,11690-11691,11693-11706,11708-11709,11711-11714,11716-11718,11720-11728,11730,11732,11734-11739,11741-11757,11759-11760,11762-11766,11768,11770-11771,11773,11775,11777,11779-11780,11782,11784,11786,11788,11790,11792-11793,11795,11797,11799,11801,11803-11804,11806-11807,11809,11811-11814,11816-11820

Modified: branches/Version-1_0-branch/property/inc/class.bocommon.inc.php
===================================================================
--- branches/Version-1_0-branch/property/inc/class.bocommon.inc.php     
2014-03-14 11:51:30 UTC (rev 11820)
+++ branches/Version-1_0-branch/property/inc/class.bocommon.inc.php     
2014-03-14 12:00:52 UTC (rev 11821)
@@ -1520,8 +1520,10 @@
                 * @param array $name array containing keys in $list
                 * @param array $descr array containing Names for the heading 
of the output for the coresponding keys in $list
                 * @param array $input_type array containing information 
whether fields are to be suppressed from the output
+                * @param array $identificator array containing 1.row for 
identification purposes in case of data import.
+                * @param string $filename
                 */
-               function download($list,$name,$descr,$input_type=array())
+               function 
download($list,$name,$descr,$input_type=array(),$identificator = 
array(),$filename = '')
                {
                        set_time_limit(500);
                        $GLOBALS['phpgw_info']['flags']['noheader'] = true;
@@ -1533,13 +1535,13 @@
                        switch ($export_format)
                        {
                                case 'csv':
-                                       
$this->csv_out($list,$name,$descr,$input_type);
+                                       
$this->csv_out($list,$name,$descr,$input_type,$identificator,$filename);
                                        break;
                                case 'excel':
-                                       
$this->excel_out($list,$name,$descr,$input_type);
+                                       
$this->excel_out($list,$name,$descr,$input_type,$identificator,$filename);
                                        break;
                                case 'ods':
-                                       
$this->ods_out($list,$name,$descr,$input_type);
+                                       
$this->ods_out($list,$name,$descr,$input_type,$identificator,$filename);
                                        break;
                        }
                }
@@ -1551,13 +1553,22 @@
                 * @param array $name array containing keys in $list
                 * @param array $descr array containing Names for the heading 
of the output for the coresponding keys in $list
                 * @param array $input_type array containing information 
whether fields are to be suppressed from the output
+                * @param array $identificator array containing 1.row for 
identification purposes in case of data import.
+                * @param string $filename
                 */
-               function excel_out($list,$name,$descr,$input_type=array())
+               function 
excel_out($list,$name,$descr,$input_type=array(),$identificator=array(),$filename
 = '')
                {
                        phpgw::import_class('phpgwapi.phpexcel');
+                       if($filename)
+                       {
+                               $filename_arr = explode('.', str_replace(' 
','_',basename($filename)));
+                               $filename = $filename_arr[0].'.xlsx';
+                       }
+                       else
+                       {
+                               $filename= str_replace(' 
','_',$GLOBALS['phpgw_info']['user']['account_lid']).'.xlsx';                   
       
+                       }
 
-                       $filename= str_replace(' 
','_',$GLOBALS['phpgw_info']['user']['account_lid']).'.xlsx';
-
                        $browser = CreateObject('phpgwapi.browser');
 //                     
$browser->content_header($filename,'application/vnd.ms-excel');
                        
$browser->content_header($filename,'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
@@ -1579,6 +1590,22 @@
                        // Set active sheet index to the first sheet, so Excel 
opens this as the first sheet
                        $objPHPExcel->setActiveSheetIndex(0);
 
+                       if($identificator)
+                       {
+                               $_first_row = 2;
+                               $i = 0;
+                               foreach($identificator as $key => $value)
+                               {
+                                       
$objPHPExcel->setActiveSheetIndex(0)->setCellValueByColumnAndRow($i, 1, $key);
+                                       $i++;
+                                       
$objPHPExcel->setActiveSheetIndex(0)->setCellValueByColumnAndRow($i, 1, $value);
+                                       $i++;
+                               }
+                       }
+                       else
+                       {
+                               $_first_row = 1;
+                       }
                        $count_uicols_name=count($name);
 
                        $text_format = array();
@@ -1593,7 +1620,7 @@
                                                
//$objPHPExcel->getActiveSheet()->getStyle('B3:B7')->applyFromArray($styleArray);
 
                                        }
-                                       
$objPHPExcel->setActiveSheetIndex(0)->setCellValueByColumnAndRow($m, 1, 
$descr[$k]);
+                                       
$objPHPExcel->setActiveSheetIndex(0)->setCellValueByColumnAndRow($m, 
$_first_row, $descr[$k]);
                                        $m++;
                                }
                        }
@@ -1615,7 +1642,7 @@
                                        $j++;
                                }
 
-                               $line = 1;
+                               $line = $_first_row;
                                $col = 'A';
 
                                foreach($content as $row)
@@ -1713,9 +1740,18 @@
                 * @param array $descr array containing Names for the heading 
of the output for the coresponding keys in $list
                 * @param array $input_type array containing information 
whether fields are to be suppressed from the output
                 */
-               function csv_out($list, $name, $descr, $input_type = array() )
+               function csv_out($list, $name, $descr, $input_type = array(), 
$identificator=array(),$filename = '')
                {
-                       $filename= str_replace(' 
','_',$GLOBALS['phpgw_info']['user']['account_lid']).'.csv';
+                       if($filename)
+                       {
+                               $filename_arr = explode('.', str_replace(' 
','_',basename($filename)));
+                               $filename = $filename_arr[0].'.csv';
+                       }
+                       else
+                       {
+                               $filename= str_replace(' 
','_',$GLOBALS['phpgw_info']['user']['account_lid']).'.csv';
+                       }
+
                        $browser = CreateObject('phpgwapi.browser');
                        $browser->content_header($filename, 'application/csv');
 
@@ -1724,6 +1760,17 @@
                                die('Unable to write to "php://output" - pleace 
notify the Administrator');
                        }
 
+                       if($identificator)
+                       {
+                               $_identificator = array();
+                               foreach($identificator as $key => $value)
+                               {
+                                       $_identificator[] =  $key;
+                                       $_identificator[] =  $value;
+                               }
+                               fputcsv($fp, $_identificator, ';');
+                       }
+
                        $count_uicols_name=count($name);
 
                        $header = array();
@@ -1763,9 +1810,18 @@
                 * @param array $descr array containing Names for the heading 
of the output for the coresponding keys in $list
                 * @param array $input_type array containing information 
whether fields are to be suppressed from the output
                 */
-               function ods_out($list, $name, $descr, $input_type = array() )
+               function ods_out($list, $name, $descr, $input_type = array(), 
$identificator=array(),$filename = '')
                {
-                       $filename= str_replace(' 
','_',$GLOBALS['phpgw_info']['user']['account_lid']).'.ods';
+                       if($filename)
+                       {
+                               $filename_arr = explode('.', str_replace(' 
','_',basename($filename)));
+                               $filename = $filename_arr[0].'.ods';
+                       }
+                       else
+                       {
+                               $filename= str_replace(' 
','_',$GLOBALS['phpgw_info']['user']['account_lid']).'.ods';
+                       }
+
                        $browser = CreateObject('phpgwapi.browser');
                        $browser->content_header($filename, 'application/ods');
 
@@ -1774,12 +1830,29 @@
                        $ods = createObject('property.ods');
                        $object = $ods->newOds(); //create a new ods file
 
+                       if($identificator)
+                       {
+                               $_first_row = 1;
+                               $i = 0;
+                               foreach($identificator as $key => $value)
+                               {
+                                       $object->addCell(1, 0, $i, $key, 
'string');
+                                       $i++;
+                                       $object->addCell(1, 0, $i, $value, 
'string');
+                                       $i++;
+                               }
+                       }
+                       else
+                       {
+                               $_first_row = 0;
+                       }
+
                        $m=0;
                        for ($k=0;$k<$count_uicols_name;$k++)
                        {
                                if(!isset($input_type[$k]) || 
$input_type[$k]!='hidden')
                                {
-                                       $object->addCell(1, 0, $m, $descr[$k], 
'string');
+                                       $object->addCell(1, $_first_row, $m, 
$descr[$k], 'string');
                                        $m++;
                                }
                        }
@@ -1801,14 +1874,14 @@
                                        $j++;
                                }
 
-                               $line = 0;
+                               $line = $_first_row +1;
                                foreach($content as $row)
                                {
-                                       $line++;
                                        for ($i=0; $i<count($row); $i++)
                                        {
                                                $object->addCell(1, $line, $i, 
$row[$i], 'string');
                                        }
+                                       $line++;
                                }
                        }
 

Modified: branches/Version-1_0-branch/property/inc/class.uiimport.inc.php
===================================================================
--- branches/Version-1_0-branch/property/inc/class.uiimport.inc.php     
2014-03-14 11:51:30 UTC (rev 11820)
+++ branches/Version-1_0-branch/property/inc/class.uiimport.inc.php     
2014-03-14 12:00:52 UTC (rev 11821)
@@ -26,6 +26,7 @@
                protected $fields = array();
                protected $table;
                protected $debug;
+               protected $identificator;
 
                // Label on the import button. Changes as we step through the 
import process.
                protected $import_button_label;
@@ -90,6 +91,7 @@
                        $this->download_template_button_label = 'Download 
template';
 
                        $check_method = 0;
+                       $get_identificator = false;
                        if($this->conv_type = phpgw::get_var('conv_type'))
                        {
                                $check_method ++;
@@ -97,11 +99,13 @@
                        if ($location_id = phpgw::get_var('location_id', 'int'))
                        {
                                $check_method ++;
+                               $get_identificator = true;
                        }
                                
                        if($table = phpgw::get_var('table'))
                        {
                                $check_method ++;
+                               $get_identificator = true;
                        }
 
                        if($check_method > 1)
@@ -190,12 +194,12 @@
                                                case 
'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet':
                                                case 
'application/vnd.oasis.opendocument.spreadsheet':
                                                case 'application/vnd.ms-excel':
-                                                       $this->csvdata = 
$this->getexceldata($file['name']);
+                                                       $this->csvdata = 
$this->getexceldata($file['name'],$get_identificator);
                                                        $valid_type = true;
                                                        break;
                                                case 'text/csv':
                                                case 
'text/comma-separated-values':
-                                                       $this->csvdata = 
$this->getcsvdata($file['name']);
+                                                       $this->csvdata = 
$this->getcsvdata($file['name'],$get_identificator);
                                                        $valid_type = true;
                                                        break;
                                                default:
@@ -389,6 +393,7 @@
 
                protected function get_template($location_id = 0)
                {
+                       $_identificator = array();
                        $data = array();
                        $_fields = array();
                        if(!$location_id && $this->table)
@@ -422,6 +427,14 @@
                        }
                        else if($location_id)
                        {
+                               $system_location = 
$GLOBALS['phpgw']->locations->get_name($location_id);
+                               $_identificator = array
+                               (
+                                       'identificator' => 
"location::{$system_location['appname']}::{$system_location['location']}"
+                               );
+                               
+                               $filename = 
"fm_entity_{$category['entity_id']}_{$category['id']}";
+
                                $entity_id = $category['entity_id'];
                                $cat_id = $category['id'];
 
@@ -490,9 +503,40 @@
                                        }
                                }
                        }
+                       if(!$_identificator && $this->table)
+                       {
+                               $_identificator = array
+                               (
+                                       'identificator' => 
"table::{$this->table}"
+                               );
+                               $filename = $this->table;
 
-                       $fields = array_keys($_fields);
+                       }
+                       else if(!$_identificator && $this->conv_type)
+                       {
+                               $_identificator = array
+                               (
+                                       'identificator' => 
"conversion::{$this->conv_type}"
+                               );
 
+                               if ( preg_match('/\.\./', $this->conv_type) )
+                               {
+                                               throw new Exception("Not a 
valid file: {$this->conv_type}");
+                               }
+
+                               $file = PHPGW_SERVER_ROOT . 
"/property/inc/import/{$GLOBALS['phpgw_info']['user']['domain']}/{$this->conv_type}";
+
+                               if ( is_file($file) )
+                               {
+                                       require_once $file;
+                               }
+                               $_import_conversion = new 
import_conversion(0,false,true);
+                               $fields = $_import_conversion->fields;
+                               $filename = 
$_import_conversion->filename_template;
+                       }
+
+                       $fields = $fields ? $fields : array_keys($_fields);
+
                        if(phpgw::get_var('debug', 'bool'))
                        {
                                _debug_array($fields);
@@ -500,13 +544,46 @@
                        else
                        {
                                $bocommon = CreateObject('property.bocommon');
-                               $bocommon->download($data, $fields, $fields);
+                               $bocommon->download($data, $fields, 
$fields,array(),$_identificator,$filename);
                                $GLOBALS['phpgw']->common->phpgw_exit();
                        }
                }
 
                protected function import_data()
                {
+                       if(!$this->identificator)
+                       {
+                               throw new Exception("Missing identificator in 
dataset");
+                       }
+                       $identificator_arr = explode("::", 
$this->identificator);
+                       switch($identificator_arr[0])
+                       {
+                               case 'location':
+                                       
if(!$GLOBALS['phpgw']->locations->get_id($identificator_arr[1], 
$identificator_arr[2]))
+                                       {
+                                               throw new Exception("No valid 
location: {$identificator_arr[2]}");
+                                       }
+                                       break;
+                               case 'table':
+                                       if($this->table && 
$identificator_arr[1] != $this->table)
+                                       {
+                                               throw new Exception("Not the 
intended target? got: {$identificator_arr[1]} , expected: {$this->table}");
+                                       }
+                                       break;
+                               case 'conversion':
+                                       if($this->conv_type && 
$identificator_arr[1] != $this->conv_type)
+                                       {
+                                               throw new Exception("Not the 
intended target? got: {$identificator_arr[1]} , expected: {$this->conv_type}");
+                                       }
+                                       break;
+                               default:
+                                       throw new Exception("No valid 
location");
+
+                       }
+                       _debug_array($this->csvdata);
+_debug_array($this->fields);
+                       _debug_array($this->identificator);die();
+
                        $metadata = array();
                        if($this->table && $this->fields)
                        {
@@ -598,17 +675,20 @@
                }
 
 
-               protected function getcsvdata($path, $skipfirstline = true)
+               protected function getcsvdata($path, $get_identificator = true)
                {
                        // Open the csv file
                        $handle = fopen($path, "r");
 
-                       if ($skipfirstline)
+                       if($get_identificator)
                        {
-                               // Read the first line to get the headers out 
of the way
-                               $this->fields = $this->getcsv($handle);
+                               $_identificator_arr = $this->getcsv($handle);
+                               $this->identificator = $_identificator_arr[1];
                        }
 
+                       // Read the first line to get the headers out of the way
+                       $this->fields = $this->getcsv($handle);
+
                        $result = array();
 
                        while(($data = $this->getcsv($handle)) !== false)
@@ -625,7 +705,7 @@
                }
 
 
-               protected function getexceldata($path, $skipfirstline = true)
+               protected function getexceldata($path, $get_identificator = 
false)
                {
                        phpgw::import_class('phpgwapi.phpexcel');
 
@@ -640,12 +720,20 @@
 
                        $rows = 
$objPHPExcel->getActiveSheet()->getHighestDataRow();
 
-                       $start = $skipfirstline ? 2 : 1; // Read the first line 
to get the headers out of the way
+                       $start = $get_identificator ? 3 : 1; // Read the first 
line to get the headers out of the way
 
-                       if ($skipfirstline)
+                       if($get_identificator)
                        {
+                               $this->identificator = 
$objPHPExcel->getActiveSheet()->getCellByColumnAndRow(1,1)->getCalculatedValue();
                                for ($j=0; $j < $highestColumnIndex; $j++ )
                                {
+                                       $this->fields[] = 
$objPHPExcel->getActiveSheet()->getCellByColumnAndRow($j,2)->getCalculatedValue();
+                               }
+                       }
+                       else
+                       {
+                               for ($j=0; $j < $highestColumnIndex; $j++ )
+                               {
                                        $this->fields[] = 
$objPHPExcel->getActiveSheet()->getCellByColumnAndRow($j,1)->getCalculatedValue();
                                }
                        }

Modified: 
branches/Version-1_0-branch/property/inc/import/default/cvs_import_fiktiv_faktura_nlsh
===================================================================
--- 
branches/Version-1_0-branch/property/inc/import/default/cvs_import_fiktiv_faktura_nlsh
      2014-03-14 11:51:30 UTC (rev 11820)
+++ 
branches/Version-1_0-branch/property/inc/import/default/cvs_import_fiktiv_faktura_nlsh
      2014-03-14 12:00:52 UTC (rev 11821)
@@ -10,9 +10,19 @@
                protected $year;
                protected $month;
                protected $date;
+               public $fields = array('Hovedgruppering', 'Art', 'Hjelpetekst', 
'Koststed', 'Beløp', 'Best.nr');
+               public $filename_template;
 
-               public function __construct($location_id,$debug = false)
+               public function __construct($location_id,$debug = false, 
$get_template = false)
                {
+                       /*
+                        * The purpose is to get to the fields definition
+                        */
+                       if($get_template)
+                       {
+                               $this->filename_template = "DTDRIFT rapport til 
Portico " . date(Ym);// 201401"
+                               return;
+                       }
                        set_time_limit(10000); //Set the time limit for this 
request
                        $this->account          = 
(int)$GLOBALS['phpgw_info']['user']['account_id'];
                        $this->db           = & $GLOBALS['phpgw']->db;
@@ -48,7 +58,6 @@
 
                public function add($data)
                {
-
 /*
     [0] => Hovedgruppering
     [1] => Art




reply via email to

[Prev in Thread] Current Thread [Next in Thread]