time_table 0.1.3 → 0.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,75 @@
1
+ class TimeTableRenderer {
2
+ createEventElement({start, end}) {
3
+ const element = document.createElement("div");
4
+
5
+ element.classList.add("event");
6
+ element.setAttribute("data-time-table-target", "event");
7
+ element.setAttribute("data-action", "mousedown->time-table#startDragEvent");
8
+ element.setAttribute("data-time-table-drag-event-param", "move");
9
+
10
+ element.innerHTML = `
11
+ <div class="event-name"><span style="font-weight: 400; color: gray;">(No Title)</span></div>
12
+ <div class="event-time" data-action="mousedown->time-table#startDragEvent" data-time-table-drag-event-param="resize">
13
+ ${ this.#durationString(start.time, end.time) }
14
+ </div>
15
+ `;
16
+
17
+ this.updateEventElement(element, {start, end});
18
+
19
+ return element;
20
+ }
21
+
22
+ updateEventElement(element, {start, end}) {
23
+ element.style.setProperty("top", `${start.location}px`);
24
+ element.style.setProperty("height", `${end.location - start.location}px`);
25
+
26
+ this.setSpecialClasses(element);
27
+
28
+ element.querySelector(".event-time").innerHTML = this.#durationString(start.time, end.time);
29
+
30
+ return element;
31
+ }
32
+
33
+ timestamp(time) {
34
+ let timestampeElement = document.createElement("div");
35
+ timestampeElement.classList.add("timestamp");
36
+ timestampeElement.classList.add("out-of-bounds");
37
+ timestampeElement.setAttribute("data-time-table-target", "timestamp");
38
+ timestampeElement.setAttribute("data-action", "mousedown->time-table#startDragEvent");
39
+ timestampeElement.setAttribute("data-time-table-drag-event-param", "rescale");
40
+
41
+ timestampeElement.innerHTML = `
42
+ <div class="label" data-action="mousedown->time-table#startDragEvent" data-time-table-drag-event-param="rescale">
43
+ ${this.#timeString(time, "short")}
44
+ </div>
45
+ `;
46
+
47
+ return timestampeElement;
48
+ }
49
+
50
+ setSpecialClasses(element) {
51
+ element.classList.toggle("tiny", element.offsetHeight < 15);
52
+ element.classList.toggle("small", element.offsetHeight < 45);
53
+ }
54
+
55
+ #timeString(date, format = "long") {
56
+ let hours = date.getUTCHours();
57
+ let minutes = date.getUTCMinutes();
58
+ let ampm = hours >= 12 ? 'PM' : 'AM';
59
+ hours = hours % 12;
60
+ hours = hours ? hours : 12; // the hour '0' should be '12'
61
+
62
+ minutes = minutes < 10 ? '0' + minutes : minutes;
63
+ if(format == "long") {
64
+ return hours + ':' + minutes + ' ' + ampm;
65
+ } else if (format == "short") {
66
+ return hours + ampm
67
+ }
68
+ }
69
+
70
+ #durationString(startTime, endTime) {
71
+ return `${this.#timeString(startTime)} - ${this.#timeString(endTime)}`;
72
+ }
73
+ }
74
+
75
+ export default new TimeTableRenderer();
@@ -15,9 +15,12 @@
15
15
  position: relative;
16
16
  height: calc(100%);
17
17
  flex-grow: 1;
18
+ /* padding-right: 20px; */
18
19
  }
19
20
 
20
21
  .timetable .timestamps {
22
+ /* width: 40px; */
23
+ /* overflow: show; */
21
24
  }
22
25
 
