element_calendar.erl 4.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. -module(element_calendar).
  2. -author('G-Grand').
  3. -include_lib("nitro/include/nitro.hrl").
  4. -include_lib("nitro/include/event.hrl").
  5. -export([render_element/1]).
  6. render_element(Record) when Record#calendar.show_if==false -> [<<>>];
  7. render_element(Record) ->
  8. Id = case Record#calendar.postback of
  9. [] -> Record#calendar.id;
  10. Postback ->
  11. ID = case Record#calendar.id of
  12. [] -> nitro:temp_id();
  13. I -> I end,
  14. nitro:wire(#event{type=click, postback=Postback, target=ID,
  15. source=Record#calendar.source, delegate=Record#calendar.delegate }),
  16. ID end,
  17. init(Id,Record),
  18. List = [
  19. %global
  20. {<<"accesskey">>, Record#calendar.accesskey},
  21. {<<"class">>, Record#calendar.class},
  22. {<<"contenteditable">>, case Record#calendar.contenteditable of true -> "true"; false -> "false"; _ -> [] end},
  23. {<<"contextmenu">>, Record#calendar.contextmenu},
  24. {<<"dir">>, case Record#calendar.dir of "ltr" -> "ltr"; "rtl" -> "rtl"; "auto" -> "auto"; _ -> [] end},
  25. {<<"draggable">>, case Record#calendar.draggable of true -> "true"; false -> "false"; _ -> [] end},
  26. {<<"dropzone">>, Record#calendar.dropzone},
  27. {<<"hidden">>, case Record#calendar.hidden of "hidden" -> "hidden"; _ -> [] end},
  28. {<<"id">>, Id},
  29. {<<"spellcheck">>, case Record#calendar.spellcheck of true -> "true"; false -> "false"; _ -> [] end},
  30. {<<"style">>, Record#calendar.style},
  31. {<<"tabindex">>, Record#calendar.tabindex},
  32. {<<"title">>, Record#calendar.title},
  33. {<<"translate">>, case Record#calendar.contenteditable of "yes" -> "yes"; "no" -> "no"; _ -> [] end},
  34. % spec
  35. {<<"autocomplete">>, case Record#calendar.autocomplete of true -> "on"; false -> "off"; _ -> [] end},
  36. {<<"autofocus">>,if Record#calendar.autofocus == true -> "autofocus"; true -> [] end},
  37. {<<"disabled">>, if Record#calendar.disabled == true -> "disabled"; true -> [] end},
  38. {<<"form">>,Record#calendar.form},
  39. {<<"list">>,Record#calendar.list},
  40. {<<"name">>,Record#calendar.name},
  41. {<<"readonly">>,if Record#calendar.readonly == true -> "readonly"; true -> [] end},
  42. {<<"required">>,if Record#calendar.required == true -> "required"; true -> [] end},
  43. {<<"step">>,Record#calendar.step},
  44. {<<"type">>, <<"calendar">>},
  45. {<<"pattern">>,Record#calendar.pattern},
  46. {<<"placeholder">>,Record#calendar.placeholder},
  47. {<<"onkeypress">>, Record#calendar.onkeypress} | Record#calendar.data_fields
  48. ],
  49. wf_tags:emit_tag(<<"input">>, nitro:render(Record#calendar.body), List).
  50. init(Id,#calendar{minDate=Min,maxDate=Max,lang=Lang,format=Form,value=Value,onSelect=SelectFn,disableDayFn=DisDayFn, position=Pos,reposition=Repos,yearRange=YearRange}) ->
  51. ID = nitro:to_list(Id),
  52. I18n = case Lang of [] -> "clLangs.ua"; Lang -> "clLangs."++nitro:to_list(Lang) end,
  53. Format = case Form of [] -> "YYYY-MM-DD"; Form -> Form end,
  54. DefaultDate = case Value of {Yv,Mv,Dv} -> nitro:f("new Date(~s,~s,~s)",[nitro:to_list(Yv),nitro:to_list(Mv-1),nitro:to_list(Dv)]); _ -> "null" end,
  55. MinDate = case Min of {Y,M,D} -> nitro:f("new Date(~s,~s,~s)",[nitro:to_list(Y), nitro:to_list(M-1), nitro:to_list(D)]); _ -> "new Date(2000, 0, 1)" end,
  56. MaxDate = case Max of {Y1,M1,D1} -> nitro:f("new Date(~s,~s,~s)",[nitro:to_list(Y1),nitro:to_list(M1-1),nitro:to_list(D1)]); _ -> "new Date(2087, 4, 13)" end,
  57. OnSelect = case SelectFn of [] -> "null"; _ -> SelectFn end,
  58. DisDay = case DisDayFn of [] -> "null"; _ -> nitro:f("function(thisDate){return ~s(thisDate);}",[DisDayFn]) end,
  59. Position = case Pos of [] -> "bottom left"; _ -> nitro:to_list(Pos) end,
  60. Reposition = case Repos of [] -> "true"; _ -> nitro:to_list(Repos) end,
  61. nitro:wire(nitro:f(
  62. "pickers['~s'] = new Pikaday({
  63. field: document.getElementById('~s'),
  64. firstDay: 1,
  65. i18n: ~s,
  66. defaultDate: ~s,
  67. setDefaultDate: true,
  68. minDate: ~s,
  69. maxDate: ~s,
  70. format: '~s',
  71. onSelect: ~s,
  72. disableDayFn: ~s,
  73. position: '~s',
  74. reposition: ~s,
  75. yearRange: ~s
  76. });",
  77. [ID,ID,I18n,DefaultDate,MinDate,MaxDate,Format,OnSelect,DisDay,Position,Reposition,nitro:to_list(YearRange)]
  78. )).