ariadne_view_components 0.0.57-x86_64-linux → 0.0.59-x86_64-linux

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.
@@ -6,7 +6,6 @@ import OptionsController from './options_controller/options_controller';
6
6
  import AccumulatorController from './accumulator_controller/accumulator_controller';
7
7
  import ToggleableController from './toggleable_controller/toggleable_controller';
8
8
  import ClipboardCopyComponent from './clipboard_copy_component/clipboard-copy-component';
9
- import RichTextAreaComponent from './rich_text_area_component/rich-text-area-component';
10
9
  import SlideoverComponent from './slideover_component/slideover-component';
11
10
  import TabNavComponent from './tab_nav_component/tab-nav-component';
12
11
  import TooltipComponent from './tooltip_component/tooltip-component';
@@ -15,7 +14,6 @@ import './time_ago_component/time-ago-component';
15
14
  const application = Application.start();
16
15
  application.register('clipboard-copy-component', ClipboardCopyComponent);
17
16
  application.register('ariadne-form', AriadneForm);
18
- application.register('rich-text-area-component', RichTextAreaComponent);
19
17
  application.register('slideover-component', SlideoverComponent);
20
18
  application.register('tab-nav-component', TabNavComponent);
21
19
  application.register('tooltip-component', TooltipComponent);
@@ -8,7 +8,6 @@ import OptionsController from './options_controller/options_controller'
8
8
  import AccumulatorController from './accumulator_controller/accumulator_controller'
9
9
  import ToggleableController from './toggleable_controller/toggleable_controller'
10
10
  import ClipboardCopyComponent from './clipboard_copy_component/clipboard-copy-component'
11
- import RichTextAreaComponent from './rich_text_area_component/rich-text-area-component'
12
11
  import SlideoverComponent from './slideover_component/slideover-component'
13
12
  import TabNavComponent from './tab_nav_component/tab-nav-component'
14
13
  import TooltipComponent from './tooltip_component/tooltip-component'
@@ -20,7 +19,6 @@ const application = Application.start()
20
19
 
21
20
  application.register('clipboard-copy-component', ClipboardCopyComponent)
22
21
  application.register('ariadne-form', AriadneForm)
23
- application.register('rich-text-area-component', RichTextAreaComponent)
24
22
  application.register('slideover-component', SlideoverComponent)
25
23
  application.register('tab-nav-component', TabNavComponent)
26
24
  application.register('tooltip-component', TooltipComponent)
@@ -3,6 +3,6 @@
3
3
  # :nocov:
4
4
  module Ariadne
5
5
  module ViewComponents
6
- VERSION = "0.0.57"
6
+ VERSION = "0.0.59"
7
7
  end
8
8
  end
@@ -14,7 +14,6 @@
14
14
  "Ariadne::ClipboardCopyComponent": "",
15
15
  "Ariadne::CloseButtonComponent": "",
16
16
  "Ariadne::ComboboxComponent": "",
17
- "Ariadne::CommentComponent": "",
18
17
  "Ariadne::ContainerComponent": "",
19
18
  "Ariadne::Content": "",
20
19
  "Ariadne::CounterComponent": "",
@@ -44,7 +43,6 @@
44
43
  "Ariadne::PopoverComponent": "",
45
44
  "Ariadne::ProgressBarComponent": "",
46
45
  "Ariadne::RelativeTimeComponent": "",
47
- "Ariadne::RichTextAreaComponent": "",
48
46
  "Ariadne::ShowMoreButtonComponent": "",
49
47
  "Ariadne::SlideoverComponent": "",
50
48
  "Ariadne::SpinnerComponent": "",
@@ -253,13 +253,6 @@
253
253
  "div"
254
254
  ]
255
255
  },
256
- "Ariadne::CommentComponent": {
257
- "DEFAULT_CLASSES": "ariadne-border-gray-300 ariadne-border ariadne-shadow ariadne-py-5 ariadne-px-5 ariadne-rounded-md ",
258
- "DEFAULT_TAG": "div",
259
- "TAG_OPTIONS": [
260
- "div"
261
- ]
262
- },
263
256
  "Ariadne::ContainerComponent": {
264
257
  "DEFAULT_CLASSES": "ariadne-px-4 sm:ariadne-px-6 lg:ariadne-px-8"
265
258
  },
