mirror of
https://github.com/nextcloud/passman.git
synced 2025-02-25 16:04:19 +08:00
Merge pull request #527 from nextcloud/fix/526/url_not_opening
Updated link-detection in detailview and fixed link only redirecting …
This commit is contained in:
commit
a765f32aa0
2 changed files with 29 additions and 19 deletions
|
@ -36,7 +36,8 @@
|
|||
value: '=value',
|
||||
secret: '=secret',
|
||||
inputField: '=useInput',
|
||||
inputFieldplaceholder: '=inputPlaceholder'
|
||||
inputFieldplaceholder: '=inputPlaceholder',
|
||||
isURLFIELD: '=url',
|
||||
},
|
||||
restrict: 'A',
|
||||
replace: 'true',
|
||||
|
@ -49,8 +50,9 @@
|
|||
'</div>' +
|
||||
'<div class="tools">' +
|
||||
'<div class="cell" ng-if="toggle" tooltip="tggltxt" ng-click="toggleVisibility()"><i class="fa" ng-class="{\'fa-eye\': !valueVisible, \'fa-eye-slash\': valueVisible }"></i></div>' +
|
||||
'<div class="cell" ng-if="isLink"><a ng-href="{{value}}" target="_blank" rel="nofollow noopener noreferrer"><i tooltip="\'Open in new window\'" class="link fa fa-external-link"></i></a></div>' +
|
||||
'<div class="cell" ngclipboard-success="onSuccess(e);" ngclipboard-error="onError(e);" ngclipboard data-clipboard-text="{{value}}"><i tooltip="copy_msg" class="fa fa-files-o"></i></div>' +
|
||||
'<div class="cell" ng-if="isURLFIELD && isLink"><a ng-href="{{value}}" target="_blank" rel="nofollow noopener noreferrer"><i tooltip="\'Open in new window\'" class="link fa fa-external-link"></i></a></div>' +
|
||||
'<div class="cell" ng-if="isURLFIELD && isPartialLink"><a ng-href="//{{value}}" target="_blank" rel="nofollow noopener noreferrer"><i tooltip="\'Open in new window\'" class="link fa fa-external-link"></i></a></div>' +
|
||||
'<div class="cell" ngclipboard-success="onSuccess(e);" ngclipboard-error="onError(e);" ngclipboard data-clipboard-text="{{value}}"><i tooltip="copy_msg" class="fa fa-files-o"></i></div>' +
|
||||
'</div></span>',
|
||||
link: function (scope) {
|
||||
var expression = /(https?:\/\/(?:www\.|(?!www))[^\s\.]+\.[^\s]{2,}|www\.[^\s]+\.[^\s]{2,})/gi;
|
||||
|
@ -67,10 +69,13 @@
|
|||
}
|
||||
if (regex.test(scope.value)) {
|
||||
scope.isLink = true;
|
||||
if(scope.value.substr(0,4) !== 'http'){
|
||||
scope.value = 'http://'+scope.value;
|
||||
} else {
|
||||
scope.isLink = false;
|
||||
if(regex.test('https://'+scope.value)){
|
||||
scope.isPartialLink = true;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
});
|
||||
if (!scope.toggle) {
|
||||
|
|
|
@ -1,8 +1,9 @@
|
|||
<div class="credential-data">
|
||||
<div class="row" ng-show="credential.label && showLabel">
|
||||
<div class="col-xs-4 col-md-3 col-lg-3">{{ 'label' | translate }}</div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9"><span credential-field
|
||||
value="credential.label"></span></div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9">
|
||||
<span credential-field value="credential.label"></span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="compromised-details" ng-show="credential.compromised">
|
||||
|
@ -12,42 +13,46 @@
|
|||
|
||||
<div class="row" ng-show="credential.username">
|
||||
<div class="col-xs-4 col-md-3 col-lg-3">{{ 'account' | translate }}</div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9"><span credential-field
|
||||
value="credential.username"></span></div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9">
|
||||
<span credential-field value="credential.username"></span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<div class="row" ng-show="credential.password">
|
||||
<div class="col-xs-4 col-md-3 col-lg-3">{{ 'password' | translate }}</div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9">
|
||||
<span credential-field value="credential.password" secret="'true'">
|
||||
|
||||
</span>
|
||||
<span credential-field value="credential.password" secret="'true'"></span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="row" ng-show="credential.otp.secret">
|
||||
<div class="col-xs-4 col-md-3 col-lg-3">{{'otp' | translate}}</div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9"><span otp-generator
|
||||
secret="credential.otp.secret"></span></div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9">
|
||||
<span otp-generator secret="credential.otp.secret"></span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<div class="row" ng-show="credential.email">
|
||||
<div class="col-xs-4 col-md-3 col-lg-3">{{'email' | translate}}</div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9"><span credential-field
|
||||
value="credential.email"></span></div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9">
|
||||
<span credential-field value="credential.email"></span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="row" ng-show="credential.url">
|
||||
<div class="col-xs-4 col-md-3 col-lg-3">{{ 'url' | translate}}</div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9"><span credential-field
|
||||
value="credential.url"></span></div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9">
|
||||
<span credential-field value="credential.url" url="true"></span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="row" ng-show="credential.description">
|
||||
<div class="col-xs-4 col-md-3 col-lg-3">{{'notes' | translate}}</div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9"><span credential-field value="credential.description_html"></span></div>
|
||||
<div class="col-xs-8 col-md-9 col-lg-9">
|
||||
<span credential-field value="credential.description_html"></span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="row" ng-show="credential.files.length > 0">
|
||||
|
|
Loading…
Reference in a new issue