| <!-- Add & Remove Role Groups Buttons --> |
| <div class="row column"> |
| <button |
| type="button" |
| ng-class="{'disabled' : roleGroupType === '' }" |
| ng-disabled="roleGroupType === ''" |
| class="btn btn-tertiary" |
| ng-click="addGroupFn(); $parent.newGroup={}" |
| > |
| <icon aria-hidden="true" file="icon-plus.svg"></icon> |
| <span>Add role group</span> |
| </button> |
| <button |
| type="button" |
| ng-disabled="roleGroupType === '' || !hasSelectedGroup" |
| class="btn btn-tertiary" |
| ng-click="removeMultipleRoleGroupsFn() " |
| > |
| <icon aria-hidden="true" file="icon-trashcan.svg"></icon> |
| <span>Remove role groups</span> |
| </button> |
| </div> |
| <!-- LDAP Role Groups Table --> |
| <div class="ldap__table"> |
| <!-- LDAP Role Groups Table Header --> |
| <div class="table__row-header row column" ng-class="{'disabled' : !enabled }"> |
| <div class="row column"> |
| <div class="table__cell-select"> |
| <label class="control-check"> |
| <span class="screen-reader-offscreen" id="select-all-groups" |
| >select or deselect all groups</span |
| > |
| <input |
| type="checkbox" |
| aria-labelledby="select-all-groups" |
| ng-disabled="!enabled || roleGroups.length < 1 " |
| ng-click="toggleAll()" |
| ng-checked="roleGroupIsSelectedChanged()" |
| ng-model="all" |
| /> |
| <span class="control__indicator"></span> |
| </label> |
| </div> |
| <div class="table__cell-sort"> |
| <div class="column small-2 sort_button_wrapper"> |
| <button |
| class="sort-ascending" |
| aria-label="sort group names in ascending order" |
| ng-click="sortBy('RemoteGroup', false)" |
| ng-disabled="!enabled || roleGroups.length < 1 " |
| ></button> |
| <button |
| class="sort-descending" |
| aria-label="sort group names in descending order" |
| ng-click="sortBy('RemoteGroup', true)" |
| ng-disabled="!enabled || roleGroups.length < 1 " |
| ></button> |
| </div> |
| </div> |
| <div class="table__cell-ldap-group"> |
| Group name |
| </div> |
| <div class="table__cell-sort"> |
| <div class="column small-2 sort_button_wrapper"> |
| <button |
| class="sort-ascending" |
| aria-label="sort group privileges in ascending order" |
| ng-click="sortBy('LocalRole', false)" |
| ng-disabled="!enabled || roleGroups.length < 1 " |
| ></button> |
| <button |
| class="sort-descending" |
| aria-label="sort group privileges in descending order" |
| ng-click="sortBy('LocalRole', true)" |
| ng-disabled="!enabled || roleGroups.length < 1 " |
| ></button> |
| </div> |
| </div> |
| <div class="table__cell-ldap-role"> |
| Group privilege |
| </div> |
| </div> |
| </div> |
| <!-- LDAP Disabled Role Groups Table Row --> |
| <div class="empty__logs" ng-if="roleGroups.length < 1 || !enabled"> |
| <p |
| ng-if="roleGroups.length < 1 && roleGroupType === 'ad' || roleGroupType === 'ldap'" |
| > |
| No role groups have been created yet. |
| </p> |
| <p ng-if=" roleGroupType === '' " ng-class="{'disabled' : !enabled }"> |
| LDAP authentication must be enabled before creating role groups. |
| </p> |
| </div> |
| <div |
| ng-repeat="group in roleGroups | orderBy:sortPropertyName:reverse track by $index " |
| > |
| <!-- Enabled LDAP Role Groups Table Rows --> |
| <div class="row column table__row-value" ng-if="enabled"> |
| <div class="table__cell-select select-header"> |
| <label class="control-check"> |
| <span class="screen-reader-offscreen" id="select-group" |
| >select or deselect {{ group.RemoteGroup }}</span |
| > |
| <input |
| type="checkbox" |
| aria-labelledby="select-group" |
| ng-model="group.isSelected" |
| ng-change="roleGroupIsSelectedChanged(); optionToggled()" |
| /> |
| <span class="control__indicator"></span> |
| </label> |
| </div> |
| <div class="table__cell-ldap"> |
| {{ group.RemoteGroup }} |
| </div> |
| <div class="table__cell-ldap"> |
| {{ group.LocalRole }} |
| </div> |
| <div class="table__cell-buttons"> |
| <button |
| class="btn btn-tertiary" |
| type="button" |
| aria-label="edit group {{ group.RemoteGroup }}" |
| ng-click="editGroupFn(group.RemoteGroup, group.LocalRole, $index); newGroup.RemoteGroup = group.RemoteGroup; newGroup.LocalRole = group.LocalRole; selectedGroupIndex = $index" |
| > |
| <icon aria-hidden="true" file="icon-edit.svg"></icon> |
| </button> |
| <button |
| class="btn btn-tertiary" |
| type="button" |
| aria-label="delete group {{ group.RemoteGroup }}" |
| ng-class="{'disabled' : roleGroups.length < 1}" |
| ng-click="removeGroupFn($index); newGroup.RemoteGroup = group.RemoteGroup; newGroup.LocalRole = group.LocalRole; selectedGroupIndex = $index" |
| > |
| <icon aria-hidden="true" file="icon-trashcan.svg"></icon> |
| </button> |
| </div> |
| </div> |
| </div> |
| </div> |
| <!-- Add/Edit Role Group Modal --> |
| <section |
| class="modal" |
| aria-labelledby="add-or-edit-group" |
| role="dialog" |
| ng-class="{'active': addGroup || editGroup}" |
| > |
| <h3 id="add-or-edit-group" class="subhead"> |
| {{ addGroup ? "Add new role group" : "Edit group privilege" }} |
| </h3> |
| <div class="modal__content-ldap"> |
| <!-- Add Role Group Modal Content --> |
| <div ng-if="addGroup"> |
| <form name="add__group__form" id="add__group__form" novalidate> |
| <div class="small-9"> |
| <label for="group_name">Role group name</label> |
| <input |
| type="text" |
| name="group_name" |
| id="group_name" |
| ng-model="newGroup.RemoteGroup" |
| required |
| /> |
| <div |
| ng-messages="add__group__form.group_name.$error" |
| class="form-error" |
| ng-class="{'visible' : add__group__form.group_name.$touched}" |
| > |
| <p ng-message="required">Field is required</p> |
| </div> |
| </div> |
| <div class="small-9"> |
| <label for="group__role">Privilege</label> |
| <select |
| id="group__role" |
| class="select__group-role" |
| name="group__role" |
| ng-model="newGroup.LocalRole" |
| required |
| > |
| <option class="courier-bold" ng-value="">Select an option</option> |
| <option class="courier-bold" ng-repeat="privilege in privileges">{{ |
| privilege |
| }}</option> |
| </select> |
| <div |
| ng-messages="add__group__form.group__role.$error" |
| class="form-error" |
| ng-class="{'visible' : add__group__form.group__role.$touched}" |
| > |
| <p ng-message="required">Field is required</p> |
| </div> |
| </div> |
| </form> |
| <div class="form-actions"> |
| <button |
| type="button" |
| class="btn btn-primary" |
| ng-class="{'disabled' : add__group__form.$invalid}" |
| ng-click="addRoleGroup(); $parent.addGroup=false; $parent.newGroup={}" |
| > |
| Save |
| </button> |
| <button |
| type="button" |
| class="btn btn-secondary" |
| ng-click="$parent.addGroup=false; $parent.newGroup={}" |
| > |
| Cancel |
| </button> |
| </div> |
| </div> |
| <!-- Edit Role Group Modal Content --> |
| <div ng-if="editGroup"> |
| <form name="edit__group__form" id="edit__group__form" novalidate> |
| <label>Role group name</label> |
| <div class="small-9 edit-group-name" ng-model="newGroup.RemoteGroup"> |
| {{ newGroup.RemoteGroup }} |
| </div> |
| <div class="small-9"> |
| <label for="group__role__edit">Privilege</label> |
| <select |
| id="group__role__edit" |
| name="group__role__edit" |
| ng-model="newGroup.LocalRole" |
| required |
| > |
| <option class="courier-bold" ng-repeat="privilege in privileges">{{ |
| privilege |
| }}</option> |
| </select> |
| <div |
| ng-messages="edit__group__form.group__role__edit.$error" |
| class="form-error" |
| ng-class="{'visible' : edit__group__form.group__role__edit.$touched}" |
| > |
| <p ng-message="required">Field is required</p> |
| </div> |
| </div> |
| </form> |
| <div class="form-actions"> |
| <button |
| type="button" |
| class="btn btn-primary" |
| ng-click="editRoleGroup();$parent.editGroup=false; $parent.newGroup={}" |
| > |
| Save |
| </button> |
| <button |
| type="button" |
| class="btn btn-secondary" |
| ng-click="$parent.editGroup=false; $parent.newGroup={}" |
| > |
| Cancel |
| </button> |
| </div> |
| </div> |
| </div> |
| </section> |
| <!-- Remove Role Groups Modal --> |
| <section |
| class="modal" |
| role="dialog" |
| aria-labelledby="remove-role-group" |
| ng-class="{'active': removeGroup}" |
| > |
| <h3 id="remove-role-group" class="subhead">Remove role group</h3> |
| <div class="modal__content-ldap"> |
| <p>Are you sure you want to remove "{{ newGroup.RemoteGroup }}"?</p> |
| </div> |
| <div class="form-actions"> |
| <button |
| type="button" |
| class="btn btn-primary" |
| ng-click="removeRoleGroup(); $parent.removeGroup=false; newGroup={}" |
| > |
| Remove |
| </button> |
| <button |
| type="button" |
| class="btn btn-secondary" |
| ng-click="removeGroup=false; $parent.removeGroup=false; newGroup={}" |
| > |
| Cancel |
| </button> |
| </div> |
| </section> |
| <!-- Remove Multiple Role Groups Modal --> |
| <section |
| class="modal" |
| role="dialog" |
| ng-class="{'active': removeMultipleGroups}" |
| > |
| <div class="page-header"> |
| <h3>Remove role group</h3> |
| </div> |
| <div class="modal__content-ldap"> |
| <p> |
| Are you sure you want to remove |
| <span ng-repeat="groups in roleGroups | filter:{isSelected:true}" |
| >{{ $last && !$first ? " and " : $first ? "" : ", " |
| }}{{ "'" + groups.RemoteGroup + "'" }}?</span |
| > |
| </p> |
| </div> |
| <div class="form-actions"> |
| <button |
| type="button" |
| class="btn btn-primary" |
| ng-click="removeMultipleRoleGroups();$parent.removeMultipleGroups=false; $parent.newGroup={}" |
| > |
| Remove |
| </button> |
| <button |
| type="button" |
| class="btn btn-secondary" |
| ng-click="removeMultipleGroups = false" |
| > |
| Cancel |
| </button> |
| </div> |
| </section> |
| <div |
| class="modal-overlay" |
| tabindex="-1" |
| ng-class="{'active': addGroup || editGroup || removeGroup || removeMultipleGroups}" |
| ></div> |