2020-06-18 13:56:37 +02:00
<!-- Modal subscription -->
< div class = "modal fade" id = "subscriptionRequiredModal" tabindex = "-1" role = "dialog" >
< div class = "modal-dialog" >
< div class = "modal-content" >
< div class = "modal-header" >
2020-11-11 17:39:19 +01:00
< h4 class = "modal-title" > {{ 'domains.subscriptionRequired.title' | tr }}< / h4 >
2020-06-18 13:56:37 +02:00
< / div >
< div class = "modal-body" >
2020-11-11 17:39:19 +01:00
< p ng-bind-html = "'domains.subscriptionRequired.description' | tr" > < / p >
2020-06-18 13:56:37 +02:00
< / div >
< div class = "modal-footer" >
2020-11-11 17:39:19 +01:00
< button type = "button" class = "btn btn-default" data-dismiss = "modal" > {{ 'main.dialog.cancel' | tr }}< / button >
< button type = "button" class = "btn btn-success" ng-click = "openSubscriptionSetup()" > {{ 'domains.subscriptionRequired.setupAction' | tr }}< / button >
2020-06-18 13:56:37 +02:00
< / div >
< / div >
< / div >
< / div >
2019-02-06 15:53:01 -08:00
<!-- modal domain add/configure -->
2018-01-22 13:01:38 -08:00
< div class = "modal fade" id = "domainConfigureModal" tabindex = "-1" role = "dialog" >
< div class = "modal-dialog" >
< div class = "modal-content" >
< div class = "modal-header" >
2020-11-11 17:39:19 +01:00
< h4 class = "modal-title" ng-show = "domainConfigure.adding" > {{ 'domains.domainDialog.addTitle' | tr }}< / h4 >
2020-11-12 23:13:52 +01:00
< h4 class = "modal-title" ng-hide = "domainConfigure.adding" > {{ 'domains.domainDialog.editTitle' | tr:{ domain: domainConfigure.domain.domain } }}< / h4 >
2018-01-22 13:01:38 -08:00
< / div >
< div class = "modal-body" >
2020-11-11 17:39:19 +01:00
< p ng-show = "domainConfigure.adding" ng-bind-html = "'domains.domainDialog.addDescription' | tr" > < / p >
2020-09-01 21:33:20 -07:00
2018-01-22 13:01:38 -08:00
< form name = "domainConfigureForm" role = "form" novalidate ng-submit = "domainConfigure.submit()" autocomplete = "off" >
2020-11-11 17:39:19 +01:00
< p class = "has-error text-center" ng-show = "domainConfigure.error" > {{ domainConfigure.error }}< / p >
< div class = "form-group" ng-show = "domainConfigure.adding" >
< label class = "control-label" > {{ 'domains.domainDialog.domain' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.newDomain" name = "newDomain" ng-disabled = "domainConfigure.busy" placeholder = "example.com" ng-required = "domainConfigure.adding" autofocus >
< / div >
< div class = "form-group" >
< label class = "control-label" > {{ 'domains.domainDialog.provider' | tr }} < sup > < a ng-href = "https://docs.cloudron.io/domains/#dns-providers" class = "help" target = "_blank" > < i class = "fa fa-question-circle" > < / i > < / a > < / sup > < / label >
< select class = "form-control" ng-model = "domainConfigure.provider" ng-options = "a.value as a.name for a in dnsProvider" ng-change = "domainConfigure.setDefaultTlsProvider()" > < / select >
< / div >
<!-- Route53 -->
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'route53'" >
< label class = "control-label" > {{ 'domains.domainDialog.route53AccessKeyId' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.accessKeyId" name = "accessKeyId" ng-disabled = "domainConfigure.busy" ng-minlength = "16" ng-maxlength = "32" ng-required = "domainConfigure.provider === 'route53'" >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'route53'" >
< label class = "control-label" > {{ 'domains.domainDialog.route53SecretAccessKey' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.secretAccessKey" name = "secretAccessKey" ng-disabled = "domainConfigure.busy" ng-required = "domainConfigure.provider === 'route53'" >
< / div >
<!-- Google Cloud DNS -->
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'gcdns'" >
< label class = "control-label" > {{ 'domains.domainDialog.gcdnsServiceAccountKey' | tr }}< / label >
< div class = "input-group" >
< input type = "file" id = "gcdnsKeyFileInput" style = "display:none" / >
< input type = "text" class = "form-control" placeholder = "Service Account Key" ng-model = "domainConfigure.gcdnsKey.keyFileName" id = "gcdnsKeyInput" name = "cert" onclick = "getElementById('gcdnsKeyFileInput').click();" style = "cursor: pointer;" ng-disabled = "domainConfigure.busy" ng-required = "domainConfigure.provider === 'gcdns'" >
< span class = "input-group-addon" >
< i class = "fa fa-upload" onclick = "getElementById('gcdnsKeyFileInput').click();" > < / i >
< / span >
2018-01-22 13:01:38 -08:00
< / div >
2020-11-11 17:39:19 +01:00
< / div >
<!-- DigitalOcean -->
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'digitalocean'" >
< label class = "control-label" > {{ 'domains.domainDialog.digitalOceanToken' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.digitalOceanToken" name = "digitalOceanToken" ng-disabled = "domainConfigure.busy" ng-required = "domainConfigure.provider === 'digitalocean'" >
< / div >
<!-- Gandi -->
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'gandi'" >
< label class = "control-label" > {{ 'domains.domainDialog.gandiApiKey' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.gandiApiKey" name = "gandiApiKey" ng-disabled = "domainConfigure.busy" ng-required = "domainConfigure.provider === 'gandi'" >
< / div >
<!-- GoDaddy -->
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'godaddy'" >
< label class = "control-label" > {{ 'domains.domainDialog.goDaddyApiKey' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.godaddyApiKey" name = "apiKey" ng-disabled = "domainConfigure.busy" ng-minlength = "1" ng-required = "domainConfigure.provider === 'godaddy'" >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'godaddy'" >
< label class = "control-label" > {{ 'domains.domainDialog.goDaddyApiSecret' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.godaddyApiSecret" name = "apiSecret" ng-disabled = "domainConfigure.busy" ng-required = "domainConfigure.provider === 'godaddy'" >
< / div >
2021-01-18 19:43:20 +01:00
<!-- Netcup -->
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'netcup'" >
< label class = "control-label" > {{ 'domains.domainDialog.netcupCustomerNumber' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.netcupCustomerNumber" name = "netcupCustomerNumber" ng-disabled = "domainConfigure.busy" ng-required = "domainConfigure.provider === 'netcup'" >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'netcup'" >
< label class = "control-label" > {{ 'domains.domainDialog.netcupApiKey' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.netcupApiKey" name = "netcupApiKey" ng-disabled = "domainConfigure.busy" ng-minlength = "1" ng-required = "domainConfigure.provider === 'netcup'" >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'netcup'" >
< label class = "control-label" > {{ 'domains.domainDialog.netcupApiPassword' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.netcupApiPassword" name = "netcupApiPassword" ng-disabled = "domainConfigure.busy" ng-required = "domainConfigure.provider === 'netcup'" >
< / div >
2020-11-11 17:39:19 +01:00
<!-- Cloudflare -->
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'cloudflare'" >
< label class = "control-label" > {{ 'domains.domainDialog.cloudflareTokenType' | tr }}< / label >
< select class = "form-control" ng-model = "domainConfigure.cloudflareTokenType" >
< option value = "GlobalApiKey" > {{ 'domains.domainDialog.cloudflareTokenTypeGlobalApiKey' | tr }}< / option >
< option value = "ApiToken" > {{ 'domains.domainDialog.cloudflareTokenTypeApiToken' | tr }}< / option >
< / select >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'cloudflare'" >
< label class = "control-label" ng-show = "domainConfigure.cloudflareTokenType === 'GlobalApiKey'" > {{ 'domains.domainDialog.cloudflareTokenTypeGlobalApiKey' | tr }}< / label >
< label class = "control-label" ng-show = "domainConfigure.cloudflareTokenType === 'ApiToken'" > {{ 'domains.domainDialog.cloudflareTokenTypeApiToken' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.cloudflareToken" name = "cloudflareToken" ng-required = "domainConfigure.provider === 'cloudflare'" ng-disabled = "domainConfigure.busy" >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'cloudflare' && domainConfigure.cloudflareTokenType === 'GlobalApiKey'" >
< label class = "control-label" > {{ 'domains.domainDialog.cloudflareEmail' | tr }}< / label >
< input type = "email" class = "form-control" ng-model = "domainConfigure.cloudflareEmail" name = "cloudflareEmail" ng-required = "domainConfigure.provider === 'cloudflare' && domainConfigure.cloudflareTokenType === 'GlobalApiKey'" ng-disabled = "domainConfigure.busy" >
< / div >
<!-- Linode -->
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'linode'" >
< label class = "control-label" > {{ 'domains.domainDialog.linodeToken' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.linodeToken" name = "linodeToken" ng-disabled = "domainConfigure.busy" ng-required = "domainConfigure.provider === 'linode'" >
< / div >
<!-- Name.com -->
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'namecom'" >
< label class = "control-label" > {{ 'domains.domainDialog.nameComUsername' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.nameComUsername" name = "nameComUsername" ng-disabled = "domainConfigure.busy" ng-required = "domainConfigure.provider === 'namecom'" >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'namecom'" >
< label class = "control-label" > {{ 'domains.domainDialog.nameComApiToken' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.nameComToken" name = "nameComToken" ng-disabled = "domainConfigure.busy" ng-minlength = "1" ng-required = "domainConfigure.provider === 'namecom'" >
< / div >
<!-- Namecheap -->
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'namecheap'" >
< label class = "control-label" > {{ 'domains.domainDialog.namecheapUsername' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.namecheapUsername" name = "namecheapUsername" ng-disabled = "domainConfigure.busy" ng-required = "domainConfigure.provider === 'namecheap'" >
< / div >
< div class = "form-group" ng-class = "{ 'has-error': false }" ng-show = "domainConfigure.provider === 'namecheap'" >
< label class = "control-label" > {{ 'domains.domainDialog.namecheapApiKey' | tr }}< / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.namecheapApiKey" name = "namecheapApiKey" ng-disabled = "domainConfigure.busy" ng-minlength = "1" ng-required = "domainConfigure.provider === 'namecheap'" >
< / div >
< p class = "small text-info text-bold" ng-show = "domainConfigure.provider === 'namecheap'" ng-bind-html = "'domains.domainDialog.namecheapInfo' | tr" > < / p >
2021-01-07 19:16:34 +01:00
< p class = "small text-info text-bold" ng-show = "domainConfigure.provider === 'wildcard'" ng-bind-html = "'domains.domainDialog.wildcardInfo' | tr:{ domain: domainConfigure.adding ? domainConfigure.newDomain : domainConfigure.domain.domain }" > < / p >
2020-11-12 23:13:52 +01:00
< p class = "small text-info text-bold" ng-show = "domainConfigure.provider === 'manual'" ng-bind-html = "'domains.domainDialog.manualInfo' | tr" > < / p >
< p class = "small text-info text-bold" ng-show = "needsPort80(domainConfigure.provider, domainConfigure.tlsConfig.provider)" ng-bind-html = "'domains.domainDialog.letsEncryptInfo' | tr" > < / p >
2020-11-11 17:39:19 +01:00
< a href = "" ng-click = "domainConfigure.advancedVisible = true" ng-hide = "domainConfigure.advancedVisible" > {{ 'domains.domainDialog.advancedAction' | tr }}< / a >
< div uib-collapse = "!domainConfigure.advancedVisible" >
2021-01-07 19:19:53 -08:00
< div class = "form-group" >
2021-01-26 22:09:36 -08:00
< label class = "control-label" > {{ 'domains.domainDialog.matrixHostname' | tr }} < sup > < a ng-href = "https://docs.cloudron.io/domains/#matrix-server-location" class = "help" target = "_blank" > < i class = "fa fa-question-circle" > < / i > < / a > < / sup > < / label >
2021-01-07 19:19:53 -08:00
< input type = "text" class = "form-control" ng-model = "domainConfigure.matrixHostname" name = "matrixHostname" ng-disabled = "domainConfigure.busy" >
< / div >
< div class = "form-group" >
2021-01-26 22:09:36 -08:00
< label class = "control-label" > {{ 'domains.domainDialog.mastodonHostname' | tr }} < sup > < a ng-href = "https://docs.cloudron.io/domains/#mastodon-server-location" class = "help" target = "_blank" > < i class = "fa fa-question-circle" > < / i > < / a > < / sup > < / label >
2021-01-07 19:19:53 -08:00
< input type = "text" class = "form-control" ng-model = "domainConfigure.mastodonHostname" name = "mastodonHostname" ng-disabled = "domainConfigure.busy" >
< / div >
2018-01-22 13:01:38 -08:00
< div class = "form-group" >
2020-11-11 17:39:19 +01:00
< label class = "control-label" > {{ 'domains.domainDialog.zoneName' | tr }} < sup > < a ng-href = "https://docs.cloudron.io/domains/#zone-name" class = "help" target = "_blank" > < i class = "fa fa-question-circle" > < / i > < / a > < / sup > < / label >
< input type = "text" class = "form-control" ng-model = "domainConfigure.zoneName" name = "zoneName" ng-disabled = "domainConfigure.busy" >
2018-01-22 13:01:38 -08:00
< / div >
2020-11-11 17:39:19 +01:00
< div class = "form-group" >
< label class = "control-label" > {{ 'domains.domainDialog.certProvider' | tr }} < sup > < a ng-href = "https://docs.cloudron.io/certificates/#certificate-providers" class = "help" target = "_blank" > < i class = "fa fa-question-circle" > < / i > < / a > < / sup > < / label >
< select class = "form-control" ng-model = "domainConfigure.tlsConfig.provider" ng-options = "a.value as a.name for a in tlsProvider" > < / select >
2020-03-12 17:13:21 -07:00
< / div >
2020-11-11 17:39:19 +01:00
<!-- Fallback certificate -->
< div ng-show = "domainConfigure.tlsConfig.provider !== 'fallback'" >
< label class = "control-label" > {{ 'domains.domainDialog.fallbackCert' | tr }}< / label >
< p ng-bind-html = "'domains.domainDialog.fallbackCertInfo' | tr" > < / p >
2018-05-09 12:24:46 +02:00
< / div >
2020-11-11 17:39:19 +01:00
< div ng-show = "domainConfigure.tlsConfig.provider === 'fallback'" >
< label class = "control-label" > {{ 'domains.domainDialog.fallbackCertCustomCert' | tr }}< / label >
2020-11-12 23:13:52 +01:00
< p ng-bind-html = "'domains.domainDialog.fallbackCertCustomCertInfo' | tr:{ customCertLink: 'https://docs.cloudron.io/certificates/#custom-certificates' }" > < / p >
2019-01-22 11:26:24 +01:00
< / div >
2020-11-11 17:39:19 +01:00
< div class = "form-group" ng-class = "{ 'has-error': (!fallbackCert.cert.$dirty && fallbackCert.error) }" >
< div class = "input-group" >
< input type = "file" id = "fallbackCertFileInput" style = "display:none" / >
< input type = "text" class = "form-control" placeholder = "{{ 'domains.domainDialog.fallbackCertCertificatePlaceholder' | tr }}" ng-model = "domainConfigure.fallbackCert.certificateFileName" name = "cert" onclick = "getElementById('fallbackCertFileInput').click();" style = "cursor: pointer;" ng-disabled = "domainConfigure.busy" >
< span class = "input-group-addon" > < i class = "fa fa-upload" onclick = "getElementById('fallbackCertFileInput').click();" > < / i > < / span >
2018-05-15 12:37:16 -07:00
< / div >
2020-11-11 17:39:19 +01:00
< / div >
< div class = "form-group" ng-class = "{ 'has-error': (!fallbackCert.key.$dirty && fallbackCert.error) }" >
< div class = "input-group" >
< input type = "file" id = "fallbackKeyFileInput" style = "display:none" / >
< input type = "text" class = "form-control" placeholder = "{{ 'domains.domainDialog.fallbackCertKeyPlaceholder' | tr }}" ng-model = "domainConfigure.fallbackCert.keyFileName" id = "fallbackKeyInput" name = "key" onclick = "getElementById('fallbackKeyFileInput').click();" style = "cursor: pointer;" ng-disabled = "domainConfigure.busy" >
< span class = "input-group-addon" > < i class = "fa fa-upload" onclick = "getElementById('fallbackKeyFileInput').click();" > < / i > < / span >
2018-05-15 12:37:16 -07:00
< / div >
2020-11-11 17:39:19 +01:00
< / div >
2018-08-27 13:50:13 -07:00
2020-11-11 17:39:19 +01:00
< / div > <!-- advanced -->
2018-01-22 13:01:38 -08:00
2020-11-11 17:39:19 +01:00
< input class = "ng-hide" type = "submit" ng-disabled = "domainConfigureForm.$invalid || domainConfigure.busy" / >
2018-01-22 13:01:38 -08:00
< / form >
< / div >
< div class = "modal-footer " >
2020-11-11 17:39:19 +01:00
< button type = "button" class = "btn btn-default" data-dismiss = "modal" > {{ 'main.dialog.cancel' | tr }}< / button >
< button type = "submit" class = "btn btn-outline btn-success pull-right" ng-click = "domainConfigure.submit()" ng-disabled = "domainConfigureForm.$invalid || domainConfigure.busy" > < i class = "fa fa-circle-notch fa-spin" ng-show = "domainConfigure.busy" > < / i > {{ 'main.dialog.save' | tr }}< / button >
2018-01-22 13:01:38 -08:00
< / div >
< / div >
< / div >
< / div >
<!-- Modal domain remove -->
< div class = "modal fade" id = "domainRemoveModal" tabindex = "-1" role = "dialog" >
< div class = "modal-dialog" >
< div class = "modal-content" >
< div class = "modal-header" >
2020-11-12 23:13:52 +01:00
< h4 class = "modal-title" > {{ 'domains.removeDialog.title' | tr:{ domain: domainRemove.domain.domain } }}< / h4 >
2018-01-22 13:01:38 -08:00
< / div >
< div class = "modal-body" >
2021-02-24 09:52:07 -08:00
< p ng-bind-html = "'domains.removeDialog.description' | tr:{ domain: domainRemove.domain.domain }" > < / p >
2020-11-11 17:39:19 +01:00
< br / >
< span class = "has-error" ng-show = "domainRemove.error" > {{ domainRemove.error }}< / span >
2018-01-22 13:01:38 -08:00
< / div >
< div class = "modal-footer" >
2020-11-11 17:39:19 +01:00
< button type = "button" class = "btn btn-default" data-dismiss = "modal" > {{ 'main.dialog.cancel' | tr }}< / button >
< button type = "button" class = "btn btn-danger" ng-click = "domainRemove.submit()" ng-disabled = "domainRemove.busy" > < i class = "fa fa-circle-notch fa-spin" ng-show = "domainRemove.busy" > < / i > {{ 'domains.removeDialog.removeAction' | tr }}< / button >
2018-01-22 13:01:38 -08:00
< / div >
< / div >
< / div >
< / div >
< div class = "content" >
< div class = "text-left" >
2020-11-11 17:39:19 +01:00
< h1 > {{ 'domains.title' | tr }} < button class = "btn btn-primary btn-outline pull-right" ng-click = "domainAdd.show()" > < i class = "fa fa-plus" > < / i > {{ 'domains.addDomain' | tr }}< / button > < / h1 >
2018-01-22 13:01:38 -08:00
< / div >
< div class = "card card-large" >
2018-12-11 12:41:42 +01:00
< div class = "row ng-hide" ng-show = "!ready" >
< div class = "col-lg-12 text-center" >
< h2 > < i class = "fa fa-circle-notch fa-spin" > < / i > < / h2 >
2018-01-22 13:01:38 -08:00
< / div >
2018-12-11 12:41:42 +01:00
< / div >
< div class = "row animateMeOpacity ng-hide" ng-show = "ready" >
< div class = "col-lg-12" >
< table class = "table table-hover" style = "margin-top: 10px;" >
< thead >
< tr >
2020-11-11 17:39:19 +01:00
< th > {{ 'domains.domain' | tr }}< / th >
< th class = "text-left hidden-xs hidden-sm" > {{ 'domains.provider' | tr }}< / th >
< th style = "width: 100px" class = "text-right" > {{ 'main.actions' | tr }}< / th >
2018-12-11 12:41:42 +01:00
< / tr >
< / thead >
< tbody >
< tr ng-repeat = "domain in domains" >
2021-01-12 19:48:48 -08:00
< td class = "elide-table-cell hand" ng-click = "domainConfigure.show(domain)" >
2018-12-11 12:41:42 +01:00
{{ domain.domain }}
< / td >
2021-01-12 19:48:48 -08:00
< td class = "text-left elide-table-cell hidden-xs hidden-sm hand" ng-click = "domainConfigure.show(domain)" >
2018-12-11 12:41:42 +01:00
{{ prettyProviderName(domain) }}
< / td >
< td class = "text-right no-wrap" style = "vertical-align: bottom" >
2021-01-12 19:48:48 -08:00
< button class = "btn btn-xs btn-default" ng-click = "domainConfigure.show(domain)" title = "{{ 'domains.tooltipEdit' | tr }}" > < i class = "fa fa-pencil-alt" > < / i > < / button >
< button class = "btn btn-xs btn-danger" ng-click = "domainRemove.show(domain)" title = "{{ 'domains.tooltipRemove' | tr }}" ng-disabled = "domain.domain === config.adminDomain" > < i class = "far fa-trash-alt" > < / i > < / button >
2018-12-11 12:41:42 +01:00
< / td >
< / tr >
< / tbody >
< / table >
< / div >
< / div >
2018-12-11 09:57:46 -08:00
< / div >
2018-12-13 15:53:53 -08:00
< div class = "text-left" >
2020-11-11 17:39:19 +01:00
< h3 > {{ 'domains.renewCerts.title' | tr }}< / h3 >
2018-12-11 09:57:46 -08:00
< / div >
< div class = "card" >
< div class = "row" >
< div class = "col-md-12" >
2020-11-11 17:39:19 +01:00
< p ng-bind-html = "'domains.renewCerts.description' | tr" > < / p >
2018-01-22 13:01:38 -08:00
< / div >
< / div >
2018-12-11 10:31:12 -08:00
< div class = "row" >
< div class = "col-md-12" style = "margin-bottom: 10px;" >
< div ng-show = "renewCerts.busy" class = "progress progress-striped active animateMe" >
< div class = "progress-bar progress-bar-success" role = "progressbar" style = "width: {{ renewCerts.percent }}%" > < / div >
< / div >
< / div >
< / div >
< div class = "row" >
< div class = "col-md-6" >
< p ng-show = "renewCerts.busy" > {{ renewCerts.message }}< / p >
< p ng-hide = "renewCerts.busy" >
< div class = "has-error" ng-show = "!renewCerts.active" > {{ renewCerts.errorMessage }}< / div >
< / p >
< / div >
< div class = "col-md-6 text-right" >
2020-11-11 17:39:19 +01:00
< button class = "btn btn-outline btn-primary" ng-click = "renewCerts.renew()" ng-disabled = "renewCerts.busy" style = "margin-right: 10px" > {{ 'domains.renewCerts.renewAllAction' | tr }}< / button >
< a class = "btn btn-primary pull-right" ng-href = "/logs.html?taskId={{renewCerts.taskId}}" ng-disabled = "!renewCerts.taskId" target = "_blank" > {{ 'domains.renewCerts.showLogsAction' | tr }}< / a >
2018-12-11 10:31:12 -08:00
< / div >
< / div >
2018-12-18 15:05:11 -08:00
< / div >
2020-02-04 12:55:51 -08:00
< div class = "text-left" >
2020-11-11 17:39:19 +01:00
< h3 > {{ 'domains.changeDashboardDomain.title' | tr }}< / h3 >
2018-12-18 15:05:11 -08:00
< / div >
2020-02-04 12:55:51 -08:00
< div class = "card" >
2018-12-18 15:05:11 -08:00
< div class = "row" >
2020-11-11 17:39:19 +01:00
< div class = "col-md-8" >
< p ng-bind-html = "'domains.changeDashboardDomain.description' | tr" > < / p >
2018-12-18 15:05:11 -08:00
< / div >
< div class = "col-md-4" >
< select class = "form-control pull-right" style = "display: inline-block; width: 200px;" ng-model = "changeDashboard.selectedDomain" ng-options = "a.domain for a in domains" > < / select >
< / div >
< / div >
< div class = "row" >
< div class = "col-md-12" style = "margin-bottom: 10px;" >
< div ng-show = "changeDashboard.busy" class = "progress progress-striped active animateMe" >
< div class = "progress-bar progress-bar-success" role = "progressbar" style = "width: {{ changeDashboard.percent }}%" > < / div >
< / div >
< / div >
< / div >
2018-12-11 10:31:12 -08:00
2018-12-18 15:05:11 -08:00
< div class = "row" >
< div class = "col-md-6" >
< p ng-show = "changeDashboard.busy" > {{ changeDashboard.message }}< / p >
< p ng-hide = "changeDashboard.busy" >
< div class = "has-error" ng-show = "!changeDashboard.active" > {{ changeDashboard.errorMessage }}< / div >
< / p >
< / div >
< div class = "col-md-6 text-right" >
2020-11-11 17:39:19 +01:00
< button class = "btn btn-outline btn-primary" ng-click = "changeDashboard.change()" ng-hide = "changeDashboard.busy" ng-disabled = "changeDashboard.selectedDomain.domain === changeDashboard.adminDomain.domain" > {{ 'domains.changeDashboardDomain.changeAction' | tr }}< / button >
< button class = "btn btn-outline btn-danger" ng-click = "changeDashboard.stop()" ng-show = "changeDashboard.busy" style = "margin-right: 10px" > {{ 'domains.changeDashboardDomain.cancelAction' | tr }}< / button >
2021-02-24 09:36:21 -08:00
< a class = "btn btn-primary pull-right" ng-href = "/logs.html?taskId={{changeDashboard.taskId}}" ng-show = "changeDashboard.busy" target = "_blank" > {{ 'domains.changeDashboardDomain.showLogsAction' | tr }}< / a >
2018-12-18 15:05:11 -08:00
< / div >
< / div >
2018-01-22 13:01:38 -08:00
< / div >
< / div >