2022-07-06 06:08:45 +00:00
< page-header title = "'Create volume'" breadcrumbs = "[{label:'Volumes', link:'docker.volumes'}, 'Add volume']" > < / page-header >
2016-08-17 05:25:42 +00:00
< div class = "row" >
2018-05-06 07:15:57 +00:00
< div class = "col-sm-12" >
2016-08-17 05:25:42 +00:00
< rd-widget >
< rd-widget-body >
2018-08-09 08:33:16 +00:00
< form class = "form-horizontal" name = "volumeCreationForm" >
2016-08-17 05:25:42 +00:00
<!-- name - input -->
< div class = "form-group" >
2018-08-09 08:33:16 +00:00
< label for = "volume_name" class = "col-sm-2 col-md-1 control-label text-left" > Name< / label >
< div class = "col-sm-10 col-md-11" >
2020-04-10 21:54:53 +00:00
< input type = "text" class = "form-control" ng-model = "formValues.Name" id = "volume_name" placeholder = "e.g. myVolume" / >
2016-08-17 05:25:42 +00:00
< / div >
< / div >
<!-- !name - input -->
2022-01-17 05:53:32 +00:00
< div class = "col-sm-12 form-section-title" > Driver configuration < / div >
2016-08-17 05:25:42 +00:00
<!-- driver - input -->
< div class = "form-group" >
2018-08-09 08:33:16 +00:00
< label for = "volume_driver" class = "col-sm-2 col-md-1 control-label text-left" > Driver< / label >
< div class = "col-sm-10 col-md-11" >
2017-04-01 10:18:46 +00:00
< select class = "form-control" ng-options = "driver for driver in availableVolumeDrivers" ng-model = "formValues.Driver" ng-if = "availableVolumeDrivers.length > 0" >
< option disabled hidden value = "" > Select a driver< / option >
< / select >
2020-04-10 21:54:53 +00:00
< input type = "text" class = "form-control" ng-model = "formValues.Driver" id = "volume_driver" placeholder = "e.g. driverName" ng-if = "availableVolumeDrivers.length === 0" / >
2016-08-17 05:25:42 +00:00
< / div >
< / div >
<!-- !driver - input -->
<!-- driver - options -->
2020-05-15 01:28:51 +00:00
< div class = "form-group" ng-hide = "formValues.CIFSData.useCIFS || formValues.NFSData.useNFS" >
2022-01-17 05:53:32 +00:00
< div class = "col-sm-12" style = "margin-top: 5px" >
2017-03-27 12:44:39 +00:00
< label class = "control-label text-left" >
Driver options
2022-07-03 23:21:25 +00:00
< portainer-tooltip message = "'Driver options are specific to the selected driver. Please refer to the selected driver documentation.'" > < / portainer-tooltip >
2017-03-27 12:44:39 +00:00
< / label >
2022-01-17 05:53:32 +00:00
< span class = "label label-default interactive" style = "margin-left: 10px" ng-click = "addDriverOption()" >
2022-07-26 23:20:21 +00:00
< pr-icon icon = "'plus'" mode = "'alt'" feather = "true" > < / pr-icon > add driver option
2016-08-17 05:25:42 +00:00
< / span >
< / div >
<!-- driver - options - input - list -->
2022-01-17 05:53:32 +00:00
< div class = "col-sm-12 form-inline" style = "margin-top: 10px" >
< div ng-repeat = "option in formValues.DriverOptions" style = "margin-top: 2px" >
2016-08-17 05:25:42 +00:00
< div class = "input-group col-sm-5 input-group-sm" >
< span class = "input-group-addon" > name< / span >
2020-04-10 21:54:53 +00:00
< input type = "text" class = "form-control" ng-model = "option.name" placeholder = "e.g. mountpoint" / >
2016-08-17 05:25:42 +00:00
< / div >
< div class = "input-group col-sm-5 input-group-sm" >
< span class = "input-group-addon" > value< / span >
2020-04-10 21:54:53 +00:00
< input type = "text" class = "form-control" ng-model = "option.value" placeholder = "e.g. /path/on/host" / >
2016-08-17 05:25:42 +00:00
< / div >
2022-07-26 23:18:06 +00:00
< button class = "btn btn-sm btn-light" type = "button" ng-click = "removeDriverOption($index)" >
2022-08-03 00:56:29 +00:00
< pr-icon icon = "'trash-2'" feather = "true" class-name = "'icon-secondary icon-md'" > < / pr-icon >
2017-03-27 12:44:39 +00:00
< / button >
2016-08-17 05:25:42 +00:00
< / div >
< / div >
<!-- !driver - options - input - list -->
< / div >
<!-- !driver - options -->
2018-08-09 08:33:16 +00:00
<!-- nfs - management -->
2020-05-15 01:28:51 +00:00
< div class = "form-group col-md-12" >
2022-08-01 17:46:09 +00:00
< por-switch-field checked = "formValues.NFSData.useNFS" label = "'Use NFS volume'" on-change = "(onUseNFSChange)" > < / por-switch-field >
2022-01-17 05:53:32 +00:00
< div ng-if = "formValues.NFSData.useNFS" class = "small text-muted" style = "margin-top: 10px" > Ensure < code > nfs-utils< / code > are installed on your hosts. < / div >
2020-05-15 01:28:51 +00:00
< / div >
2018-08-09 08:33:16 +00:00
< volumes-nfs-form data = "formValues.NFSData" ng-show = "formValues.Driver === 'local'" > < / volumes-nfs-form >
<!-- !nfs - management -->
2020-05-15 01:28:51 +00:00
<!-- cifs - management -->
< div class = "form-group col-md-12" >
2022-08-01 17:46:09 +00:00
< por-switch-field checked = "formValues.CIFSData.useCIFS" label = "'Use CIFS volume'" on-change = "(onUseCIFSChange)" > < / por-switch-field >
2022-01-17 05:53:32 +00:00
< div ng-if = "formValues.CIFSData.useCIFS" class = "small text-muted" style = "margin-top: 10px" > Ensure < code > cifs-utils< / code > are installed on your hosts. < / div >
2020-05-15 01:28:51 +00:00
< / div >
< volumes-cifs-form data = "formValues.CIFSData" ng-show = "formValues.Driver === 'local'" > < / volumes-cifs-form >
<!-- !cifs - management -->
2018-07-23 09:31:21 +00:00
< div ng-if = "applicationState.endpoint.mode.agentProxy && applicationState.endpoint.mode.provider === 'DOCKER_SWARM_MODE' && formValues.Driver === 'local'" >
2022-01-17 05:53:32 +00:00
< div class = "col-sm-12 form-section-title" > Deployment < / div >
2018-05-06 07:15:57 +00:00
<!-- node - selection -->
2022-11-02 11:29:26 +00:00
< node-selector model = "formValues.NodeName" endpoint-id = "endpoint.Id" > < / node-selector >
2018-05-06 07:15:57 +00:00
<!-- !node - selection -->
< / div >
2017-05-23 18:56:10 +00:00
<!-- access - control -->
2020-06-09 09:55:36 +00:00
< por-access-control-form form-data = "formValues.AccessControlData" > < / por-access-control-form >
2017-05-23 18:56:10 +00:00
<!-- !access - control -->
2017-03-27 12:44:39 +00:00
<!-- actions -->
2022-01-17 05:53:32 +00:00
< div class = "col-sm-12 form-section-title" > Actions < / div >
2017-03-27 12:44:39 +00:00
< div class = "form-group" >
< div class = "col-sm-12" >
2020-04-10 21:54:53 +00:00
< button
type="button"
class="btn btn-primary btn-sm"
ng-click="create()"
2020-05-15 01:28:51 +00:00
ng-disabled="state.actionInProgress || (formValues.NFSData.useNFS & & !volumeCreationForm.nfsInformationForm.$valid) || (formValues.CIFSData.useCIFS & & !volumeCreationForm.cifsInformationForm.$valid)"
2020-04-10 21:54:53 +00:00
button-spinner="state.actionInProgress"
>
2017-11-12 21:39:12 +00:00
< span ng-hide = "state.actionInProgress" > Create the volume< / span >
< span ng-show = "state.actionInProgress" > Creating volume...< / span >
2017-11-12 19:27:28 +00:00
< / button >
2022-01-17 05:53:32 +00:00
< span class = "text-danger" ng-if = "state.formValidationError" style = "margin-left: 5px" > {{ state.formValidationError }}< / span >
2017-03-27 12:44:39 +00:00
< / div >
< / div >
<!-- !actions -->
2016-08-17 05:25:42 +00:00
< / form >
< / rd-widget-body >
< / rd-widget >
< / div >
< / div >