diff --git a/.gitignore b/.gitignore index 2c9fda4ca6..64fd8ad3a1 100644 --- a/.gitignore +++ b/.gitignore @@ -34,3 +34,7 @@ resources/lang/locales.js /public/hot result docker-compose.yaml + +public/css/filament-monaco-editor/ + +public/js/filament-monaco-editor/ diff --git a/app/Filament/Resources/EggResource.php b/app/Filament/Resources/EggResource.php index 906f0786df..efeb9714a0 100644 --- a/app/Filament/Resources/EggResource.php +++ b/app/Filament/Resources/EggResource.php @@ -27,24 +27,53 @@ public static function form(Form $form): Form ->schema([ Forms\Components\Tabs::make()->tabs([ Forms\Components\Tabs\Tab::make('Configuration') - ->columns(2) + ->columns(['default' => 1, 'sm' => 1, 'md' => 2, 'lg' => 4]) ->schema([ - Forms\Components\TextInput::make('name')->required()->maxLength(191) + Forms\Components\TextInput::make('name') + ->required() + ->maxLength(191) + ->columnSpan(['default' => 1, 'sm' => 1, 'md' => 2, 'lg' => 2]) ->helperText('A simple, human-readable name to use as an identifier for this Egg.'), - Forms\Components\Textarea::make('description')->rows(5) + Forms\Components\TextInput::make('uuid') + ->disabled() + ->columnSpan(['default' => 1, 'sm' => 1, 'md' => 2, 'lg' => 2]) + ->helperText('This is the globally unique identifier for this Egg which Wings uses as an identifier.'), + Forms\Components\Textarea::make('description') + ->rows(3) + ->columnSpan(['default' => 1, 'sm' => 1, 'md' => 2, 'lg' => 2]) ->helperText('A description of this Egg that will be displayed throughout the Panel as needed.'), - Forms\Components\TextInput::make('uuid')->disabled() - ->helperText('This is the globally unique identifier for this Egg which the Daemon uses as an identifier.'), - Forms\Components\TextInput::make('author')->required()->maxLength(191)->disabled() + Forms\Components\TextInput::make('author') + ->required() + ->maxLength(191) + ->disabled() + ->columnSpan(['default' => 1, 'sm' => 1, 'md' => 2, 'lg' => 2]) ->helperText('The author of this version of the Egg. Uploading a new Egg configuration from a different author will change this.'), - Forms\Components\Toggle::make('force_outgoing_ip')->required() + Forms\Components\Textarea::make('startup') + ->rows(2) + ->columnSpanFull() + ->required() + ->helperText('The default startup command that should be used for new servers using this Egg.'), + Forms\Components\TagsInput::make('file_denylist') + ->placeholder('denied-file.txt') + ->helperText('A list of files that the end user is not allowed to edit.') + ->columnSpan(['default' => 1, 'sm' => 1, 'md' => 2, 'lg' => 2]), + Forms\Components\TagsInput::make('features') + ->placeholder('Add Feature') + ->helperText('') + ->columnSpan(['default' => 1, 'sm' => 1, 'md' => 2, 'lg' => 2]), + Forms\Components\Toggle::make('force_outgoing_ip') ->helperText("Forces all outgoing network traffic to have its Source IP NATed to the IP of the server's primary allocation IP. Required for certain games to work properly when the Node has multiple public IP addresses. Enabling this option will disable internal networking for any servers using this egg, causing them to be unable to internally access other servers on the same node."), - Forms\Components\Textarea::make('startup')->rows(5) - ->helperText('The default startup command that should be used for new servers using this Egg.'), + Forms\Components\Toggle::make('script_is_privileged') + ->helperText('The docker images available to servers using this egg.'), + Forms\Components\TextInput::make('update_url') + ->disabled() + ->helperText('Not implemented.') + ->columnSpan(['default' => 1, 'sm' => 1, 'md' => 2, 'lg' => 2]), Forms\Components\KeyValue::make('docker_images') ->columnSpanFull() + ->required() ->addActionLabel('Add Image') ->keyLabel('Name') ->valueLabel('Image URI') @@ -52,41 +81,41 @@ public static function form(Form $form): Form ]), Forms\Components\Tabs\Tab::make('Process Management') - ->columns(2) + ->columns() ->schema([ Forms\Components\Select::make('config_from') ->label('Copy Settings From') ->placeholder('None') ->relationship('configFrom', 'name', ignoreRecord: true) ->helperText('If you would like to default to settings from another Egg select it from the menu above.'), - Forms\Components\TextInput::make('config_stop') ->maxLength(191) ->label('Stop Command') ->helperText('The command that should be sent to server processes to stop them gracefully. If you need to send a SIGINT you should enter ^C here.'), - Forms\Components\Textarea::make('config_startup')->rows(10)->json() ->label('Start Configuration') ->helperText('List of values the daemon should be looking for when booting a server to determine completion.'), - Forms\Components\Textarea::make('config_files')->rows(10)->json() ->label('Configuration Files') ->helperText('This should be a JSON representation of configuration files to modify and what parts should be changed.'), - Forms\Components\Textarea::make('config_logs')->rows(10)->json() ->label('Log Configuration') ->helperText('This should be a JSON representation of where log files are stored, and whether or not the daemon should be creating custom logs.'), ]), Forms\Components\Tabs\Tab::make('Egg Variables') ->columnSpanFull() - // ->columns(2) + ->columns(2) ->schema([ Forms\Components\Repeater::make('variables') - ->grid(3) + ->grid() ->relationship('variables') ->name('name') - ->columns(1) - ->columnSpan(1) + ->columns(2) + ->reorderable() + ->collapsible() + ->collapsed() + ->orderColumn() + ->columnSpan(2) ->itemLabel(fn (array $state) => $state['name']) ->mutateRelationshipDataBeforeCreateUsing(function (array $data): array { $data['default_value'] ??= ''; @@ -108,14 +137,14 @@ public static function form(Form $form): Form ->debounce(750) ->maxLength(191) ->columnSpanFull() - ->afterStateUpdated(fn (Forms\Set $set, $state) => - $set('env_variable', str($state)->trim()->snake()->upper()->toString()) + ->afterStateUpdated(fn (Forms\Set $set, $state) => $set('env_variable', str($state)->trim()->snake()->upper()->toString()) ) ->required(), Forms\Components\Textarea::make('description')->columnSpanFull(), Forms\Components\TextInput::make('env_variable') ->label('Environment Variable') ->maxLength(191) + ->hint(fn ($state) => "{{{$state}}}") ->required(), Forms\Components\TextInput::make('default_value')->maxLength(191), Forms\Components\Textarea::make('rules')->rows(3)->columnSpanFull(), @@ -147,11 +176,6 @@ public static function form(Form $form): Form ]), ])->columnSpanFull()->persistTabInQueryString(), - - // Forms\Components\TagsInput::make('features'), - // Forms\Components\TagsInput::make('file_denylist')->placeholder('new-file.txt'), - // Forms\Components\TextInput::make('update_url'), - // Forms\Components\Toggle::make('script_is_privileged')->required(), ]); } diff --git a/database/migrations/2024_04_20_214441_add_egg_var_sort.php b/database/migrations/2024_04_20_214441_add_egg_var_sort.php new file mode 100644 index 0000000000..f1a4346cd4 --- /dev/null +++ b/database/migrations/2024_04_20_214441_add_egg_var_sort.php @@ -0,0 +1,28 @@ +unsignedTinyInteger('sort')->nullable()->after('egg_id'); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + Schema::table('egg_variables', function (Blueprint $table) { + $table->dropColumn('sort'); + }); + } +};