element_calendar.erl 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  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},
  44. {<<"value">>,nitro:js_escape(Record#calendar.value)} | Record#calendar.data_fields
  45. ],
  46. wf_tags:emit_tag(<<"input">>, nitro:render(Record#calendar.body), List).
  47. init(Id,#calendar{minDate=Min,maxDate=Max,lang=Lang,format=Form}) ->
  48. ID = nitro:to_list(Id),
  49. I18n = case Lang of
  50. undefined -> "clLangs.ua";
  51. Lang -> "clLangs."++nitro:to_list(Lang) end,
  52. Format = case Form of
  53. undefined -> "YYYY-MM-DD";
  54. Form -> Form end,
  55. MinDate = case Min of
  56. {Y,M,D} -> nitro:f("new Date(~s,~s,~s)",[nitro:to_list(Y),nitro:to_list(M-1),nitro:to_list(D)]);
  57. _ -> "new Date(2000, 0, 1)" end,
  58. MaxDate = case Max of
  59. {Y1,M1,D1} -> nitro:f("new Date(~s,~s,~s)",[nitro:to_list(Y1),nitro:to_list(M1-1),nitro:to_list(D1)]);
  60. _ -> "new Date(2087, 4, 13)" end,
  61. nitro:wire(nitro:f(
  62. "pickers['~s'] = new Pikaday({
  63. field: document.getElementById('~s'),
  64. firstDay: 1,
  65. i18n: ~s,
  66. minDate: ~s,
  67. maxDate: ~s,
  68. format: '~s'
  69. });",
  70. [ID,ID,I18n,MinDate,MaxDate,Format]
  71. )).