ItemProgram.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. <?php
  2. namespace App\Model;
  3. use Illuminate\Database\Eloquent\Model;
  4. class ItemProgram extends Model
  5. {
  6. protected $table = 'item_program';
  7. const INPUT_TYPE_VARIABLE = [
  8. 'varchar1'=>['type' => 'text'],
  9. 'varchar2'=>['type' => 'text'],
  10. 'varchar3'=>['type' => 'text'],
  11. 'varchar4'=>['type' => 'text'],
  12. 'varchar5'=>['type' => 'text'],
  13. 'varchar6'=>['type' => 'text'],
  14. 'varchar7'=>['type' => 'text'],
  15. 'varchar8'=>['type' => 'text'],
  16. 'varchar9'=>['type' => 'text'],
  17. 'varchar10'=>['type' => 'text'],
  18. 'varchar11'=>['type' => 'text'],
  19. 'varchar12'=>['type' => 'text'],
  20. 'varchar13'=>['type' => 'text'],
  21. 'varchar14'=>['type' => 'text'],
  22. 'varchar15'=>['type' => 'text'],
  23. 'varchar16'=>['type' => 'text'],
  24. 'varchar17'=>['type' => 'text'],
  25. 'varchar18'=>['type' => 'text'],
  26. 'varchar19'=>['type' => 'text'],
  27. 'varchar20'=>['type' => 'text'],
  28. 'float1'=>['type' => 'number'],
  29. 'float2'=>['type' => 'number'],
  30. 'float3'=>['type' => 'number'],
  31. 'float4'=>['type' => 'number'],
  32. 'float5'=>['type' => 'number'],
  33. 'float6'=>['type' => 'number'],
  34. 'float7'=>['type' => 'number'],
  35. 'float8'=>['type' => 'number'],
  36. 'float9'=>['type' => 'number'],
  37. 'float10'=>['type' => 'number'],
  38. 'date1'=>['type' => 'date'],
  39. 'date2'=>['type' => 'date'],
  40. 'date3'=>['type' => 'date'],
  41. 'date4'=>['type' => 'date'],
  42. 'date5'=>['type' => 'date'],
  43. 'date6'=>['type' => 'date'],
  44. 'date7'=>['type' => 'date'],
  45. 'date8'=>['type' => 'date'],
  46. 'date9'=>['type' => 'date'],
  47. 'date10'=>['type' => 'date'],
  48. ];
  49. const COLUMN_CLASSIFICATION_VARIABLE = [
  50. 'file' => [
  51. 'varchar1',
  52. 'varchar2',
  53. 'varchar3',
  54. 'varchar4',
  55. 'varchar5',
  56. 'varchar6',
  57. 'varchar7',
  58. 'varchar8',
  59. 'varchar9',
  60. 'varchar10',
  61. 'varchar11',
  62. 'varchar12',
  63. 'varchar13',
  64. 'varchar14',
  65. 'varchar15',
  66. 'varchar16',
  67. 'varchar17',
  68. 'varchar18',
  69. 'varchar19',
  70. 'varchar20',
  71. ],
  72. 'provinsi' => [
  73. 'varchar1',
  74. 'varchar2',
  75. 'varchar3',
  76. 'varchar4',
  77. 'varchar5',
  78. 'varchar6',
  79. 'varchar7',
  80. 'varchar8',
  81. 'varchar9',
  82. 'varchar10',
  83. 'varchar11',
  84. 'varchar12',
  85. 'varchar13',
  86. 'varchar14',
  87. 'varchar15',
  88. 'varchar16',
  89. 'varchar17',
  90. 'varchar18',
  91. 'varchar19',
  92. 'varchar20',
  93. ],
  94. 'kabkot' => [
  95. 'varchar1',
  96. 'varchar2',
  97. 'varchar3',
  98. 'varchar4',
  99. 'varchar5',
  100. 'varchar6',
  101. 'varchar7',
  102. 'varchar8',
  103. 'varchar9',
  104. 'varchar10',
  105. 'varchar11',
  106. 'varchar12',
  107. 'varchar13',
  108. 'varchar14',
  109. 'varchar15',
  110. 'varchar16',
  111. 'varchar17',
  112. 'varchar18',
  113. 'varchar19',
  114. 'varchar20',
  115. ],
  116. 'text' => [
  117. 'varchar1',
  118. 'varchar2',
  119. 'varchar3',
  120. 'varchar4',
  121. 'varchar5',
  122. 'varchar6',
  123. 'varchar7',
  124. 'varchar8',
  125. 'varchar9',
  126. 'varchar10',
  127. 'varchar11',
  128. 'varchar12',
  129. 'varchar13',
  130. 'varchar14',
  131. 'varchar15',
  132. 'varchar16',
  133. 'varchar17',
  134. 'varchar18',
  135. 'varchar19',
  136. 'varchar20',
  137. ],
  138. 'select' => [
  139. 'varchar1',
  140. 'varchar2',
  141. 'varchar3',
  142. 'varchar4',
  143. 'varchar5',
  144. 'varchar6',
  145. 'varchar7',
  146. 'varchar8',
  147. 'varchar9',
  148. 'varchar10',
  149. 'varchar11',
  150. 'varchar12',
  151. 'varchar13',
  152. 'varchar14',
  153. 'varchar15',
  154. 'varchar16',
  155. 'varchar17',
  156. 'varchar18',
  157. 'varchar19',
  158. 'varchar20',
  159. ],
  160. 'number' => [
  161. 'float1',
  162. 'float2',
  163. 'float3',
  164. 'float4',
  165. 'float5',
  166. 'float6',
  167. 'float7',
  168. 'float8',
  169. 'float9',
  170. 'float10',
  171. ],
  172. 'date' => [
  173. 'date1',
  174. 'date2',
  175. 'date3',
  176. 'date4',
  177. 'date5',
  178. 'date6',
  179. 'date7',
  180. 'date8',
  181. 'date9',
  182. 'date10',
  183. ],
  184. ];
  185. protected $fillable = [
  186. 'id_template',
  187. 'id_template_program_detail',
  188. 'kolom',
  189. 'tipe_kolom',
  190. 'order_by',
  191. 'label',
  192. 'status',
  193. 'is_required',
  194. 'id_master_option',
  195. 'created_by',
  196. 'modified_by'
  197. ];
  198. public function templateProgram(){
  199. return $this->belongsTo('App\Model\TemplateProgram', 'id_template');
  200. }
  201. public function masterOption(){
  202. return $this->belongsTo('App\Model\MasterOption', 'id_master_option');
  203. }
  204. public function getTypeAttribute(){
  205. switch ($this->tipe_kolom) {
  206. case 'text':
  207. return 'text';
  208. break;
  209. case 'provinsi':
  210. return 'text';
  211. break;
  212. case 'kabkot':
  213. return 'text';
  214. break;
  215. case 'file':
  216. return 'file';
  217. break;
  218. case 'number':
  219. return 'number';
  220. break;
  221. case 'select':
  222. return 'select';
  223. break;
  224. case 'date':
  225. return 'date';
  226. break;
  227. }
  228. }
  229. }