element_calendar.erl 3.9 KB

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