23
26
  .timetable:hover {
@@ -30,7 +33,8 @@
30
33
 
31
34
  .timestamps {
32
35
  position: absolute;
33
- left: 5px;
36
+ left: 0;
37
+ padding-left: 5px;
34
38
  right: 0;
35
39
  display: flex;
36
40
  flex-direction: column;
@@ -39,7 +43,7 @@
39
43
  /* height: 50px; */
40
44
  justify-content: space-between;
41
45
  /* z-index: 100; */
42
- overflow: visible;
46
+ /* overflow: visible; */
43
47
  }
44
48
 
45
49
  .timestamps .timestamp {
@@ -51,11 +55,21 @@
51
55
  overflow: visible;
52
56
  }
53
57
 
58
+ .timestamps .timestamp.out-of-bounds {
59
+ color: rgb(168, 167, 167);
60
+ }
61
+
54
62
  .timestamp .label {
55
63
  margin-top: -0.5em;
64
+ height: 100%;
65
+ width: fit-content;
66
+ z-index: 5;
56
67
  /* z-index: 1000; */
57
68
  }
58
69
 
70
+ .timestamp .label:hover {
71
+ cursor: ns-resize;
72
+ }
59
73
 
60
74
  .timestamps .timestamp::before {
61
75
  content: "";
@@ -1,9 +1,9 @@
1
1
  module TimeTable
2
2
  module TimeTableHelper
3
- def time_table(date = nil, scale: 100, events: [], &block)
3
+ def time_table(date = nil, frozen: false, scale: 60, events: [], clip: 15, &block)
4
4
  # @time_table = TimeTable.new
5
5
  # @time_table.scale = scale
6
- timetable = Timetable.new(date, scale: scale)
6
+ timetable = Timetable.new(date, scale: scale, clip_size: clip, frozen: frozen)
7
7
  render "time_table/time_table", timetable: timetable, events: events, &block
8
8
  end
9
9
 
@@ -12,7 +12,7 @@ module TimeTable
12
12
 
13
13
 
14
14
  class Timetable
15
- attr_accessor :start_time, :end_time, :segment_size, :segment_scale, :clip_size, :clock_type
15
+ attr_accessor :start_time, :end_time, :segment_size, :segment_scale, :clip_size, :clock_type, :frozen
16
16
 
17
17
  def initialize(date = nil, **options)
18
18
  @start_time = options[:start_time] || 0
@@ -23,6 +23,7 @@ module TimeTable
23
23
  @segment_scale = options[:scale] || 100
24
24
  @clip_size = options[:clip_size] || 15
25
25
  @clock_type = options[:clock_type] || :meridian
26
+ @frozen = options[:frozen] || false
26
27
  end
27
28
 
28
29
  def segments
@@ -6,6 +6,7 @@
6
6
  mousemove->time-table#drag
7
7
  ",
8
8
  time_table_drag_event_param: "create",
9
+ timetable_frozen_param: timetable.frozen,
9
10
  timetable_clip_size: timetable.clip_size,
10
11
  timetable_scale: timetable.segment_scale,
11
12
  timetable_start_time: timetable.start_time.iso8601,
@@ -14,8 +15,8 @@
14
15
 
15
16
  <div class="timestamps">
16
17
  <% 24.times do |hour| %>
17
- <div class="timestamp">
18
- <div class="label">
18
+ <div class="timestamp" data-time-table-target="timestamp">
19
+ <div class="label" data-action="mousedown->time-table#startDragEvent" data-time-table-drag-event-param="rescale">
19
20
  <%= hour == 0 ? "12 AM" : (hour > 12 ? "#{hour - 12} PM" : "#{hour} AM") %>
20
21
  </div>
21
22
  </div>
@@ -1,3 +1,3 @@
1
1
  module TimeTable
2
- VERSION = "0.1.3"
2
+ VERSION = "0.1.5"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: time_table
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.3
4
+ version: 0.1.5
5
5
  platform: ruby
6
6
  authors:
7
7
  - Joshua Hadik
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2025-04-28 00:00:00.000000000 Z
11
+ date: 2025-05-09 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rails
@@ -39,6 +39,12 @@ files:
39
39
  - app/assets/javascript/time_table/controllers/application.js
40
40
  - app/assets/javascript/time_table/controllers/index.js
41
41
  - app/assets/javascript/time_table/controllers/time_table_controller.js
42
+ - app/assets/javascript/time_table/controllers/time_table_controller_old.js
43
+ - app/assets/javascript/time_table/controllers/time_table_controller_pre_time_keeper.js
44
+ - app/assets/javascript/time_table/helpers/drag_event_state.js
45
+ - app/assets/javascript/time_table/helpers/scroll_frame.js
46
+ - app/assets/javascript/time_table/helpers/time_keeper.js
47
+ - app/assets/javascript/time_table/helpers/time_table_renderer.js
42
48
  - app/assets/stylesheets/time_table/application.css
43
49
  - app/assets/stylesheets/time_table/time_table.css
44
50
  - app/controllers/time_table/application_controller.rb