import { acceptance } from 'helpers/qunit-helpers'; import { _clearSnapshots } from 'select-kit/components/composer-actions'; acceptance('Composer Actions', { loggedIn: true, settings: { enable_whispers: true }, beforeEach() { _clearSnapshots(); }, }); QUnit.test('replying to post', async assert => { const composerActions = selectKit('.composer-actions'); await visit('/t/internationalization-localization/280'); await click('article#post_3 button.reply'); await composerActions.expandAwait(); assert.equal(composerActions.rowByIndex(0).value(), 'reply_as_new_topic'); assert.equal(composerActions.rowByIndex(1).value(), 'reply_as_private_message'); assert.equal(composerActions.rowByIndex(2).value(), 'reply_to_topic'); assert.equal(composerActions.rowByIndex(3).value(), 'toggle_whisper'); assert.equal(composerActions.rowByIndex(4).value(), undefined); }); QUnit.test('replying to post - reply_as_private_message', async assert => { const composerActions = selectKit('.composer-actions'); await visit('/t/internationalization-localization/280'); await click('article#post_3 button.reply'); await composerActions.expandAwait(); await composerActions.selectRowByValueAwait('reply_as_private_message'); assert.equal(find('.users-input .item:eq(0)').text(), 'codinghorror'); assert.ok(find('.d-editor-input').val().indexOf('Continuing the discussion') >= 0); }); QUnit.test('replying to post - reply_to_topic', async assert => { const composerActions = selectKit('.composer-actions'); await visit('/t/internationalization-localization/280'); await click('article#post_3 button.reply'); await fillIn('.d-editor-input', 'test replying to topic when initially replied to post'); await composerActions.expandAwait(); await composerActions.selectRowByValueAwait('reply_to_topic'); assert.equal(find('.action-title .topic-link').text().trim(), 'Internationalization / localization'); assert.equal(find('.action-title .topic-link').attr("href"), '/t/internationalization-localization/280'); assert.equal(find('.d-editor-input').val(), 'test replying to topic when initially replied to post'); }); QUnit.test('replying to post - toggle_whisper', async assert => { const composerActions = selectKit('.composer-actions'); await visit('/t/internationalization-localization/280'); await click('article#post_3 button.reply'); await fillIn('.d-editor-input', 'test replying as whisper to topic when initially not a whisper'); await composerActions.expandAwait(); await composerActions.selectRowByValueAwait('toggle_whisper'); assert.ok( find('.composer-fields .whisper').text().indexOf(I18n.t("composer.whisper")) > 0 ); }); QUnit.test('replying to post - reply_as_new_topic', async assert => { const composerActions = selectKit('.composer-actions'); const categoryChooser = selectKit('.title-wrapper .category-chooser'); const categoryChooserReplyArea = selectKit('.reply-area .category-chooser'); const quote = 'test replying as new topic when initially replied to post'; await visit('/t/internationalization-localization/280'); await click('#topic-title .d-icon-pencil'); await categoryChooser.expandAwait(); await categoryChooser.selectRowByValueAwait(4); await click('#topic-title .submit-edit'); await click('article#post_3 button.reply'); await fillIn('.d-editor-input', quote); await composerActions.expandAwait(); await composerActions.selectRowByValueAwait('reply_as_new_topic'); assert.equal(categoryChooserReplyArea.header().name(), 'faq'); assert.equal(find('.action-title').text().trim(), I18n.t("topic.create_long")); assert.ok(find('.d-editor-input').val().includes(quote)); }); QUnit.test('shared draft', async assert => { const composerActions = selectKit('.composer-actions'); await visit("/"); await click('#create-topic'); await composerActions.expandAwait(); await composerActions.selectRowByValueAwait('shared_draft'); assert.equal( find('#reply-control .btn-primary.create .d-button-label').text(), I18n.t('composer.create_shared_draft') ); assert.ok(find('#reply-control.composing-shared-draft').length === 1); }); QUnit.test('hide component if no content', async assert => { const composerActions = selectKit('.composer-actions'); await visit('/u/eviltrout/messages'); await click('.new-private-message'); assert.ok(composerActions.el().hasClass("is-hidden")); }); QUnit.test('interactions', async assert => { const composerActions = selectKit('.composer-actions'); const quote = 'Life is like riding a bicycle.'; await visit('/t/internationalization-localization/280'); await click('article#post_3 button.reply'); await fillIn('.d-editor-input', quote); await composerActions.expandAwait(); await composerActions.selectRowByValueAwait('reply_to_topic'); assert.equal(find('.action-title').text().trim(), "Internationalization / localization"); assert.equal(find('.d-editor-input').val(), quote); await composerActions.expandAwait(); assert.equal(composerActions.rowByIndex(0).value(), 'reply_as_new_topic'); assert.equal(composerActions.rowByIndex(1).value(), 'reply_to_post'); assert.equal(composerActions.rowByIndex(2).value(), 'reply_as_private_message'); assert.equal(composerActions.rowByIndex(3).value(), 'toggle_whisper'); assert.equal(composerActions.rows().length, 4); await composerActions.selectRowByValueAwait('reply_to_post'); await composerActions.expandAwait(); assert.ok(exists(find('.action-title img.avatar'))); assert.equal(find('.action-title .user-link').text().trim(), "codinghorror"); assert.equal(find('.d-editor-input').val(), quote); assert.equal(composerActions.rowByIndex(0).value(), 'reply_as_new_topic'); assert.equal(composerActions.rowByIndex(1).value(), 'reply_as_private_message'); assert.equal(composerActions.rowByIndex(2).value(), 'reply_to_topic'); assert.equal(composerActions.rowByIndex(3).value(), 'toggle_whisper'); assert.equal(composerActions.rows().length, 4); await composerActions.selectRowByValueAwait('reply_as_new_topic'); await composerActions.expandAwait(); assert.equal(find('.action-title').text().trim(), I18n.t("topic.create_long")); assert.ok(find('.d-editor-input').val().includes(quote)); assert.equal(composerActions.rowByIndex(0).value(), 'reply_to_post'); assert.equal(composerActions.rowByIndex(1).value(), 'reply_as_private_message'); assert.equal(composerActions.rowByIndex(2).value(), 'reply_to_topic'); assert.equal(composerActions.rowByIndex(3).value(), 'shared_draft'); assert.equal(composerActions.rows().length, 4); await composerActions.selectRowByValueAwait('reply_as_private_message'); await composerActions.expandAwait(); assert.equal(find('.action-title').text().trim(), I18n.t("topic.private_message")); assert.ok(find('.d-editor-input').val().indexOf("Continuing the discussion") === 0); assert.equal(composerActions.rowByIndex(0).value(), 'reply_as_new_topic'); assert.equal(composerActions.rowByIndex(1).value(), 'reply_to_post'); assert.equal(composerActions.rowByIndex(2).value(), 'reply_to_topic'); assert.equal(composerActions.rows().length, 3); });