2 Vars: mailing:obj, testContact:obj, testGroup:obj, crmMailing:FormController
4 <div class=
"crmMailing-preview">
6 In Firefox (at least), clicking the preview buttons causes the browser to display validation warnings
7 for unrelated fields *and* display preview. To avoid this weird UX, we disable preview buttons when the form is incomplete/invalid.
9 <div class=
"preview-popup">
10 <div ng-show=
"!mailing.body_html && !mailing.body_text">
11 <em>({{ts('No content to preview')}})
</em>
13 <div ng-hide=
"!mailing.body_html">
14 <button ng-disabled=
"crmMailing.$invalid" ng-click=
"doPreview('html')">{{ts('Preview as HTML')}}
</button>
16 <div ng-hide=
"!mailing.body_text">
17 <button ng-disabled=
"crmMailing.$invalid" ng-click=
"doPreview('text')">{{ts('Preview as Plain Text')}}
</button>
20 <div ng-hide="!mailing.body_html && !mailing.body_text">
21 <button ng-disabled="crmMailing.$invalid" ng-click="doPreview('full')">{{ts('Preview')}}</button>
25 <div class=
"preview-contact" ng-form
>
27 {{ts('Send test email to:')}}
31 name=
"preview_test_email"
34 ng-model=
"testContact.email"
35 placeholder=
"example@example.org"
38 <button ng-disabled=
"crmMailing.$invalid || !testContact.email" ng-click=
"doSend({email: testContact.email})">{{ts('Send test')}}
</button>
40 <div class=
"preview-group" ng-form
>
42 {{ts('Send test email to group:')}}
46 name=
"preview_test_group"
48 ui-options=
"{dropdownAutoWidth : true, allowClear: true, placeholder: ts('Select Group')}"
49 ng-model=
"testGroup.gid"
50 ng-options=
"group.id as group.title for group in crmMailingConst.groupNames|orderBy:'title'"
52 <option value=
""></option>
55 <button ng-disabled=
"crmMailing.$invalid || !testGroup.gid" ng-click=
"doSend({gid: testGroup.gid})">{{ts('Send test')}}
</button>
57 <div class=
"clear"></div>