colombia_170_2.cif 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. <?php
  2. /**
  3. * Implements hook_install() using the name of the country as the base of
  4. * the function name.
  5. */
  6. function colombia_install() {
  7. // Make the entry in the country table.
  8. // VALUES = Country ID, Country Name, 2-digit Code, 3-digit Code, File Version
  9. db_insert('uc_countries')
  10. ->fields(array(
  11. 'country_id' => 170,
  12. 'country_name' => 'Colombia',
  13. 'country_iso_code_2' => 'CO',
  14. 'country_iso_code_3' => 'COL',
  15. 'version' => 2,
  16. ))
  17. ->execute();
  18. // Make the entries in the zones table.
  19. $zones = array(
  20. array(170, 'DC', 'Distrito Capital de Bogotá'),
  21. array(170, 'AMA', 'Amazonas'),
  22. array(170, 'ANT', 'Antioquia'),
  23. array(170, 'ARA', 'Arauca'),
  24. array(170, 'ATL', 'Atlántico'),
  25. array(170, 'BOL', 'Bolívar'),
  26. array(170, 'BOY', 'Boyacá'),
  27. array(170, 'CAL', 'Caldas'),
  28. array(170, 'CAQ', 'Caquetá'),
  29. array(170, 'CAS', 'Casanare'),
  30. array(170, 'CAU', 'Cauca'),
  31. array(170, 'CES', 'Cesar'),
  32. array(170, 'COR', 'Córdoba'),
  33. array(170, 'CUN', 'Cundinamarca'),
  34. array(170, 'CHO', 'Chocó'),
  35. array(170, 'GUA', 'Guainía'),
  36. array(170, 'GUV', 'Guaviare'),
  37. array(170, 'HUI', 'Huila'),
  38. array(170, 'LAG', 'La Guajira'),
  39. array(170, 'MAG', 'Magdalena'),
  40. array(170, 'MET', 'Meta'),
  41. array(170, 'NAR', 'Nariño'),
  42. array(170, 'NSA', 'Norte de Santander'),
  43. array(170, 'PUT', 'Putumayo'),
  44. array(170, 'QUI', 'Quindío'),
  45. array(170, 'RIS', 'Risaralda'),
  46. array(170, 'SAP', 'San Andrés, Providencia y Santa Catalina'),
  47. array(170, 'SAN', 'Santander'),
  48. array(170, 'SUC', 'Sucre'),
  49. array(170, 'TOL', 'Tolima'),
  50. array(170, 'VAC', 'Valle del Cauca'),
  51. array(170, 'VAU', 'Vaupés'),
  52. array(170, 'VID', 'Vichada'),
  53. );
  54. $query = db_insert('uc_zones')->fields(array('zone_country_id', 'zone_code', 'zone_name'));
  55. foreach ($zones as $zone) {
  56. $query->values($zone);
  57. }
  58. $query->execute();
  59. // Set address format.
  60. uc_set_address_format(
  61. 170,
  62. "!company\r\n" .
  63. "!first_name !last_name\r\n" .
  64. "!street1\r\n" .
  65. "!street2\r\n" .
  66. "!city !zone_code !postal_code\r\n" .
  67. "!country_name_if"
  68. );
  69. }
  70. /**
  71. * Implements hook_update() with $version being the only argument.
  72. * Add a new case for each version update, and be sure to always include the
  73. * latest changes in the install function.
  74. */
  75. function colombia_update($version) {
  76. switch ($version) {
  77. case 2:
  78. // Add missing zone.
  79. $zones = array(
  80. array(170, 'BOY', 'Boyacá'),
  81. );
  82. $query = db_insert('uc_zones')->fields(array('zone_country_id', 'zone_code', 'zone_name'));
  83. foreach ($zones as $zone) {
  84. $query->values($zone);
  85. }
  86. $query->execute();
  87. // Rename zones.
  88. db_update('uc_zones')
  89. ->fields(array('zone_name' => 'Distrito Capital de Bogotá'))
  90. ->condition('zone_country_id', 170)
  91. ->condition('zone_code', 'DC')
  92. ->execute();
  93. db_update('uc_zones')
  94. ->fields(array('zone_name' => 'Atlántico'))
  95. ->condition('zone_country_id', 170)
  96. ->condition('zone_code', 'ATL')
  97. ->execute();
  98. db_update('uc_zones')
  99. ->fields(array('zone_name' => 'Bolívar'))
  100. ->condition('zone_country_id', 170)
  101. ->condition('zone_code', 'BOL')
  102. ->execute();
  103. db_update('uc_zones')
  104. ->fields(array('zone_name' => 'Caquetá'))
  105. ->condition('zone_country_id', 170)
  106. ->condition('zone_code', 'CAQ')
  107. ->execute();
  108. db_update('uc_zones')
  109. ->fields(array('zone_name' => 'Córdoba'))
  110. ->condition('zone_country_id', 170)
  111. ->condition('zone_code', 'COR')
  112. ->execute();
  113. db_update('uc_zones')
  114. ->fields(array('zone_name' => 'Chocó'))
  115. ->condition('zone_country_id', 170)
  116. ->condition('zone_code', 'CHO')
  117. ->execute();
  118. db_update('uc_zones')
  119. ->fields(array('zone_name' => 'Guainía'))
  120. ->condition('zone_country_id', 170)
  121. ->condition('zone_code', 'GUA')
  122. ->execute();
  123. db_update('uc_zones')
  124. ->fields(array('zone_name' => 'Nariño'))
  125. ->condition('zone_country_id', 170)
  126. ->condition('zone_code', 'NAR')
  127. ->execute();
  128. db_update('uc_zones')
  129. ->fields(array('zone_name' => 'Quindío'))
  130. ->condition('zone_country_id', 170)
  131. ->condition('zone_code', 'QUI')
  132. ->execute();
  133. db_update('uc_zones')
  134. ->fields(array('zone_name' => 'San Andrés, Providencia y Santa Catalina'))
  135. ->condition('zone_country_id', 170)
  136. ->condition('zone_code', 'SAP')
  137. ->execute();
  138. db_update('uc_zones')
  139. ->fields(array('zone_name' => 'Vaupés'))
  140. ->condition('zone_country_id', 170)
  141. ->condition('zone_code', 'VAU')
  142. ->execute();
  143. break;
  144. }
  145. }