element_calendar.erl 4.1 KB

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