element_calendar.erl 4.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. -module(element_calendar).
  2. -include_lib("nitro/include/calendar.hrl").
  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. {<<"value">>, case Record#calendar.value of {Yv,Mv,Dv} -> io_lib:format("~4..0B-~2..0B-~2..0B",[Yv,Mv,Dv]); [] -> []; _ -> [] end},
  46. {<<"pattern">>,Record#calendar.pattern},
  47. {<<"placeholder">>,Record#calendar.placeholder},
  48. {<<"onkeypress">>, Record#calendar.onkeypress} | Record#calendar.data_fields
  49. ],
  50. wf_tags:emit_tag(<<"input">>, nitro:render(Record#calendar.body), List).
  51. init(Id,#calendar{minDate=Min,maxDate=Max,lang=Lang,format=Form,
  52. value=Value,onSelect=SelectFn,disableDayFn=DisDayFn,
  53. position=Pos,reposition=Repos,yearRange=YearRange} = Calendar) ->
  54. ID = nitro:to_list(Id),
  55. I18n = "clLangs.ua",
  56. Format = "YYYY-MM-DD",
  57. DefaultDate = case Value of
  58. {Yv,Mv,Dv} -> nitro:f("new Date(~s,~s,~s)",[nitro:to_list(Yv),nitro:to_list(Mv-1),nitro:to_list(Dv)]);
  59. _ -> "new Date(2019, 11, 26)" end,
  60. 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(2009, 3, 4)" end,
  61. 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(2189, 4, 1)" end,
  62. OnSelect = "null",
  63. DisDay = "null",
  64. Position = "bottom left",
  65. Reposition = "true",
  66. nitro:wire(nitro:f(
  67. "pickers['~s'] = new Pikaday({
  68. field: document.getElementById('~s'),
  69. firstDay: 0,
  70. i18n: ~s,
  71. defaultDate: ~s,
  72. setDefaultDate: false,
  73. minDate: ~s,
  74. maxDate: ~s,
  75. format: '~s',
  76. onSelect: ~s,
  77. disableDayFn: ~s,
  78. position: '~s',
  79. reposition: ~s,
  80. yearRange: ~s
  81. });",
  82. [ID,ID,I18n,DefaultDate,MinDate,MaxDate,Format,OnSelect,DisDay,
  83. Position,Reposition,nitro:to_list(YearRange)]
  84. )).