FEATURE: Show a textarea in advanced mode (#12806)

When switching to advanced mode, show a textarea instead of individual
inputs. Every line of the textarea is equivalent with an input.
This commit is contained in:
Bianca Nenciu 2021-04-23 16:54:53 +03:00 committed by GitHub
parent e53b474557
commit a97e3e249d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 41 additions and 15 deletions

View File

@ -24,6 +24,7 @@ export default Controller.extend(ModalFunctionality, {
pollType: REGULAR_POLL_TYPE, pollType: REGULAR_POLL_TYPE,
pollTitle: "", pollTitle: "",
pollOptions: null, pollOptions: null,
pollOptionsText: null,
pollMin: 1, pollMin: 1,
pollMax: 2, pollMax: 2,
pollStep: 1, pollStep: 1,
@ -39,6 +40,7 @@ export default Controller.extend(ModalFunctionality, {
pollType: REGULAR_POLL_TYPE, pollType: REGULAR_POLL_TYPE,
pollTitle: null, pollTitle: null,
pollOptions: [EmberObject.create({ value: "" })], pollOptions: [EmberObject.create({ value: "" })],
pollOptionsText: "",
pollMin: 1, pollMin: 1,
pollMax: 2, pollMax: 2,
pollStep: 1, pollStep: 1,
@ -337,6 +339,17 @@ export default Controller.extend(ModalFunctionality, {
})); }));
}, },
@action
onOptionsTextChange(e) {
let idx = 0;
this.set(
"pollOptions",
e.target.value
.split("\n")
.map((value) => EmberObject.create({ idx: idx++, value }))
);
},
@action @action
insertPoll() { insertPoll() {
this.toolbarEvent.addText(this.pollOutput); this.toolbarEvent.addText(this.pollOutput);
@ -346,6 +359,12 @@ export default Controller.extend(ModalFunctionality, {
@action @action
toggleAdvanced() { toggleAdvanced() {
this.toggleProperty("showAdvanced"); this.toggleProperty("showAdvanced");
if (this.showAdvanced) {
this.set(
"pollOptionsText",
this.pollOptions.map((x) => x.value).join("\n")
);
}
}, },
@action @action

View File

@ -26,23 +26,30 @@
<div class="poll-options"> <div class="poll-options">
{{#if showAdvanced}} {{#if showAdvanced}}
<label class="input-group-label">{{i18n "poll.ui_builder.poll_options.label"}}</label> <label class="input-group-label">{{i18n "poll.ui_builder.poll_options.label"}}</label>
{{/if}} {{textarea value=pollOptionsText input=(action "onOptionsTextChange")}}
{{#each pollOptions as |option|}} {{#if showMinNumOfOptionsValidation}}
<div class="input-group poll-option-value"> {{#unless minNumOfOptionsValidation.ok}}
{{input value=option.value enter=(action "addOption" option)}} {{input-tip validation=minNumOfOptionsValidation}}
{{#if canRemoveOption}} {{/unless}}
{{d-button icon="trash-alt" action=(action "removeOption" option)}} {{/if}}
{{else}}
{{#each pollOptions as |option|}}
<div class="input-group poll-option-value">
{{input value=option.value enter=(action "addOption" option)}}
{{#if canRemoveOption}}
{{d-button icon="trash-alt" action=(action "removeOption" option)}}
{{/if}}
</div>
{{/each}}
<div class="poll-option-controls">
{{d-button icon="plus" label="poll.ui_builder.poll_options.add" action=(action "addOption" pollOptions.lastObject)}}
{{#if (and showMinNumOfOptionsValidation (not minNumOfOptionsValidation.ok))}}
{{input-tip validation=minNumOfOptionsValidation}}
{{/if}} {{/if}}
</div> </div>
{{/each}} {{/if}}
<div class="poll-option-controls">
{{d-button icon="plus" label="poll.ui_builder.poll_options.add" action=(action "addOption" pollOptions.lastObject)}}
{{#if showMinNumOfOptionsValidation}}
{{input-tip validation=minNumOfOptionsValidation}}
{{/if}}
</div>
</div> </div>
{{/unless}} {{/unless}}

View File

@ -118,7 +118,7 @@ en:
poll_title: poll_title:
label: Title (optional) label: Title (optional)
poll_options: poll_options:
label: Options label: Options (one per line)
add: Add option add: Add option
automatic_close: automatic_close:
label: Automatically close poll label: Automatically close poll