@@ -698,10 +691,6 @@
698
691
  "span"
699
692
  ]
700
693
  },
701
- "Ariadne::RichTextAreaComponent": {
702
- "DEFAULT_CLASSES": "",
703
- "DEFAULT_TAG": "div"
704
- },
705
694
  "Ariadne::ShowMoreButtonComponent": {
706
695
  "DEFAULT_ATTRIBUTES": {
707
696
  "wrapper": {
data/static/statuses.json CHANGED
@@ -14,7 +14,6 @@
14
14
  "Ariadne::ClipboardCopyComponent": "stable",
15
15
  "Ariadne::CloseButtonComponent": "stable",
16
16
  "Ariadne::ComboboxComponent": "stable",
17
- "Ariadne::CommentComponent": "stable",
18
17
  "Ariadne::ContainerComponent": "stable",
19
18
  "Ariadne::Content": "stable",
20
19
  "Ariadne::CounterComponent": "stable",
@@ -44,7 +43,6 @@
44
43
  "Ariadne::PopoverComponent": "stable",
45
44
  "Ariadne::ProgressBarComponent": "stable",
46
45
  "Ariadne::RelativeTimeComponent": "stable",
47
- "Ariadne::RichTextAreaComponent": "stable",
48
46
  "Ariadne::ShowMoreButtonComponent": "stable",
49
47
  "Ariadne::SlideoverComponent": "stable",
50
48
  "Ariadne::SpinnerComponent": "stable",
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: ariadne_view_components
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.57
4
+ version: 0.0.59
5
5
  platform: x86_64-linux
6
6
  authors:
7
7
  - Garen J. Torikian
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2023-07-14 00:00:00.000000000 Z
11
+ date: 2023-07-19 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: tailwind_merge
@@ -122,7 +122,6 @@ files:
122
122
  - app/assets/javascripts/components/ariadne/events_controller/events_controller.d.ts
123
123
  - app/assets/javascripts/components/ariadne/options_controller/options_controller.d.ts
124
124
  - app/assets/javascripts/components/ariadne/outlet_manager_controller/outlet_manager_controller.d.ts
125
- - app/assets/javascripts/components/ariadne/rich_text_area_component/rich-text-area-component.d.ts
126
125
  - app/assets/javascripts/components/ariadne/slideover_component/slideover-component.d.ts
127
126
  - app/assets/javascripts/components/ariadne/string_match_controller/string_match_controller.d.ts
128
127
  - app/assets/javascripts/components/ariadne/synced_boolean_attributes_controller/synced_boolean_attributes_controller.d.ts
@@ -173,8 +172,6 @@ files:
173
172
  - app/components/ariadne/close_button_component.rb
174
173
  - app/components/ariadne/combobox_component.html.erb
175
174
  - app/components/ariadne/combobox_component.rb
176
- - app/components/ariadne/comment_component.rb
177
- - app/components/ariadne/comment_component/comment_component.html.erb
178
175
  - app/components/ariadne/component.rb
179
176
  - app/components/ariadne/container_component.rb
180
177
  - app/components/ariadne/container_component/container_component.html.erb
@@ -233,11 +230,6 @@ files:
233
230
  - app/components/ariadne/progress_bar_component.rb
234
231
  - app/components/ariadne/relative_time_component.html.erb
235
232
  - app/components/ariadne/relative_time_component.rb
236
- - app/components/ariadne/rich_text_area_component.rb
237
- - app/components/ariadne/rich_text_area_component/rich-text-area-component.d.ts
238
- - app/components/ariadne/rich_text_area_component/rich-text-area-component.js
239
- - app/components/ariadne/rich_text_area_component/rich-text-area-component.ts
240
- - app/components/ariadne/rich_text_area_component/rich_text_area_component.html.erb
241
233
  - app/components/ariadne/show_more_button_component.html.erb
242
234
  - app/components/ariadne/show_more_button_component.rb
243
235
  - app/components/ariadne/slideover_component.rb
@@ -1,6 +0,0 @@
1
- import { Controller } from '@hotwired/stimulus';
2
- export default class RichTextArea extends Controller {
3
- static targets: string[];
4
- readonly editorTargets: [HTMLDivElement];
5
- connect(): void;
6
- }
@@ -1,37 +0,0 @@
1
- <%= render(Ariadne::BaseComponent.new(tag: @tag, classes: @classes, attributes: @attributes)) do %>
2
- <%= render(Ariadne::TabContainerComponent.new(sr_label: @sr_label)) do |tab_container| %>
3
- <%= tab_container.with_tab(id: public_tab.id, selected: public_tab.selected, classes: public_tab.classes, attributes: public_tab.attributes) do |tab| %>
4
- <% tab.with_text { @public_tab_text } %>
5
- <% tab.with_panel(attributes: {:"data-public" => true}) do %>
6
- <%= ariadne_form_with(url: @url, method: @method, classes: @classes, attributes: @attributes) do |comment_box| %>
7
- <% @hidden_fields.each do |name, value| %>
8
- <%= hidden_field_tag name, value %>
9
- <% end %>
10
- <div class="ariadne-overflow-hidden ariadne-border ariadne-border-slate-300 ariadne-shadow-sm">
11
- <%= hidden_field_tag 'message_is_public', true %>
12
- <%= render(Ariadne::RichTextAreaComponent.new(name: :message_public_bodytext, sr_label: "Select reply type", attributes: { required: true})) %>
13
- <% comment_box.submit { @submit } %>
14
- </div>
15
- <div class="ariadne-py-2 ariadne-flex ariadne-justify-end">
16
- <%= public_submit %>
17
- </div>
18
- <% end %>
19
- <% end %>
20
- <% end %>
21
- <%= tab_container.with_tab(id: internal_tab.id, selected: internal_tab.selected, classes: internal_tab.classes, attributes: internal_tab.attributes) do |tab| %>
22
- <% tab.with_text { @internal_tab_text } %>
23
- <% tab.with_panel do %>
24
- <%= ariadne_form_with(url: @url, method: @method, classes: @classes, attributes: @attributes) do |comment_box| %>
25
- <div class="ariadne-overflow-hidden ariadne-border ariadne-border-gray-300 ariadne-shadow-sm">
26
- <%= hidden_field_tag 'message_is_public', false %>
27
- <%= render(Ariadne::RichTextAreaComponent.new(name: :message_internal_bodytext, sr_label: "Select reply type", attributes: { required: true})) %>
28
- <% comment_box.submit { @submit } %>
29
- </div>
30
- <div class="ariadne-py-2 ariadne-flex ariadne-justify-end">
31
- <%= internal_submit %>
32
- </div>
33
- <% end %>
34
- <% end %>
35
- <% end %>
36
- <% end %>
37
- <% end %>
@@ -1,71 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Ariadne
4
- # Defines a submittable form for adding comments to a conversation.
5
- #
6
- #
7
- # @accessibility This component requires you to pass in a `sr_label`
8
- # attribute, which will be used to label the tabs for screen readers.
9
- class CommentComponent < Ariadne::Component
10
- DEFAULT_TAG = :div
11
- TAG_OPTIONS = [DEFAULT_TAG].freeze
12
-
13
- DEFAULT_CLASSES = "ariadne-border-gray-300 ariadne-border ariadne-shadow ariadne-py-5 ariadne-px-5 ariadne-rounded-md "
14
-
15
- renders_one :public_tab, lambda { |selected: false, text:, classes: "", attributes: {}|
16
- attributes[:"data-public"] = true
17
- @tab_idx += 1
18
- id = attributes.fetch(:id, "public-tab-#{@tab_idx}")
19
- @public_tab_text = text
20
-
21
- Ariadne::TabComponent.new(selected: selected, classes: classes, id: id, with_panel: true, attributes: attributes)
22
- }
23
-
24
- renders_one :public_submit, lambda { |classes: "", attributes: {}|
25
- Ariadne::ButtonComponent.new(type: Ariadne::BaseButton::TYPE_SUBMIT, scheme: Ariadne::ButtonComponent::DEFAULT_SCHEME, classes: classes, attributes: attributes)
26
- }
27
-
28
- renders_one :internal_tab, lambda { |selected: false, text:, classes: "", attributes: {}|
29
- attributes[:"data-public"] = false
30
- @tab_idx += 1
31
- id = attributes.fetch(:id, "internal-tab-#{@tab_idx}")
32
- @internal_tab_text = text
33
-
34
- Ariadne::TabComponent.new(selected: selected, classes: classes, id: id, with_panel: true, attributes: attributes)
35
- }
36
-
37
- renders_one :internal_submit, lambda { |classes: "", attributes: {}|
38
- Ariadne::ButtonComponent.new(type: Ariadne::BaseButton::TYPE_SUBMIT, scheme: Ariadne::ButtonComponent::DEFAULT_SCHEME, classes: classes, attributes: attributes)
39
- }
40
-
41
- # @example Default
42
- #
43
- # <%= render(Ariadne::CommentComponent.new(url: "/messages", method: :post, sr_label: "Select delivery time")) do |comment| %>
44
- # <% comment.with_public_tab(selected: true, text: "Reply to sender") %>
45
- # <% comment.with_public_submit { "Send" } %>
46
- # <% comment.with_internal_tab(text: "Internal comment") %>
47
- # <% comment.with_internal_submit { "Send" } %>
48
- # <% end %>
49
- #
50
- # @param url [String] The URL to take action against.
51
- # @param method [String] The method to use when submitting the form.
52
- # @param sr_label [String] A label to introduce these tabs for screen readers.
53
- # @param hidden_fields [[String]] An array of arrays of additional (hidden) fields to add to the form.
54
- # @param classes [String] <%= link_to_classes_docs %>
55
- # @param attributes [Hash] <%= link_to_attributes_docs %>
56
- def initialize(url:, method: :post, sr_label:, hidden_fields: [], classes: "", attributes: {})
57
- @tag = DEFAULT_TAG
58
- @classes = merge_class_names(
59
- DEFAULT_CLASSES,
60
- classes,
61
- )
62
- @url = url
63
- @method = method
64
- @sr_label = sr_label
65
-
66
- @tab_idx = -1
67
- @hidden_fields = hidden_fields
68
- @attributes = attributes
69
- end
70
- end
71
- end
@@ -1,6 +0,0 @@
1
- import { Controller } from '@hotwired/stimulus';
2
- export default class RichTextArea extends Controller {
3
- static targets: string[];
4
- readonly editorTargets: [HTMLDivElement];
5
- connect(): void;
6
- }
@@ -1,38 +0,0 @@
1
- import { Controller } from '@hotwired/stimulus';
2
- import { Editor } from '@tiptap/core';
3
- import { Document } from '@tiptap/extension-document';
4
- import { Paragraph } from '@tiptap/extension-paragraph';
5
- import { Text } from '@tiptap/extension-text';
6
- import DropCursor from '@tiptap/extension-dropcursor';
7
- import GapCursor from '@tiptap/extension-gapcursor';
8
- import { History } from '@tiptap/extension-history';
9
- class RichTextArea extends Controller {
10
- connect() {
11
- for (const editorElement of this.editorTargets) {
12
- const pmEditor = new Editor({
13
- extensions: [DropCursor, GapCursor, History, Document, Paragraph, Text],
14
- content: '',
15
- injectCSS: false,
16
- element: editorElement,
17
- editorProps: {
18
- attributes: {
19
- class: 'ariadne-h-28 ariadne-max-h-48 ariadne-p-2 ariadne-rounded-lg ariadne-overflow-y-auto focus:ariadne-outline-none',
20
- },
21
- },
22
- parseOptions: {
23
- preserveWhitespace: true,
24
- },
25
- });
26
- const tiptapValueContainer = editorElement.previousElementSibling;
27
- if (tiptapValueContainer) {
28
- const parentForm = editorElement.closest('form');
29
- parentForm === null || parentForm === void 0 ? void 0 : parentForm.addEventListener('submit', () => {
30
- tiptapValueContainer.setAttribute('value', pmEditor.getText() || '');
31
- pmEditor.commands.clearContent(); // TODO: test this
32
- });
33
- }
34
- }
35
- }
36
- }
37
- RichTextArea.targets = ['editor'];
38
- export default RichTextArea;
@@ -1,47 +0,0 @@
1
- import {Controller} from '@hotwired/stimulus'
2
-
3
- import {Editor} from '@tiptap/core'
4
-
5
- import {Document} from '@tiptap/extension-document'
6
- import {Paragraph} from '@tiptap/extension-paragraph'
7
- import {Text} from '@tiptap/extension-text'
8
-
9
- import DropCursor from '@tiptap/extension-dropcursor'
10
- import GapCursor from '@tiptap/extension-gapcursor'
11
- import {History} from '@tiptap/extension-history'
12
-
13
- export default class RichTextArea extends Controller {
14
- static targets = ['editor']
15
-
16
- declare readonly editorTargets: [HTMLDivElement]
17
-
18
- connect() {
19
- for (const editorElement of this.editorTargets) {
20
- const pmEditor = new Editor({
21
- extensions: [DropCursor, GapCursor, History, Document, Paragraph, Text],
22
- content: '',
23
- injectCSS: false,
24
- element: editorElement,
25
- editorProps: {
26
- attributes: {
27
- class:
28
- 'ariadne-h-28 ariadne-max-h-48 ariadne-p-2 ariadne-rounded-lg ariadne-overflow-y-auto focus:ariadne-outline-none',
29
- },
30
- },
31
- parseOptions: {
32
- preserveWhitespace: true,
33
- },
34
- })
35
-
36
- const tiptapValueContainer = editorElement.previousElementSibling
37
- if (tiptapValueContainer) {
38
- const parentForm = editorElement.closest('form')
39
-
40
- parentForm?.addEventListener('submit', () => {
41
- tiptapValueContainer.setAttribute('value', pmEditor.getText() || '')
42
- pmEditor.commands.clearContent() // TODO: test this
43
- })
44
- }
45
- }
46
- }
47
- }
@@ -1,6 +0,0 @@
1
- <%= render(Ariadne::BaseComponent.new(tag: @tag, classes: @classes, attributes: @attributes)) do %>
2
- <% if @has_form %>
3
- <input type="hidden" data-tiptap-value-container=true name="<%= @name %>" id="<%= @name %>">
4
- <% end %>
5
- <div class="tiptap-editor" name="rich-text-area" data-rich-text-area-component-target="editor"></div>
6
- <% end %>
@@ -1,35 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Ariadne
4
- # Add a general description of component here
5
- # Add additional usage considerations or best practices that may aid the user to use the component correctly.
6
- # @accessibility Add any accessibility considerations
7
- class RichTextAreaComponent < Ariadne::Component
8
- DEFAULT_TAG = :div
9
- DEFAULT_CLASSES = ""
10
-
11
- # @example Default
12
- #
13
- # <%= render(Ariadne::RichTextAreaComponent.new(name: "bodytext", sr_label: "Enter message contents")) { "Example" } %>
14
- #
15
- # @param name [Symbol] Identifies the form/param name for this rich text area.
16
- # @param sr_label [String] A label to introduce these tabs for screen readers.
17
- # @param has_form [Boolean] Indicates whether this component is wrapped in a form.
18
- # @param classes [String] <%= link_to_classes_docs %>
19
- # @param attributes [Hash] <%= link_to_attributes_docs %>
20
- def initialize(name:, sr_label:, has_form: true, classes: "", attributes: {})
21
- @tag = DEFAULT_TAG
22
- @name = name
23
- @sr_label = sr_label
24
- @has_form = has_form
25
-
26
- @classes = merge_class_names(
27
- DEFAULT_CLASSES,
28
- classes,
29
- )
30
- @attributes = attributes
31
- @attributes[:"data-controller"] = "rich-text-area-component"
32
- @attributes[:"data-has-form"] = true if @has_form
33
- end
34
- end
35
- end