element_calendar.erl 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. -module(element_calendar).
  2. %%-author('G-Grand').
  3. -include_lib("nitro/include/calendar.hrl").
  4. -include_lib("nitro/include/nitro.hrl").
  5. -include_lib("nitro/include/event.hrl").
  6. -export([render_element/1]).
  7. render_element(Record) when Record#calendar.show_if == false -> [<<>>];
  8. render_element(Record) ->
  9. Id = case Record#calendar.postback of
  10. [] -> Record#calendar.id;
  11. Postback ->
  12. ID0 = case Record#calendar.id of
  13. [] -> nitro:temp_id();
  14. I -> I
  15. end,
  16. nitro:wire(#event{type = click, postback = Postback, target = ID0,
  17. source = Record#calendar.source, delegate = Record#calendar.delegate }),
  18. ID0
  19. end,
  20. init(Id, Record),
  21. List = [
  22. %% global
  23. {<<"accesskey">>, Record#calendar.accesskey},
  24. {<<"class">>, Record#calendar.class},
  25. {<<"contenteditable">>,
  26. case Record#calendar.contenteditable of
  27. true -> "true";
  28. false -> "false";
  29. _ -> []
  30. end},
  31. {<<"contextmenu">>, Record#calendar.contextmenu},
  32. {<<"dir">>,
  33. case Record#calendar.dir of
  34. ltr -> "ltr";
  35. rtl -> "rtl";
  36. auto -> "auto";
  37. _ -> []
  38. end},
  39. {<<"draggable">>,
  40. case Record#calendar.draggable of
  41. true -> "true";
  42. false -> "false";
  43. _ -> []
  44. end},
  45. {<<"dropzone">>, Record#calendar.dropzone},
  46. {<<"hidden">>,
  47. case Record#calendar.hidden of
  48. true -> "hidden";
  49. _ -> []
  50. end},
  51. {<<"id">>, Id},
  52. {<<"spellcheck">>,
  53. case Record#calendar.spellcheck of
  54. true -> "true";
  55. false -> "false";
  56. _ -> []
  57. end},
  58. {<<"style">>, Record#calendar.style},
  59. {<<"tabindex">>, Record#calendar.tabindex},
  60. {<<"title">>, Record#calendar.title},
  61. {<<"translate">>,
  62. case Record#calendar.contenteditable of
  63. true -> "yes";
  64. false -> "no";
  65. _ -> []
  66. end},
  67. %% spec
  68. {<<"autocomplete">>,
  69. case Record#calendar.autocomplete of
  70. true -> "on";
  71. false -> "off";
  72. _ -> []
  73. end},
  74. {<<"autofocus">>,
  75. case Record#calendar.autofocus of
  76. true -> "autofocus";
  77. _ -> []
  78. end},
  79. {<<"disabled">>,
  80. case Record#calendar.disabled of
  81. true -> "disabled";
  82. _ -> []
  83. end},
  84. {<<"form">>, Record#calendar.form},
  85. {<<"list">>, Record#calendar.list},
  86. {<<"name">>, Record#calendar.name},
  87. {<<"readonly">>,
  88. case Record#calendar.readonly of
  89. true -> "readonly";
  90. _ -> []
  91. end},
  92. {<<"required">>,
  93. case Record#calendar.required of
  94. true -> "required";
  95. _ -> []
  96. end},
  97. {<<"step">>, Record#calendar.step},
  98. {<<"type">>, <<"calendar">>},
  99. {<<"pattern">>, Record#calendar.pattern},
  100. {<<"placeholder">>, Record#calendar.placeholder},
  101. {<<"onkeypress">>, Record#calendar.onkeypress} | Record#calendar.data_fields
  102. ],
  103. wf_tags:emit_tag(<<"input">>, nitro:render(Record#calendar.body), List).
  104. init(Id0, #calendar{minDate = Min, maxDate = Max, lang = Lang,
  105. format = Form, value = Value, onSelect = SelectFn,
  106. disableDayFn = DisDayFn, firstDay = FirstDay, position = Pos,
  107. reposition = Repos, yearRange = YearRange} = _Calendar) ->
  108. ID = nitro:to_list(Id0),
  109. I18n = case Lang of
  110. [] -> "clLangs.ua";
  111. Lang -> "clLangs." ++ nitro:to_list(Lang)
  112. end,
  113. DefaultDate = case Value of
  114. {Yv, Mv, Dv} ->
  115. nitro:f("new Date(~s,~s,~s)", [nitro:to_list(Yv), nitro:to_list(Mv - 1), nitro:to_list(Dv) ]);
  116. _ -> "''"
  117. end,
  118. MinDate = case Min of
  119. {Y, M, D} ->
  120. nitro:f("new Date(~s,~s,~s)", [nitro:to_list(Y), nitro:to_list(M - 1), nitro:to_list(D) ]);
  121. _ -> "new Date(2000, 0, 1)"
  122. end,
  123. MaxDate = case Max of
  124. {Y1, M1, D1} ->
  125. nitro:f("new Date(~s,~s,~s)", [nitro:to_list(Y1), nitro:to_list(M1 - 1), nitro:to_list(D1) ]);
  126. _ -> "new Date(2135, 4, 13)"
  127. end,
  128. OnSelect = case SelectFn of
  129. [] -> "null";
  130. _ -> SelectFn
  131. end,
  132. DisDay = case DisDayFn of
  133. [] -> "null";
  134. _ ->
  135. nitro:f("function(thisDate){return ~s(thisDate);}", [DisDayFn] )
  136. end,
  137. Position = case Pos of
  138. [] -> "bottom left";
  139. _ -> nitro:to_list(Pos)
  140. end,
  141. Reposition = case Repos of
  142. [] -> "true";
  143. _ -> nitro:to_list(Repos)
  144. end,
  145. WeekFirstDay = nitro:to_list(FirstDay),
  146. nitro:wire(nitro:f(
  147. "pickers['~s'] = new Pikaday({"
  148. "field: document.getElementById('~s'),"
  149. "i18n: ~s,"
  150. "defaultDate: ~s,"
  151. "setDefaultDate: true,"
  152. "firstDay: ~s,"
  153. "minDate: ~s,"
  154. "maxDate: ~s,"
  155. "format: '~s',"
  156. "onSelect: ~s,"
  157. "disableDayFn: ~s,"
  158. "position: '~s',"
  159. "reposition: ~s,"
  160. "yearRange: ~s"
  161. "});",
  162. [ID, ID, I18n, DefaultDate, WeekFirstDay, MinDate, MaxDate, Form, OnSelect, DisDay, Position, Reposition, nitro:to_list(YearRange) ] )).