Merge branch 'master' into node-6.9

This commit is contained in:
Shane Kilkelly 2017-02-20 11:07:14 +00:00
commit 9734f29086
8 changed files with 43 additions and 9 deletions

View file

@ -302,7 +302,7 @@ div.full-size.pdf(ng-controller="PdfController")
.alert.alert-danger(ng-show="pdf.validation.conflictedPaths")
div
strong #{translate("conflicting_paths_found")}
div #{translate("following_paths_conflict")}
div !{translate("following_paths_conflict")}
div
li(ng-repeat="entry in pdf.validation.conflictedPaths") {{ '/'+entry['path'] }}

View file

@ -79,6 +79,7 @@
on-submit="submitNewComment(content);"
on-cancel="cancelNewComment();"
on-indicator-click="toggleReviewPanel();"
layout-to-left="reviewPanel.layoutToLeft"
)
.rp-entry-list(
@ -310,7 +311,7 @@ script(type='text/ng-template', id='addCommentEntryTemplate')
ng-if="!commentState.adding"
ng-click="startNewComment(); onIndicatorClick();"
tooltip="Add a comment"
tooltip-placement="right"
tooltip-placement="{{ layoutToLeft ? 'left' : 'right' }}"
tooltip-append-to-body="true"
)
i.fa.fa-commenting

View file

@ -20,6 +20,6 @@ block content
.col-md-12  
.row
.span-md-12
a.btn.btn-success(href="/project") #{translate("Done")}
a.btn.btn-success(href="/project") #{translate("done")}

View file

@ -17,7 +17,7 @@ block content
div
p.small
| #{translate("clear_sessions_description")}
| !{translate("clear_sessions_description")}
div
div(ng-if="state.otherSessions.length == 0")

View file

@ -107,7 +107,7 @@ block content
span.small.text-primary(ng-show="changePasswordForm.newPassword2.$error.areEqual && changePasswordForm.newPassword2.$dirty")
| #{translate("doesnt_match")}
span.small.text-primary(ng-show="!changePasswordForm.newPassword2.$error.areEqual && changePasswordForm.newPassword2.$invalid && changePasswordForm.newPassword2.$dirty")
| #{translate("Invalid Password")}
| #{translate("invalid_password")}
.actions
button.btn.btn-primary(
type='submit',

View file

@ -105,6 +105,7 @@ load = (EventEmitter) ->
throw new Error("unknown op type")
addComment: (op, metadata) ->
# TODO: Don't allow overlapping comments?
@comments.push comment = {
id: op.t or @newId()
op: # Copy because we'll modify in place
@ -167,12 +168,14 @@ load = (EventEmitter) ->
op_length = op.i.length
op_end = op.p + op_length
already_merged = false
previous_change = null
moved_changes = []
remove_changes = []
new_changes = []
for change in @changes
for change, i in @changes
change_start = change.op.p
if change.op.d?
@ -200,6 +203,16 @@ load = (EventEmitter) ->
# Only merge inserts if they are from the same user
is_same_user = metadata.user_id == change.metadata.user_id
# If this is an insert op at the end of an existing insert with a delete following, and it cancels out the following
# delete then we shouldn't append it to this insert, but instead only cancel the following delete.
# E.g.
# foo|<--- about to insert 'b' here
# inserted 'foo' --^ ^-- deleted 'bar'
# should become just 'foo' not 'foob' (with the delete marker becoming just 'ar'), .
next_change = @changes[i+1]
is_op_adjacent_to_next_delete = next_change? and next_change.op.d? and op.p == change_end and next_change.op.p == op.p
will_op_cancel_next_delete = is_op_adjacent_to_next_delete and next_change.op.d.slice(0, op.i.length) == op.i
# If there is a delete at the start of the insert, and we're inserting
# at the start, we SHOULDN'T merge since the delete acts as a partition.
# The previous op will be the delete, but it's already been shifted by this insert
@ -222,7 +235,8 @@ load = (EventEmitter) ->
if @track_changes and
is_change_overlapping and
!is_insert_blocked_by_delete and
!already_merged and
!already_merged and
!will_op_cancel_next_delete and
is_same_user
offset = op_start - change_start
change.op.i = change.op.i.slice(0, offset) + op.i + change.op.i.slice(offset)
@ -398,8 +412,8 @@ load = (EventEmitter) ->
_addOp: (op, metadata) ->
change = {
id: @newId()
op: op
metadata: metadata
op: @_clone(op) # Don't take a reference to the existing op since we'll modify this in place with future changes
metadata: @_clone(metadata)
}
@changes.push change
@ -471,6 +485,11 @@ load = (EventEmitter) ->
else # Only update to the current change if we haven't removed it.
previous_change = change
return { moved_changes, remove_changes }
_clone: (object) ->
clone = {}
(clone[k] = v for k,v of object)
return clone
if define?
define ["utils/EventEmitter"], load

View file

@ -9,6 +9,7 @@ define [
onSubmit: "&"
onCancel: "&"
onIndicatorClick: "&"
layoutToLeft: "="
link: (scope, element, attrs) ->
scope.state =
isAdding: false

View file

@ -181,6 +181,19 @@
}
}
// Hack to solve an issue where scrollbars aren't visible in Safari.
// Safari seems to clip part of the scrollbar element. By giving the
// element a background, we're telling Safari that it *really* needs to
// paint the whole area. See https://github.com/ajaxorg/ace/issues/2872
.ace_scrollbar-inner {
background-color: #FFF;
opacity: 0.01;
.ace_dark & {
background-color: #000;
}
}
.ui-layout-resizer {
width: 6px;
background-color: #f4f4f4;