Pārlūkot izejas kodu

fixed HTML: <fieldset> + <legend> (#6202)

* legend tags cleaned

* formgroup -> fieldset tag

* add bookmarklet class

* Update logs.phtml

* Update logs.phtml

* fixed log table text alignment
maTh 2 gadi atpakaļ
vecāks
revīzija
6bd6494ad4

+ 3 - 4
app/install.php

@@ -385,8 +385,8 @@ function printStep0(): void {
 		</div>
 	</div>
 
+	<h2><?= _t('install.language.choose') ?></h2>
 	<form action="index.php?step=0" method="post">
-		<legend><?= _t('install.language.choose') ?></legend>
 		<div class="form-group">
 			<label class="group-name" for="language"><?= _t('install.language') ?></label>
 			<div class="group-controls">
@@ -522,8 +522,8 @@ function printStep2(): void {
 		(empty($_SESSION['bd_error']) ? '' : ' : ' . $_SESSION['bd_error']) ?></p>
 	<?php } ?>
 
+	<h2><?= _t('install.bdd.conf') ?></h2>
 	<form action="index.php?step=2" method="post" autocomplete="off">
-		<legend><?= _t('install.bdd.conf') ?></legend>
 		<div class="form-group">
 			<label class="group-name" for="type"><?= _t('install.bdd.type') ?></label>
 			<div class="group-controls">
@@ -622,9 +622,8 @@ function printStep3(): void {
 	<p class="alert alert-error"><?= _t('install.fix_errors_before') ?></p>
 	<?php } ?>
 
+	<h2><?= _t('install.conf') ?></h2>
 	<form action="index.php?step=3" method="post">
-		<legend><?= _t('install.conf') ?></legend>
-
 		<div class="form-group">
 			<label class="group-name" for="default_user"><?= _t('install.default_user') ?></label>
 			<div class="group-controls">

+ 9 - 11
app/views/configure/integration.phtml

@@ -13,7 +13,7 @@
 	<form method="post" action="<?= _url('configure', 'integration') ?>" class="draggableList">
 		<input type="hidden" name="_csrf" value="<?= FreshRSS_Auth::csrfToken() ?>" />
 		<template id="simple-share">
-			<formgroup class="group-share dragbox">
+			<fieldset class="group-share dragbox">
 				<legend draggable="true">##label##</legend>
 				<input type="hidden" id="share_##key##_type" name="share[##key##][type]" value="##type##" data-leave-validation="" />
 				<div class="form-group" id="group-share-##key##">
@@ -27,10 +27,10 @@
 						<button type="button" class="remove btn btn-attention" title="<?= _t('conf.sharing.remove') ?>"><?= _t('gen.action.remove') ?></button>
 					</div>
 				</div>
-			</formgroup>
+			</fieldset>
 		</template>
 		<template id="advanced-share">
-			<formgroup class="group-share dragbox">
+			<fieldset class="group-share dragbox">
 				<legend draggable="true">##label##</legend>
 				<input type="hidden" id="share_##key##_type" name="share[##key##][type]" value="##type##" data-leave-validation="" />
 				<input type="hidden" id="share_##key##_method" name="share[##key##][method]" value="##method##" />
@@ -53,7 +53,7 @@
 						<button type="button" class="remove btn btn-attention" title="<?= _t('conf.sharing.remove') ?>"><?= _t('gen.action.remove') ?></button>
 					</div>
 				</div>
-			</formgroup>
+			</fieldset>
 		</template>
 
 		<?php
@@ -64,7 +64,7 @@
 				}
 				$share->update($share_options);
 		?>
-		<formgroup class="group-share dragbox" id="group-share-<?= $key ?>">
+		<fieldset class="group-share dragbox" id="group-share-<?= $key ?>">
 			<legend draggable="true"><?= $share->name(true) ?></legend>
 			<input type="hidden" id="share_<?= $key ?>_type" name="share[<?= $key ?>][type]" value="<?= $share->type() ?>" />
 			<input type="hidden" id="share_<?= $key ?>_method" name="share[<?= $key ?>][method]" value="<?= $share->method() ?>" />
@@ -110,13 +110,11 @@
 			</div>
 
 
-		</formgroup>
+		</fieldset>
 		<?php } ?>
 
-		<formgroup>
-			<legend>
-				<?= _t('conf.sharing.add') ?>
-			</legend>
+		<fieldset>
+			<legend><?= _t('conf.sharing.add') ?></legend>
 			<div class="form-group">
 				<div class="group-controls">
 					<div class="stick">
@@ -132,7 +130,7 @@
 					</div>
 				</div>
 			</div>
-		</formgroup>
+		</fieldset>
 
 		<div class="form-group form-actions">
 			<div class="group-controls">

+ 1 - 1
app/views/configure/system.phtml

@@ -74,7 +74,7 @@
 			</div>
 		</div>
 
-		<legend><?= _t('admin.system.registration.title') ?></legend>
+		<h2><?= _t('admin.system.registration.title') ?></h2>
 
 		<div class="form-group">
 			<label class="group-name" for="max-registrations-select"><?= _t('admin.system.registration.select.label') ?></label>

+ 62 - 56
app/views/feed/add.phtml

@@ -3,7 +3,7 @@
 	/** @var FreshRSS_View $this */
 	if ($this->feed !== null) {
 ?>
-<main class="post">
+<main class="post bookmarklet">
 	<h1><?= _t('sub.feed.add') ?></h1>
 
 	<?php if (!$this->load_ok) { ?>
@@ -12,76 +12,82 @@
 
 	<form method="post" action="<?= _url('feed', 'add') ?>" autocomplete="off">
 		<input type="hidden" name="_csrf" value="<?= FreshRSS_Auth::csrfToken() ?>" />
-		<legend><?= _t('sub.feed.information') ?></legend>
-		<?php if ($this->load_ok) { ?>
-		<div class="form-group">
-			<label class="group-name"><?= _t('sub.feed.title') ?></label>
-			<div class="group-controls">
-				<label><?= $this->feed->name()  ?></label>
+		<fieldset>
+			<legend><?= _t('sub.feed.information') ?></legend>
+			<?php if ($this->load_ok) { ?>
+			<div class="form-group">
+				<label class="group-name"><?= _t('sub.feed.title') ?></label>
+				<div class="group-controls">
+					<label><?= $this->feed->name()  ?></label>
+				</div>
 			</div>
-		</div>
 
-		<?php $desc = $this->feed->description(); if ($desc != '') { ?>
-		<div class="form-group">
-			<label class="group-name"><?= _t('sub.feed.description') ?></label>
-			<div class="group-controls">
-				<label><?= htmlspecialchars($desc, ENT_NOQUOTES, 'UTF-8') ?></label>
+			<?php $desc = $this->feed->description(); if ($desc != '') { ?>
+			<div class="form-group">
+				<label class="group-name"><?= _t('sub.feed.description') ?></label>
+				<div class="group-controls">
+					<label><?= htmlspecialchars($desc, ENT_NOQUOTES, 'UTF-8') ?></label>
+				</div>
 			</div>
-		</div>
-		<?php } ?>
+			<?php } ?>
 
-		<div class="form-group">
-			<label class="group-name"><?= _t('sub.feed.website') ?></label>
-			<div class="group-controls">
-				<div class="stick">
-					<input type="text" value="<?= $this->feed->website() ?>" disabled="disabled" />
-					<a class="btn" target="_blank" rel="noreferrer" href="<?= $this->feed->website() ?>"><?= _i('link') ?></a>
+			<div class="form-group">
+				<label class="group-name"><?= _t('sub.feed.website') ?></label>
+				<div class="group-controls">
+					<div class="stick">
+						<input type="text" value="<?= $this->feed->website() ?>" disabled="disabled" />
+						<a class="btn" target="_blank" rel="noreferrer" href="<?= $this->feed->website() ?>"><?= _i('link') ?></a>
+					</div>
 				</div>
 			</div>
-		</div>
-		<?php } ?>
+			<?php } ?>
 
-		<div class="form-group">
-			<label class="group-name" for="url"><?= _t('sub.feed.url') ?></label>
-			<div class="group-controls">
-				<div class="stick">
-					<input type="text" name="url_rss" id="url" value="<?= $this->feed->url() ?>" />
-					<a class="btn open-url" target="_blank" rel="noreferrer" href="<?= $this->feed->url() ?>" data-input="url" title="<?= _t('gen.action.open_url') ?>"><?= _i('link') ?></a>
+			<div class="form-group">
+				<label class="group-name" for="url"><?= _t('sub.feed.url') ?></label>
+				<div class="group-controls">
+					<div class="stick">
+						<input type="text" name="url_rss" id="url" value="<?= $this->feed->url() ?>" />
+						<a class="btn open-url" target="_blank" rel="noreferrer" href="<?= $this->feed->url() ?>" data-input="url" title="<?= _t('gen.action.open_url') ?>"><?= _i('link') ?></a>
+					</div>
+					<br />
+					<a class="btn" target="_blank" rel="noreferrer" href="https://validator.w3.org/feed/check.cgi?url=<?= $this->feed->url() ?>"><?= _t('sub.feed.validator') ?></a>
 				</div>
-				<br />
-				<a class="btn" target="_blank" rel="noreferrer" href="https://validator.w3.org/feed/check.cgi?url=<?= $this->feed->url() ?>"><?= _t('sub.feed.validator') ?></a>
 			</div>
-		</div>
-		<div class="form-group">
-			<label class="group-name" for="category"><?= _t('sub.category') ?></label>
-			<div class="group-controls">
-				<select name="category" id="category">
-					<?php foreach ($this->categories as $cat) { ?>
-					<option value="<?= $cat->id() ?>"<?= $cat->id() == 1 ? ' selected="selected"' : '' ?>>
-						<?= $cat->name() ?>
-					</option>
-					<?php } ?>
-				</select>
+			<div class="form-group">
+				<label class="group-name" for="category"><?= _t('sub.category') ?></label>
+				<div class="group-controls">
+					<select name="category" id="category">
+						<?php foreach ($this->categories as $cat) { ?>
+						<option value="<?= $cat->id() ?>"<?= $cat->id() == 1 ? ' selected="selected"' : '' ?>>
+							<?= $cat->name() ?>
+						</option>
+						<?php } ?>
+					</select>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 
-		<legend><?= _t('sub.feed.auth.http') ?></legend>
-		<?php $auth = $this->feed->httpAuth(false); ?>
-		<div class="form-group">
-			<label class="group-name" for="http_user"><?= _t('sub.feed.auth.username') ?></label>
-			<div class="group-controls">
-				<input type="text" name="http_user" id="http_user" value="<?= $auth['username'] ?>" autocomplete="off" />
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.auth.help') ?></p>
+		<fieldset>
+			<legend><?= _t('sub.feed.auth.http') ?></legend>
+			<?php $auth = $this->feed->httpAuth(false); ?>
+			<div class="form-group">
+				<label class="group-name" for="http_user"><?= _t('sub.feed.auth.username') ?></label>
+				<div class="group-controls">
+					<input type="text" name="http_user" id="http_user" value="<?= $auth['username'] ?>" autocomplete="off" />
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.auth.help') ?></p>
+				</div>
 			</div>
 
-			<label class="group-name" for="http_pass"><?= _t('sub.feed.auth.password') ?></label>
-			<div class="group-controls">
-				<div class="stick">
-					<input type="password" name="http_pass" id="http_pass" value="<?= $auth['password'] ?>" autocomplete="new-password" />
-					<button type="button" class="btn toggle-password" data-toggle="http_pass"><?= _i('key') ?></button>
+			<div class="form-group">
+				<label class="group-name" for="http_pass"><?= _t('sub.feed.auth.password') ?></label>
+				<div class="group-controls">
+					<div class="stick">
+						<input type="password" name="http_pass" id="http_pass" value="<?= $auth['password'] ?>" autocomplete="new-password" />
+						<button type="button" class="btn toggle-password" data-toggle="http_pass"><?= _i('key') ?></button>
+					</div>
 				</div>
 			</div>
-		</div>
+		</fieldset>
 
 		<div class="form-group form-actions">
 			<div class="group-controls">

+ 201 - 194
app/views/helpers/category/update.phtml

@@ -17,224 +17,231 @@
 
 	<form method="post" action="<?= _url('category', 'update', 'id', $this->category->id(), '#', 'slider') ?>" autocomplete="off">
 		<input type="hidden" name="_csrf" value="<?= FreshRSS_Auth::csrfToken() ?>" />
-
-		<legend><?= _t('sub.category.information') ?></legend>
-		<div class="form-group">
-			<label class="group-name" for="name"><?= _t('sub.category.title') ?></label>
-			<div class="group-controls">
-				<input type="text" name="name" id="name" value="<?= $this->category->name()  ?>" <?=
-					//Disallow changing the name of the default category
-					$this->category->id() === FreshRSS_CategoryDAO::DEFAULTCATEGORYID ? 'readonly="readonly"' : ''
-				?> />
+		<fieldset>
+			<legend><?= _t('sub.category.information') ?></legend>
+			<div class="form-group">
+				<label class="group-name" for="name"><?= _t('sub.category.title') ?></label>
+				<div class="group-controls">
+					<input type="text" name="name" id="name" value="<?= $this->category->name()  ?>" <?=
+						//Disallow changing the name of the default category
+						$this->category->id() === FreshRSS_CategoryDAO::DEFAULTCATEGORYID ? 'readonly="readonly"' : ''
+					?> />
+				</div>
 			</div>
-		</div>
-		<div class="form-group">
-			<label class="group-name" for="position"><?= _t('sub.category.position') ?></label>
-			<div class="group-controls">
-				<input type="number" name="position" id="position" min="1" value="<?= $this->category->attributeInt('position') ?>" />
-				<p class="help"><?= _i('help') ?> <?= _t('sub.category.position_help') ?></p>
+			<div class="form-group">
+				<label class="group-name" for="position"><?= _t('sub.category.position') ?></label>
+				<div class="group-controls">
+					<input type="number" name="position" id="position" min="1" value="<?= $this->category->attributeInt('position') ?>" />
+					<p class="help"><?= _i('help') ?> <?= _t('sub.category.position_help') ?></p>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
-				<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+					<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 
 		<?php if (!$this->category->isDefault()): ?>
-		<legend><?= _t('sub.category.dynamic_opml') ?> <?= _i('opml-dyn') ?></legend>
-		<div class="form-group">
-			<label class="group-name" for="opml_url"><?= _t('sub.category.opml_url') ?></label>
-			<div class="group-controls">
-				<div class="stick">
-					<input id="opml_url" name="opml_url" type="url" autocomplete="off" class="long" data-disable-update="refreshOpml" value="<?= $this->category->attributeString('opml_url') ?>" />
-					<button type="submit" class="btn" id="refreshOpml" formmethod="post" formaction="<?= _url('category', 'refreshOpml', 'id', $this->category->id()) ?>">
-						<?= _i('refresh') ?> <?= _t('gen.action.refresh_opml') ?>
-					</button>
-					<a class="btn open-url" target="_blank" rel="noreferrer" href="" data-input="opml_url" title="<?= _t('gen.action.open_url') ?>"><?= _i('link') ?></a>
-				</div>
-				<p class="help"><?= _i('help') ?> <?= _t('gen.short.blank_to_disable') ?></p>
-				<p class="help"><?= _i('help') ?> <?= _t('sub.category.dynamic_opml.help') ?></p>
-			</div>
-		</div>
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
-				<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
-				<button type="submit" class="btn btn-attention confirm"
-					data-str-confirm="<?= _t('gen.js.confirm_action_feed_cat') ?>"
-					formaction="<?= _url('category', 'empty', 'id', $this->category->id(), 'muted', 1) ?>"
-					formmethod="post"><?= _t('gen.action.delete_muted_feeds') ?></button>
-			</div>
-		</div>
+			<fieldset>
+				<legend><?= _t('sub.category.dynamic_opml') ?> <?= _i('opml-dyn') ?></legend>
+				<div class="form-group">
+					<label class="group-name" for="opml_url"><?= _t('sub.category.opml_url') ?></label>
+					<div class="group-controls">
+						<div class="stick">
+							<input id="opml_url" name="opml_url" type="url" autocomplete="off" class="long" data-disable-update="refreshOpml" value="<?= $this->category->attributeString('opml_url') ?>" />
+							<button type="submit" class="btn" id="refreshOpml" formmethod="post" formaction="<?= _url('category', 'refreshOpml', 'id', $this->category->id()) ?>">
+								<?= _i('refresh') ?> <?= _t('gen.action.refresh_opml') ?>
+							</button>
+							<a class="btn open-url" target="_blank" rel="noreferrer" href="" data-input="opml_url" title="<?= _t('gen.action.open_url') ?>"><?= _i('link') ?></a>
+						</div>
+						<p class="help"><?= _i('help') ?> <?= _t('gen.short.blank_to_disable') ?></p>
+						<p class="help"><?= _i('help') ?> <?= _t('sub.category.dynamic_opml.help') ?></p>
+					</div>
+				</div>
+				<div class="form-group form-actions">
+					<div class="group-controls">
+						<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+						<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+						<button type="submit" class="btn btn-attention confirm"
+							data-str-confirm="<?= _t('gen.js.confirm_action_feed_cat') ?>"
+							formaction="<?= _url('category', 'empty', 'id', $this->category->id(), 'muted', 1) ?>"
+							formmethod="post"><?= _t('gen.action.delete_muted_feeds') ?></button>
+					</div>
+				</div>
+			</fieldset>
 		<?php endif; ?>
 
-		<legend><?= _t('sub.feed.filteractions') ?></legend>
-		<div class="form-group">
-			<label class="group-name" for="filteractions_read"><?= _t('conf.reading.read.when') ?></label>
-			<div class="group-controls">
-				<textarea name="filteractions_read" id="filteractions_read" class="w100"><?php
-					foreach ($this->category->filtersAction('read') as $filterRead) {
-						echo $filterRead->getRawInput(), PHP_EOL;
-					}
-				?></textarea>
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.filteractions.help') ?></p>
+		<fieldset>
+			<legend><?= _t('sub.feed.filteractions') ?></legend>
+			<div class="form-group">
+				<label class="group-name" for="filteractions_read"><?= _t('conf.reading.read.when') ?></label>
+				<div class="group-controls">
+					<textarea name="filteractions_read" id="filteractions_read" class="w100"><?php
+						foreach ($this->category->filtersAction('read') as $filterRead) {
+							echo $filterRead->getRawInput(), PHP_EOL;
+						}
+					?></textarea>
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.filteractions.help') ?></p>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
-				<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+					<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 
-		<legend><?= _t('sub.category.archiving') ?></legend>
-		<?php
-			$archiving = $this->category->attributeArray('archiving');
-			/** @var array<'default'?:bool,'keep_period'?:string,'keep_max'?:int,'keep_min'?:int,'keep_favourites'?:bool,'keep_labels'?:bool,'keep_unreads'?:bool>|null $archiving */
-			if (empty($archiving)) {
-				$archiving = [ 'default' => true ];
-			} else {
-				$archiving['default'] = false;
-			}
-			$volatile = [
-				'enable_keep_period' => false,
-				'keep_period_count' => '3',
-				'keep_period_unit' => 'P1M',
-			];
-			if (!empty($archiving['keep_period']) && is_string($archiving['keep_period'])) {
-				if (preg_match('/^PT?(?P<count>\d+)[YMWDH]$/', $archiving['keep_period'], $matches)) {
-					$volatile['enable_keep_period'] = true;
-					$volatile['keep_period_count'] = $matches['count'];
-					$volatile['keep_period_unit'] = str_replace($matches['count'], '1', $archiving['keep_period']);
+		<fieldset>
+			<legend><?= _t('sub.category.archiving') ?></legend>
+			<?php
+				$archiving = $this->category->attributeArray('archiving');
+				/** @var array<'default'?:bool,'keep_period'?:string,'keep_max'?:int,'keep_min'?:int,'keep_favourites'?:bool,'keep_labels'?:bool,'keep_unreads'?:bool>|null $archiving */
+				if (empty($archiving)) {
+					$archiving = [ 'default' => true ];
+				} else {
+					$archiving['default'] = false;
+				}
+				$volatile = [
+					'enable_keep_period' => false,
+					'keep_period_count' => '3',
+					'keep_period_unit' => 'P1M',
+				];
+				if (!empty($archiving['keep_period']) && is_string($archiving['keep_period'])) {
+					if (preg_match('/^PT?(?P<count>\d+)[YMWDH]$/', $archiving['keep_period'], $matches)) {
+						$volatile['enable_keep_period'] = true;
+						$volatile['keep_period_count'] = $matches['count'];
+						$volatile['keep_period_unit'] = str_replace($matches['count'], '1', $archiving['keep_period']);
+					}
+				}
+				//Defaults
+				if (!isset($archiving['keep_max']) || !is_int($archiving['keep_max'])) {
+					$archiving['keep_max'] = 0;
 				}
-			}
-			//Defaults
-			if (!isset($archiving['keep_max']) || !is_int($archiving['keep_max'])) {
-				$archiving['keep_max'] = 0;
-			}
-			if (!isset($archiving['keep_min']) || !is_int($archiving['keep_min'])) {
-				$archiving['keep_min'] = 50;
-			}
-			if (!isset($archiving['keep_favourites']) || !is_bool($archiving['keep_favourites'])) {
-				$archiving['keep_favourites'] = true;
-			}
-			if (!isset($archiving['keep_labels']) || !is_bool($archiving['keep_labels'])) {
-				$archiving['keep_labels'] = true;
-			}
-			if (!isset($archiving['keep_unreads']) || !is_bool($archiving['keep_unreads'])) {
-				$archiving['keep_unreads'] = false;
-			}
-		?>
+				if (!isset($archiving['keep_min']) || !is_int($archiving['keep_min'])) {
+					$archiving['keep_min'] = 50;
+				}
+				if (!isset($archiving['keep_favourites']) || !is_bool($archiving['keep_favourites'])) {
+					$archiving['keep_favourites'] = true;
+				}
+				if (!isset($archiving['keep_labels']) || !is_bool($archiving['keep_labels'])) {
+					$archiving['keep_labels'] = true;
+				}
+				if (!isset($archiving['keep_unreads']) || !is_bool($archiving['keep_unreads'])) {
+					$archiving['keep_unreads'] = false;
+				}
+			?>
 
-		<p class="alert alert-warn">
-			<?= _t('conf.archiving.policy_warning') ?>
-		</p>
+			<p class="alert alert-warn">
+				<?= _t('conf.archiving.policy_warning') ?>
+			</p>
 
-		<div class="form-group">
-			<label class="group-name" for="use_default_purge_options"><?= _t('conf.archiving.policy') ?></label>
-			<div class="group-controls">
-				<label class="checkbox">
-					<input type="checkbox" name="use_default_purge_options" id="use_default_purge_options" value="1"<?= $archiving['default'] ? ' checked="checked"' : '' ?>
-						data-leave-validation="<?= $archiving['default'] ? 1 : 0 ?>" />
-					<?= _t('gen.short.by_default') ?>
-				</label>
+			<div class="form-group">
+				<label class="group-name" for="use_default_purge_options"><?= _t('conf.archiving.policy') ?></label>
+				<div class="group-controls">
+					<label class="checkbox">
+						<input type="checkbox" name="use_default_purge_options" id="use_default_purge_options" value="1"<?= $archiving['default'] ? ' checked="checked"' : '' ?>
+							data-leave-validation="<?= $archiving['default'] ? 1 : 0 ?>" />
+						<?= _t('gen.short.by_default') ?>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
-			<div class="group-controls">
-				<label class="checkbox" for="enable_keep_max">
-					<input type="checkbox" name="enable_keep_max" id="enable_keep_max" value="1"<?= empty($archiving['keep_max']) ? '' : ' checked="checked"' ?>
-						data-leave-validation="<?= empty($archiving['keep_max']) ? 0 : 1 ?>"/>
-					<?= _t('conf.archiving.keep_max') ?>
-					<input type="number" id="keep_max" name="keep_max" min="0" value="<?= empty($archiving['keep_max']) ? 200 : $archiving['keep_max'] ?>"
-						data-leave-validation="<?= empty($archiving['keep_max']) ? 200 : $archiving['keep_max'] ?>"/>
-				</label>
+			<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
+				<div class="group-controls">
+					<label class="checkbox" for="enable_keep_max">
+						<input type="checkbox" name="enable_keep_max" id="enable_keep_max" value="1"<?= empty($archiving['keep_max']) ? '' : ' checked="checked"' ?>
+							data-leave-validation="<?= empty($archiving['keep_max']) ? 0 : 1 ?>"/>
+						<?= _t('conf.archiving.keep_max') ?>
+						<input type="number" id="keep_max" name="keep_max" min="0" value="<?= empty($archiving['keep_max']) ? 200 : $archiving['keep_max'] ?>"
+							data-leave-validation="<?= empty($archiving['keep_max']) ? 200 : $archiving['keep_max'] ?>"/>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
-			<div class="group-controls">
-				<label class="checkbox" for="enable_keep_period">
-					<input type="checkbox" name="enable_keep_period" id="enable_keep_period" value="1"<?= $volatile['enable_keep_period'] ? ' checked="checked"' : '' ?>
-						data-leave-validation="<?= $volatile['enable_keep_period'] ? 1 : 0 ?>"/>
-					<?= _t('conf.archiving.keep_period') ?>
-					<input type="number" id="keep_period_count" name="keep_period_count" min="0" value="<?= $volatile['keep_period_count'] ?>"
-						data-leave-validation="<?= $volatile['keep_period_count'] ?>"/>
-					<select class="number" name="keep_period_unit" id="keep_period_unit" data-leave-validation="<?= $volatile['keep_period_unit'] ?>">
-						<option></option>
-						<option value="P1Y" <?= 'P1Y' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.years') ?></option>
-						<option value="P1M" <?= 'P1M' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.months') ?></option>
-						<option value="P1W" <?= 'P1W' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.weeks') ?></option>
-						<option value="P1D" <?= 'P1D' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.days') ?></option>
-						<option value="PT1H" <?= 'PT1H' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.hours') ?></option>
-					</select>
-				</label>
+			<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
+				<div class="group-controls">
+					<label class="checkbox" for="enable_keep_period">
+						<input type="checkbox" name="enable_keep_period" id="enable_keep_period" value="1"<?= $volatile['enable_keep_period'] ? ' checked="checked"' : '' ?>
+							data-leave-validation="<?= $volatile['enable_keep_period'] ? 1 : 0 ?>"/>
+						<?= _t('conf.archiving.keep_period') ?>
+						<input type="number" id="keep_period_count" name="keep_period_count" min="0" value="<?= $volatile['keep_period_count'] ?>"
+							data-leave-validation="<?= $volatile['keep_period_count'] ?>"/>
+						<select class="number" name="keep_period_unit" id="keep_period_unit" data-leave-validation="<?= $volatile['keep_period_unit'] ?>">
+							<option></option>
+							<option value="P1Y" <?= 'P1Y' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.years') ?></option>
+							<option value="P1M" <?= 'P1M' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.months') ?></option>
+							<option value="P1W" <?= 'P1W' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.weeks') ?></option>
+							<option value="P1D" <?= 'P1D' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.days') ?></option>
+							<option value="PT1H" <?= 'PT1H' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.hours') ?></option>
+						</select>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
-			<div class="group-name"><?= _t('conf.archiving.exception') ?></div>
-			<div class="group-controls">
-				<label class="checkbox" for="keep_favourites">
-					<input type="checkbox" name="keep_favourites" id="keep_favourites" value="1"<?= $archiving['keep_favourites'] ? ' checked="checked"' : '' ?>
-						data-leave-validation="<?= $archiving['keep_favourites'] ? 1 : 0 ?>"/>
-					<?= _t('conf.archiving.keep_favourites') ?>
-				</label>
+			<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
+				<div class="group-name"><?= _t('conf.archiving.exception') ?></div>
+				<div class="group-controls">
+					<label class="checkbox" for="keep_favourites">
+						<input type="checkbox" name="keep_favourites" id="keep_favourites" value="1"<?= $archiving['keep_favourites'] ? ' checked="checked"' : '' ?>
+							data-leave-validation="<?= $archiving['keep_favourites'] ? 1 : 0 ?>"/>
+						<?= _t('conf.archiving.keep_favourites') ?>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
-			<div class="group-controls">
-				<label class="checkbox" for="keep_labels">
-					<input type="checkbox" name="keep_labels" id="keep_labels" value="1"<?= $archiving['keep_labels'] ? ' checked="checked"' : '' ?>
-						data-leave-validation="<?= $archiving['keep_labels'] ? 1 : 0 ?>"/>
-					<?= _t('conf.archiving.keep_labels') ?>
-				</label>
+			<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
+				<div class="group-controls">
+					<label class="checkbox" for="keep_labels">
+						<input type="checkbox" name="keep_labels" id="keep_labels" value="1"<?= $archiving['keep_labels'] ? ' checked="checked"' : '' ?>
+							data-leave-validation="<?= $archiving['keep_labels'] ? 1 : 0 ?>"/>
+						<?= _t('conf.archiving.keep_labels') ?>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
-			<div class="group-controls">
-				<label class="checkbox" for="keep_unreads">
-					<input type="checkbox" name="keep_unreads" id="keep_unreads" value="1"<?= $archiving['keep_unreads'] ? ' checked="checked"' : '' ?>
-						data-leave-validation="<?= $archiving['keep_unreads'] ? 1 : 0 ?>"/>
-					<?= _t('conf.archiving.keep_unreads') ?>
-				</label>
+			<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
+				<div class="group-controls">
+					<label class="checkbox" for="keep_unreads">
+						<input type="checkbox" name="keep_unreads" id="keep_unreads" value="1"<?= $archiving['keep_unreads'] ? ' checked="checked"' : '' ?>
+							data-leave-validation="<?= $archiving['keep_unreads'] ? 1 : 0 ?>"/>
+						<?= _t('conf.archiving.keep_unreads') ?>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
-			<div class="group-controls">
-				<label for="keep_min"><?= _t('sub.feed.keep_min') ?>
-					<input type="number" id="keep_min" name="keep_min" min="0" value="<?= $archiving['keep_min'] ?>"
-						data-leave-validation="<?= $archiving['keep_min'] ?>">
-				</label>
+			<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
+				<div class="group-controls">
+					<label for="keep_min"><?= _t('sub.feed.keep_min') ?>
+						<input type="number" id="keep_min" name="keep_min" min="0" value="<?= $archiving['keep_min'] ?>"
+							data-leave-validation="<?= $archiving['keep_min'] ?>">
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
-				<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+					<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+				</div>
 			</div>
-		</div>
 
-		<?php if (!$this->category->isDefault()): ?>
-		<p class="alert alert-warn">
-			<?= _t('sub.feed.moved_category_deleted', _t('gen.short.default_category')) ?>
-		</p>
-		<?php endif;?>
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-attention confirm"
-					data-str-confirm="<?= _t('gen.js.confirm_action_feed_cat') ?>"
-					formaction="<?= _url('category', 'empty', 'id', $this->category->id()) ?>"
-					formmethod="post"><?= _t('gen.action.empty') ?></button>
-				<?php if (!$this->category->isDefault()): ?>
-				<button type="submit" class="btn btn-attention confirm"
-					data-str-confirm="<?= _t('gen.js.confirm_action_feed_cat') ?>"
-					formaction="<?= _url('category', 'delete', 'id', $this->category->id()) ?>"
-					formmethod="post"><?= _t('gen.action.remove') ?></button>
-				<?php endif;?>
+			<?php if (!$this->category->isDefault()): ?>
+			<p class="alert alert-warn">
+				<?= _t('sub.feed.moved_category_deleted', _t('gen.short.default_category')) ?>
+			</p>
+			<?php endif;?>
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button type="submit" class="btn btn-attention confirm"
+						data-str-confirm="<?= _t('gen.js.confirm_action_feed_cat') ?>"
+						formaction="<?= _url('category', 'empty', 'id', $this->category->id()) ?>"
+						formmethod="post"><?= _t('gen.action.empty') ?></button>
+					<?php if (!$this->category->isDefault()): ?>
+					<button type="submit" class="btn btn-attention confirm"
+						data-str-confirm="<?= _t('gen.js.confirm_action_feed_cat') ?>"
+						formaction="<?= _url('category', 'delete', 'id', $this->category->id()) ?>"
+						formmethod="post"><?= _t('gen.action.remove') ?></button>
+					<?php endif;?>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 	</form>
 </div>

+ 109 - 105
app/views/helpers/configure/query.phtml

@@ -22,120 +22,124 @@
 			</div>
 		</div>
 
-		<legend><?= _t('conf.query.share') ?></legend>
-		<div class="form-group">
-			<div class="group-controls">
-				<label class="checkbox" for="shareRss">
-					<input type="checkbox" name="query[shareRss]" id="shareRss" value="1" <?= $this->query->shareRss() ? 'checked="checked"' : ''?> />
-					<?= _t('conf.query.filter.shareRss') ?>
-				</label>
-				<?php if ($this->query->sharedUrlRss() !== ''): ?>
-				<ul>
-					<li><a href="<?= $this->query->sharedUrlHtml() ?>"><?= _i('link') ?> <?= _t('conf.query.share.html') ?></a></li>
-					<li><a href="<?= $this->query->sharedUrlRss() ?>"><?= _i('link') ?> <?= _t('conf.query.share.rss') ?></a></li>
-				</ul>
-				<?php endif; ?>
-			</div>
-			<div class="group-controls">
-				<label class="checkbox" for="shareOpml">
-					<input type="checkbox" name="query[shareOpml]" id="shareOpml" value="1" <?= $this->query->shareOpml() && $this->query->safeForOpml() ? 'checked="checked"' : '' ?>
-						<?= $this->query->safeForOpml() ? '' : 'disabled="disabled"' ?> />
-					<?= _t('conf.query.filter.shareOpml') ?>
-				</label>
-				<?php if ($this->query->sharedUrlOpml() !== ''): ?>
-				<ul>
-					<li><a href="<?= $this->query->sharedUrlOpml() ?>"><?= _i('link') ?> <?= _t('conf.query.share.opml') ?></a></li>
-				</ul>
-				<?php endif; ?>
+		<fieldset>
+			<legend><?= _t('conf.query.share') ?></legend>
+			<div class="form-group">
+				<div class="group-controls">
+					<label class="checkbox" for="shareRss">
+						<input type="checkbox" name="query[shareRss]" id="shareRss" value="1" <?= $this->query->shareRss() ? 'checked="checked"' : ''?> />
+						<?= _t('conf.query.filter.shareRss') ?>
+					</label>
+					<?php if ($this->query->sharedUrlRss() !== ''): ?>
+					<ul>
+						<li><a href="<?= $this->query->sharedUrlHtml() ?>"><?= _i('link') ?> <?= _t('conf.query.share.html') ?></a></li>
+						<li><a href="<?= $this->query->sharedUrlRss() ?>"><?= _i('link') ?> <?= _t('conf.query.share.rss') ?></a></li>
+					</ul>
+					<?php endif; ?>
+				</div>
+				<div class="group-controls">
+					<label class="checkbox" for="shareOpml">
+						<input type="checkbox" name="query[shareOpml]" id="shareOpml" value="1" <?= $this->query->shareOpml() && $this->query->safeForOpml() ? 'checked="checked"' : '' ?>
+							<?= $this->query->safeForOpml() ? '' : 'disabled="disabled"' ?> />
+						<?= _t('conf.query.filter.shareOpml') ?>
+					</label>
+					<?php if ($this->query->sharedUrlOpml() !== ''): ?>
+					<ul>
+						<li><a href="<?= $this->query->sharedUrlOpml() ?>"><?= _i('link') ?> <?= _t('conf.query.share.opml') ?></a></li>
+					</ul>
+					<?php endif; ?>
+				</div>
+				<p class="help"><?= _i('help') ?> <?= _t('conf.query.share.help') ?></a></p>
+				<p class="help"><?= _i('help') ?> <?= _t('conf.query.help') ?></a></p>
 			</div>
-			<p class="help"><?= _i('help') ?> <?= _t('conf.query.share.help') ?></a></p>
-			<p class="help"><?= _i('help') ?> <?= _t('conf.query.help') ?></a></p>
-		</div>
 
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 
-		<legend><?= _t('conf.query.filter') ?></legend>
-		<div class="form-group">
-			<label class="group-name" for=""><?= _t('conf.query.filter.search') ?></label>
-			<div class="group-controls">
-				<input type="text" id="query_search" name="query[search]" value="<?= htmlspecialchars($this->query->getSearch()->getRawInput(), ENT_COMPAT, 'UTF-8') ?>"/>
-				<p class="help"><?= _i('help') ?> <?= _t('gen.menu.search_help') ?></a></p>
+		<fieldset>
+			<legend><?= _t('conf.query.filter') ?></legend>
+			<div class="form-group">
+				<label class="group-name" for=""><?= _t('conf.query.filter.search') ?></label>
+				<div class="group-controls">
+					<input type="text" id="query_search" name="query[search]" value="<?= htmlspecialchars($this->query->getSearch()->getRawInput(), ENT_COMPAT, 'UTF-8') ?>"/>
+					<p class="help"><?= _i('help') ?> <?= _t('gen.menu.search_help') ?></a></p>
+				</div>
 			</div>
-		</div>
-		<div class="form-group">
-			<label class="group-name" for=""><?= _t('conf.query.filter.state') ?></label>
-			<div class="group-controls">
-				<label class="checkbox" for="show_read">
-					<input type="checkbox" name="query[state][]" id="show_read"
-						value="<?= FreshRSS_Entry::STATE_READ ?>" <?= FreshRSS_Entry::STATE_READ & $this->query->getState() ? 'checked="checked"' : ''?> />
-					<?= _t('index.menu.read') ?>
-				</label>
-				<label class="checkbox" for="show_not_read">
-					<input type="checkbox" name="query[state][]" id="show_not_read"
-						value="<?= FreshRSS_Entry::STATE_NOT_READ ?>" <?= FreshRSS_Entry::STATE_NOT_READ & $this->query->getState() ? 'checked="checked"' : ''?> />
-					<?= _t('index.menu.unread') ?>
-				</label>
-				<label class="checkbox" for="show_favorite">
-					<input type="checkbox" name="query[state][]" id="show_favorite"
-						value="<?= FreshRSS_Entry::STATE_FAVORITE ?>" <?= FreshRSS_Entry::STATE_FAVORITE & $this->query->getState() ? 'checked="checked"' : ''?> />
-					<?= _t('index.menu.starred') ?>
-				</label>
-				<label class="checkbox" for="show_not_favorite">
-					<input type="checkbox" name="query[state][]" id="show_not_favorite"
-						value="<?= FreshRSS_Entry::STATE_NOT_FAVORITE ?>" <?= FreshRSS_Entry::STATE_NOT_FAVORITE & $this->query->getState() ? 'checked="checked"' : ''?> />
-					<?= _t('index.menu.non-starred') ?>
-				</label>
+			<div class="form-group">
+				<label class="group-name" for=""><?= _t('conf.query.filter.state') ?></label>
+				<div class="group-controls">
+					<label class="checkbox" for="show_read">
+						<input type="checkbox" name="query[state][]" id="show_read"
+							value="<?= FreshRSS_Entry::STATE_READ ?>" <?= FreshRSS_Entry::STATE_READ & $this->query->getState() ? 'checked="checked"' : ''?> />
+						<?= _t('index.menu.read') ?>
+					</label>
+					<label class="checkbox" for="show_not_read">
+						<input type="checkbox" name="query[state][]" id="show_not_read"
+							value="<?= FreshRSS_Entry::STATE_NOT_READ ?>" <?= FreshRSS_Entry::STATE_NOT_READ & $this->query->getState() ? 'checked="checked"' : ''?> />
+						<?= _t('index.menu.unread') ?>
+					</label>
+					<label class="checkbox" for="show_favorite">
+						<input type="checkbox" name="query[state][]" id="show_favorite"
+							value="<?= FreshRSS_Entry::STATE_FAVORITE ?>" <?= FreshRSS_Entry::STATE_FAVORITE & $this->query->getState() ? 'checked="checked"' : ''?> />
+						<?= _t('index.menu.starred') ?>
+					</label>
+					<label class="checkbox" for="show_not_favorite">
+						<input type="checkbox" name="query[state][]" id="show_not_favorite"
+							value="<?= FreshRSS_Entry::STATE_NOT_FAVORITE ?>" <?= FreshRSS_Entry::STATE_NOT_FAVORITE & $this->query->getState() ? 'checked="checked"' : ''?> />
+						<?= _t('index.menu.non-starred') ?>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group">
-			<label class="group-name" for="query_get"><?= _t('conf.query.filter.type') ?></label>
-			<div class="group-controls">
-				<select name="query[get]" id="query_get" size="10">
-					<option value="a" <?= in_array($this->query->getGet(), ['', 'a'], true) ? 'selected="selected"' : '' ?>><?= _t('index.feed.title') ?></option>
-					<option value="i" <?= 'i' === $this->query->getGet() ? 'selected="selected"' : '' ?>><?= _t('index.menu.important') ?></option>
-					<option value="s" <?= 's' === $this->query->getGet() ? 'selected="selected"' : '' ?>><?= _t('index.feed.title_fav') ?></option>
-					<option value="T" <?= 'T' === $this->query->getGet() ? 'selected="selected"' : '' ?>><?= _t('index.menu.tags') ?></option>
-					<optgroup label="<?= _t('conf.query.filter.tags') ?>">
-						<?php foreach ($this->tags as $tag): ?>
-							<option value="t_<?= $tag->id() ?>" <?= "t_{$tag->id()}" === $this->query->getGet() ? 'selected="selected"' : '' ?>><?= $tag->name() ?></option>
-						<?php endforeach?>
-					</optgroup>
-					<optgroup label="<?= _t('conf.query.filter.categories') ?>">
-						<?php foreach ($this->categories as $category): ?>
-							<option value="c_<?= $category->id() ?>" <?= "c_{$category->id()}" === $this->query->getGet() ? 'selected="selected"' : '' ?>><?= $category->name() ?></option>
-						<?php endforeach?>
-					</optgroup>
-					<optgroup label="<?= _t('conf.query.filter.feeds') ?>">
-						<?php foreach ($this->feeds as $feed): ?>
-							<option value="f_<?= $feed->id() ?>" <?= "f_{$feed->id()}" === $this->query->getGet() ? 'selected="selected"' : '' ?>><?= $feed->name() ?></option>
-						<?php endforeach?>
-					</optgroup>
-				</select>
+			<div class="form-group">
+				<label class="group-name" for="query_get"><?= _t('conf.query.filter.type') ?></label>
+				<div class="group-controls">
+					<select name="query[get]" id="query_get" size="10">
+						<option value="a" <?= in_array($this->query->getGet(), ['', 'a'], true) ? 'selected="selected"' : '' ?>><?= _t('index.feed.title') ?></option>
+						<option value="i" <?= 'i' === $this->query->getGet() ? 'selected="selected"' : '' ?>><?= _t('index.menu.important') ?></option>
+						<option value="s" <?= 's' === $this->query->getGet() ? 'selected="selected"' : '' ?>><?= _t('index.feed.title_fav') ?></option>
+						<option value="T" <?= 'T' === $this->query->getGet() ? 'selected="selected"' : '' ?>><?= _t('index.menu.tags') ?></option>
+						<optgroup label="<?= _t('conf.query.filter.tags') ?>">
+							<?php foreach ($this->tags as $tag): ?>
+								<option value="t_<?= $tag->id() ?>" <?= "t_{$tag->id()}" === $this->query->getGet() ? 'selected="selected"' : '' ?>><?= $tag->name() ?></option>
+							<?php endforeach?>
+						</optgroup>
+						<optgroup label="<?= _t('conf.query.filter.categories') ?>">
+							<?php foreach ($this->categories as $category): ?>
+								<option value="c_<?= $category->id() ?>" <?= "c_{$category->id()}" === $this->query->getGet() ? 'selected="selected"' : '' ?>><?= $category->name() ?></option>
+							<?php endforeach?>
+						</optgroup>
+						<optgroup label="<?= _t('conf.query.filter.feeds') ?>">
+							<?php foreach ($this->feeds as $feed): ?>
+								<option value="f_<?= $feed->id() ?>" <?= "f_{$feed->id()}" === $this->query->getGet() ? 'selected="selected"' : '' ?>><?= $feed->name() ?></option>
+							<?php endforeach?>
+						</optgroup>
+					</select>
+				</div>
 			</div>
-		</div>
-		<div class="form-group">
-			<label class="group-name" for=""><?= _t('conf.query.filter.order') ?></label>
-			<div class="group-controls">
-				<select name="query[order]" id="query_order">
-					<option value=""></option>
-					<option value="DESC" <?= 'DESC' === $this->query->getOrder() ? 'selected="selected"' : '' ?>><?= _t('conf.query.order_desc') ?></option>
-					<option value="ASC" <?= 'ASC' === $this->query->getOrder() ? 'selected="selected"' : '' ?>><?= _t('conf.query.order_asc') ?></option>
-				</select>
+			<div class="form-group">
+				<label class="group-name" for=""><?= _t('conf.query.filter.order') ?></label>
+				<div class="group-controls">
+					<select name="query[order]" id="query_order">
+						<option value=""></option>
+						<option value="DESC" <?= 'DESC' === $this->query->getOrder() ? 'selected="selected"' : '' ?>><?= _t('conf.query.order_desc') ?></option>
+						<option value="ASC" <?= 'ASC' === $this->query->getOrder() ? 'selected="selected"' : '' ?>><?= _t('conf.query.order_asc') ?></option>
+					</select>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
-				<button type="submit" class="btn btn-attention confirm"
-					data-str-confirm="<?= _t('gen.js.confirm_action_feed_cat') ?>"
-					formaction="<?= _url('configure', 'deleteQuery', 'id', $this->queryId) ?>"
-					formmethod="post"><?= _t('gen.action.remove') ?></button>
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+					<button type="submit" class="btn btn-attention confirm"
+						data-str-confirm="<?= _t('gen.js.confirm_action_feed_cat') ?>"
+						formaction="<?= _url('configure', 'deleteQuery', 'id', $this->queryId) ?>"
+						formmethod="post"><?= _t('gen.action.remove') ?></button>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 	</form>
 </div>

+ 474 - 462
app/views/helpers/feed/update.phtml

@@ -34,381 +34,390 @@
 	?>
 	<form method="post" action="<?= $url ?>" autocomplete="off">
 		<input type="hidden" name="_csrf" value="<?= FreshRSS_Auth::csrfToken() ?>" />
-		<legend><?= _t('sub.feed.information') ?></legend>
-		<div class="form-group">
-			<label class="group-name" for="name"><?= _t('sub.feed.title') ?></label>
-			<div class="group-controls">
-				<input type="text" name="name" id="name" class="w100" value="<?= $this->feed->name(true) ?>" required="required" />
-			</div>
-		</div>
-		<div class="form-group">
-			<label class="group-name" for="description"><?= _t('sub.feed.description') ?></label>
-			<div class="group-controls">
-				<textarea name="description" id="description" class="w100"><?= htmlspecialchars($this->feed->description(), ENT_NOQUOTES, 'UTF-8') ?></textarea>
+		<fieldset>
+			<legend><?= _t('sub.feed.information') ?></legend>
+			<div class="form-group">
+				<label class="group-name" for="name"><?= _t('sub.feed.title') ?></label>
+				<div class="group-controls">
+					<input type="text" name="name" id="name" class="w100" value="<?= $this->feed->name(true) ?>" required="required" />
+				</div>
 			</div>
-		</div>
-		<div class="form-group">
-			<label class="group-name" for="website"><?= _t('sub.feed.website') ?></label>
-			<div class="group-controls">
-				<div class="stick w100">
-					<input type="url" name="website" id="website" value="<?= $this->feed->website() ?>" />
-					<a class="btn open-url" target="_blank" rel="noreferrer" href="<?= $this->feed->website() ?>" data-input="website" title="<?= _t('gen.action.open_url') ?>"><?= _i('link') ?></a>
+			<div class="form-group">
+				<label class="group-name" for="description"><?= _t('sub.feed.description') ?></label>
+				<div class="group-controls">
+					<textarea name="description" id="description" class="w100"><?= htmlspecialchars($this->feed->description(), ENT_NOQUOTES, 'UTF-8') ?></textarea>
 				</div>
 			</div>
-		</div>
-		<div class="form-group">
-			<label class="group-name" for="url"><?= _t('sub.feed.url') ?></label>
-			<div class="group-controls">
-				<div class="stick w100">
-					<input type="url" name="url" id="url" value="<?= $this->feed->url() ?>" required="required" />
-					<a class="btn open-url" target="_blank" rel="noreferrer" href="<?= $this->feed->url() ?>" data-input="url" title="<?= _t('gen.action.open_url') ?>"><?= _i('link') ?></a>
+			<div class="form-group">
+				<label class="group-name" for="website"><?= _t('sub.feed.website') ?></label>
+				<div class="group-controls">
+					<div class="stick w100">
+						<input type="url" name="website" id="website" value="<?= $this->feed->website() ?>" />
+						<a class="btn open-url" target="_blank" rel="noreferrer" href="<?= $this->feed->website() ?>" data-input="website" title="<?= _t('gen.action.open_url') ?>"><?= _i('link') ?></a>
+					</div>
 				</div>
-				<a class="btn" target="_blank" rel="noreferrer" href="https://validator.w3.org/feed/check.cgi?url=<?=
-					rawurlencode(htmlspecialchars_decode($this->feed->url(), ENT_QUOTES)) ?>"><?= _t('sub.feed.validator') ?></a>
 			</div>
-		</div>
-		<div class="form-group">
-			<label class="group-name" for="category"><?= _t('sub.category') ?></label>
-			<div class="group-controls">
-				<select name="category" id="category" class="w100">
-				<?php foreach ($this->categories as $cat) { ?>
-				<option value="<?= $cat->id() ?>"<?= $cat->id() == $this->feed->categoryId() ? ' selected="selected"' : '' ?>>
-					<?= $cat->name() ?>
-				</option>
-				<?php } ?>
-				</select>
+			<div class="form-group">
+				<label class="group-name" for="url"><?= _t('sub.feed.url') ?></label>
+				<div class="group-controls">
+					<div class="stick w100">
+						<input type="url" name="url" id="url" value="<?= $this->feed->url() ?>" required="required" />
+						<a class="btn open-url" target="_blank" rel="noreferrer" href="<?= $this->feed->url() ?>" data-input="url" title="<?= _t('gen.action.open_url') ?>"><?= _i('link') ?></a>
+					</div>
+					<a class="btn" target="_blank" rel="noreferrer" href="https://validator.w3.org/feed/check.cgi?url=<?=
+						rawurlencode(htmlspecialchars_decode($this->feed->url(), ENT_QUOTES)) ?>"><?= _t('sub.feed.validator') ?></a>
+				</div>
 			</div>
-		</div>
-		<div class="form-group">
-			<label class="group-name" for="priority"><?= _t('sub.feed.priority') ?></label>
-			<div class="group-controls">
-				<select name="priority" id="priority" class="w50">
-					<option value='<?= FreshRSS_Feed::PRIORITY_IMPORTANT ?>' <?php
-						if (FreshRSS_Feed::PRIORITY_IMPORTANT === $this->feed->priority()) {echo 'selected="selected"';}?>><?= _t('sub.feed.priority.important') ?></option>
-					<option value='<?= FreshRSS_Feed::PRIORITY_MAIN_STREAM ?>' <?php
-						if (FreshRSS_Feed::PRIORITY_MAIN_STREAM === $this->feed->priority()) {echo 'selected="selected"';}?>><?= _t('sub.feed.priority.main_stream') ?></option>
-					<option value='<?= FreshRSS_Feed::PRIORITY_CATEGORY ?>' <?php
-						if (FreshRSS_Feed::PRIORITY_CATEGORY === $this->feed->priority()) {echo 'selected="selected"';}?>><?= _t('sub.feed.priority.category') ?></option>
-					<option value='<?= FreshRSS_Feed::PRIORITY_ARCHIVED ?>' <?php
-						if (FreshRSS_Feed::PRIORITY_ARCHIVED === $this->feed->priority()) {echo 'selected="selected"';}?>><?= _t('sub.feed.priority.archived') ?></option>
-				</select>
-				<?= _i('important') ?>
+			<div class="form-group">
+				<label class="group-name" for="category"><?= _t('sub.category') ?></label>
+				<div class="group-controls">
+					<select name="category" id="category" class="w100">
+					<?php foreach ($this->categories as $cat) { ?>
+					<option value="<?= $cat->id() ?>"<?= $cat->id() == $this->feed->categoryId() ? ' selected="selected"' : '' ?>>
+						<?= $cat->name() ?>
+					</option>
+					<?php } ?>
+					</select>
+				</div>
 			</div>
-		</div>
-
-		<div class="form-group">
-			<label class="group-name" for="ttl"><?= _t('sub.feed.ttl') ?></label>
-			<div class="group-controls">
-				<select class="w50" name="ttl" id="ttl" required="required"><?php
-					$found = false;
-					foreach (array(FreshRSS_Feed::TTL_DEFAULT => _t('gen.short.by_default'), 900 => '15min', 1200 => '20min', 1500 => '25min', 1800 => '30min', 2700 => '45min',
-							3600 => '1h', 5400 => '1.5h', 7200 => '2h', 10800 => '3h', 14400 => '4h', 18800 => '5h', 21600 => '6h', 25200 => '7h', 28800 => '8h',
-							36000 => '10h', 43200 => '12h', 64800 => '18h',
-							86400 => '1d', 129600 => '1.5d', 172800 => '2d', 259200 => '3d', 345600 => '4d', 432000 => '5d', 518400 => '6d',
-							604800 => '1wk', 1209600 => '2wk', 1814400 => '3wk', 2419200 => '4wk', 2629744 => '1mo') as $v => $t) {
-						echo '<option value="' . $v . ($this->feed->ttl() === $v ? '" selected="selected' : '') . '">' . $t . '</option>';
-						if ($this->feed->ttl() == $v) {
-							$found = true;
-						}
-					}
-					if (!$found) {
-						echo '<option value="' . intval($this->feed->ttl()) . '" selected="selected">' . intval($this->feed->ttl()) . 's</option>';
-					}
-				?></select>
-				<label for="mute">
-					<input type="checkbox" name="mute" id="mute" value="1"<?= $this->feed->mute() ? ' checked="checked"' : '' ?> />
-					<?= _t('sub.feed.mute') ?>
-				</label>
+			<div class="form-group">
+				<label class="group-name" for="priority"><?= _t('sub.feed.priority') ?></label>
+				<div class="group-controls">
+					<select name="priority" id="priority" class="w50">
+						<option value='<?= FreshRSS_Feed::PRIORITY_IMPORTANT ?>' <?php
+							if (FreshRSS_Feed::PRIORITY_IMPORTANT === $this->feed->priority()) {echo 'selected="selected"';}?>><?= _t('sub.feed.priority.important') ?></option>
+						<option value='<?= FreshRSS_Feed::PRIORITY_MAIN_STREAM ?>' <?php
+							if (FreshRSS_Feed::PRIORITY_MAIN_STREAM === $this->feed->priority()) {echo 'selected="selected"';}?>><?= _t('sub.feed.priority.main_stream') ?></option>
+						<option value='<?= FreshRSS_Feed::PRIORITY_CATEGORY ?>' <?php
+							if (FreshRSS_Feed::PRIORITY_CATEGORY === $this->feed->priority()) {echo 'selected="selected"';}?>><?= _t('sub.feed.priority.category') ?></option>
+						<option value='<?= FreshRSS_Feed::PRIORITY_ARCHIVED ?>' <?php
+							if (FreshRSS_Feed::PRIORITY_ARCHIVED === $this->feed->priority()) {echo 'selected="selected"';}?>><?= _t('sub.feed.priority.archived') ?></option>
+					</select>
+					<?= _i('important') ?>
+				</div>
 			</div>
-		</div>
 
-		<?php if ($this->feed->pubSubHubbubEnabled()) { ?>
 			<div class="form-group">
+				<label class="group-name" for="ttl"><?= _t('sub.feed.ttl') ?></label>
 				<div class="group-controls">
-					<label class="checkbox" for="pubsubhubbub">
-						<input type="checkbox" name="pubsubhubbub" id="pubsubhubbub" disabled="disabled" value="1" checked="checked" />
-						<?= _t('sub.feed.websub') ?>
+					<select class="w50" name="ttl" id="ttl" required="required"><?php
+						$found = false;
+						foreach (array(FreshRSS_Feed::TTL_DEFAULT => _t('gen.short.by_default'), 900 => '15min', 1200 => '20min', 1500 => '25min', 1800 => '30min', 2700 => '45min',
+								3600 => '1h', 5400 => '1.5h', 7200 => '2h', 10800 => '3h', 14400 => '4h', 18800 => '5h', 21600 => '6h', 25200 => '7h', 28800 => '8h',
+								36000 => '10h', 43200 => '12h', 64800 => '18h',
+								86400 => '1d', 129600 => '1.5d', 172800 => '2d', 259200 => '3d', 345600 => '4d', 432000 => '5d', 518400 => '6d',
+								604800 => '1wk', 1209600 => '2wk', 1814400 => '3wk', 2419200 => '4wk', 2629744 => '1mo') as $v => $t) {
+							echo '<option value="' . $v . ($this->feed->ttl() === $v ? '" selected="selected' : '') . '">' . $t . '</option>';
+							if ($this->feed->ttl() == $v) {
+								$found = true;
+							}
+						}
+						if (!$found) {
+							echo '<option value="' . intval($this->feed->ttl()) . '" selected="selected">' . intval($this->feed->ttl()) . 's</option>';
+						}
+					?></select>
+					<label for="mute">
+						<input type="checkbox" name="mute" id="mute" value="1"<?= $this->feed->mute() ? ' checked="checked"' : '' ?> />
+						<?= _t('sub.feed.mute') ?>
 					</label>
 				</div>
 			</div>
-		<?php } ?>
 
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
-				<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
-				<?php
-				if ($from === '') {
-					$url = _url('feed', 'delete', 'id', $this->feed->id());
-				} else {
-					$url = _url('feed', 'delete', 'id', $this->feed->id(), 'from', $from);
-				}
-				?>
-				<button type="submit" class="btn btn-attention confirm"
-					data-str-confirm="<?= _t('gen.js.confirm_action_feed_cat') ?>"
-					formaction="<?= $url ?>"
-					formmethod="post"><?= _t('gen.action.remove') ?></button>
+			<?php if ($this->feed->pubSubHubbubEnabled()) { ?>
+				<div class="form-group">
+					<div class="group-controls">
+						<label class="checkbox" for="pubsubhubbub">
+							<input type="checkbox" name="pubsubhubbub" id="pubsubhubbub" disabled="disabled" value="1" checked="checked" />
+							<?= _t('sub.feed.websub') ?>
+						</label>
+					</div>
+				</div>
+			<?php } ?>
+
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+					<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+					<?php
+					if ($from === '') {
+						$url = _url('feed', 'delete', 'id', $this->feed->id());
+					} else {
+						$url = _url('feed', 'delete', 'id', $this->feed->id(), 'from', $from);
+					}
+					?>
+					<button type="submit" class="btn btn-attention confirm"
+						data-str-confirm="<?= _t('gen.js.confirm_action_feed_cat') ?>"
+						formaction="<?= $url ?>"
+						formmethod="post"><?= _t('gen.action.remove') ?></button>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 
-		<legend><?= _t('sub.feed.auth.configuration') ?></legend>
-		<?php $auth = $this->feed->httpAuth(false); ?>
-		<div class="form-group">
-			<label class="group-name" for="http_user_feed<?= $this->feed->id() ?>"><?= _t('sub.feed.auth.username') ?></label>
-			<div class="group-controls">
-				<input type="text" name="http_user_feed<?= $this->feed->id() ?>" id="http_user_feed<?= $this->feed->id() ?>" class="w50" value="<?=
-					empty($auth['username']) ? '' : $auth['username'] ?>" autocomplete="off" />
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.auth.help') ?></p>
+		<fieldset>
+			<legend><?= _t('sub.feed.auth.configuration') ?></legend>
+			<?php $auth = $this->feed->httpAuth(false); ?>
+			<div class="form-group">
+				<label class="group-name" for="http_user_feed<?= $this->feed->id() ?>"><?= _t('sub.feed.auth.username') ?></label>
+				<div class="group-controls">
+					<input type="text" name="http_user_feed<?= $this->feed->id() ?>" id="http_user_feed<?= $this->feed->id() ?>" class="w50" value="<?=
+						empty($auth['username']) ? '' : $auth['username'] ?>" autocomplete="off" />
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.auth.help') ?></p>
+				</div>
 			</div>
-		</div>
-		<div class="form-group">
-			<label class="group-name" for="http_pass_feed<?= $this->feed->id() ?>"><?= _t('sub.feed.auth.password') ?></label>
-			<div class="group-controls">
-				<div class="stick w50">
-					<input type="password" name="http_pass_feed<?= $this->feed->id() ?>" id="http_pass_feed<?= $this->feed->id() ?>" value="<?=
-						$auth['password'] ?>" autocomplete="new-password" />
-					<button type="button" class="btn toggle-password" data-toggle="http_pass_feed<?= $this->feed->id() ?>"><?= _i('key') ?></button>
+			<div class="form-group">
+				<label class="group-name" for="http_pass_feed<?= $this->feed->id() ?>"><?= _t('sub.feed.auth.password') ?></label>
+				<div class="group-controls">
+					<div class="stick w50">
+						<input type="password" name="http_pass_feed<?= $this->feed->id() ?>" id="http_pass_feed<?= $this->feed->id() ?>" value="<?=
+							$auth['password'] ?>" autocomplete="new-password" />
+						<button type="button" class="btn toggle-password" data-toggle="http_pass_feed<?= $this->feed->id() ?>"><?= _i('key') ?></button>
+					</div>
 				</div>
 			</div>
-		</div>
 
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
-				<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+					<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 
-		<legend><?= _t('sub.feed.filteractions') ?></legend>
-		<div class="form-group">
-			<label class="group-name" for="mark_updated_article_unread"><?= _t('conf.reading.mark_updated_article_unread') ?></label>
-			<div class="group-controls">
-				<select name="mark_updated_article_unread" id="mark_updated_article_unread" class="w50">
-					<option value=""<?= $this->feed->attributeBoolean('mark_updated_article_unread') === null ? ' selected="selected"' : '' ?>><?= _t('gen.short.by_default') ?></option>
-					<option value="0"<?= $this->feed->attributeBoolean('mark_updated_article_unread') === false ? ' selected="selected"' : '' ?>><?= _t('gen.short.no') ?></option>
-					<option value="1"<?= $this->feed->attributeBoolean('mark_updated_article_unread') === true ? ' selected="selected"' : '' ?>><?= _t('gen.short.yes') ?></option>
-				</select>
+		<fieldset>
+			<legend><?= _t('sub.feed.filteractions') ?></legend>
+			<div class="form-group">
+				<label class="group-name" for="mark_updated_article_unread"><?= _t('conf.reading.mark_updated_article_unread') ?></label>
+				<div class="group-controls">
+					<select name="mark_updated_article_unread" id="mark_updated_article_unread" class="w50">
+						<option value=""<?= $this->feed->attributeBoolean('mark_updated_article_unread') === null ? ' selected="selected"' : '' ?>><?= _t('gen.short.by_default') ?></option>
+						<option value="0"<?= $this->feed->attributeBoolean('mark_updated_article_unread') === false ? ' selected="selected"' : '' ?>><?= _t('gen.short.no') ?></option>
+						<option value="1"<?= $this->feed->attributeBoolean('mark_updated_article_unread') === true ? ' selected="selected"' : '' ?>><?= _t('gen.short.yes') ?></option>
+					</select>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<label class="group-name" for="read_when_same_title_in_feed"><?= _t('conf.reading.read.when') ?></label>
-			<div class="group-controls">
-				<select name="read_when_same_title_in_feed" id="read_when_same_title_in_feed" class="w50">
-					<option value=""<?= $this->feed->attributeBoolean('read_when_same_title_in_feed') === null ? ' selected="selected"' : '' ?>><?= _t('gen.short.by_default') ?></option>
-					<option value="0"<?= $this->feed->attributeBoolean('read_when_same_title_in_feed') === false ? ' selected="selected"' : '' ?>><?= _t('gen.short.no') ?></option>
-					<option value="10"<?= $this->feed->attributeInt('read_when_same_title_in_feed') == 10 ? ' selected="selected"' : '' ?>>10</option>
-					<option value="25"<?= $this->feed->attributeInt('read_when_same_title_in_feed') == 25 ? ' selected="selected"' : '' ?>>25</option>
-					<option value="100"<?= $this->feed->attributeInt('read_when_same_title_in_feed') == 100 ? ' selected="selected"' : '' ?>>100</option>
-					<option value="1000"<?= $this->feed->attributeInt('read_when_same_title_in_feed') == 1000 ? ' selected="selected"' : '' ?>>1 000</option>
-				</select>
-				<?= _t('conf.reading.read.when_same_title') ?>
+			<div class="form-group">
+				<label class="group-name" for="read_when_same_title_in_feed"><?= _t('conf.reading.read.when') ?></label>
+				<div class="group-controls">
+					<select name="read_when_same_title_in_feed" id="read_when_same_title_in_feed" class="w50">
+						<option value=""<?= $this->feed->attributeBoolean('read_when_same_title_in_feed') === null ? ' selected="selected"' : '' ?>><?= _t('gen.short.by_default') ?></option>
+						<option value="0"<?= $this->feed->attributeBoolean('read_when_same_title_in_feed') === false ? ' selected="selected"' : '' ?>><?= _t('gen.short.no') ?></option>
+						<option value="10"<?= $this->feed->attributeInt('read_when_same_title_in_feed') == 10 ? ' selected="selected"' : '' ?>>10</option>
+						<option value="25"<?= $this->feed->attributeInt('read_when_same_title_in_feed') == 25 ? ' selected="selected"' : '' ?>>25</option>
+						<option value="100"<?= $this->feed->attributeInt('read_when_same_title_in_feed') == 100 ? ' selected="selected"' : '' ?>>100</option>
+						<option value="1000"<?= $this->feed->attributeInt('read_when_same_title_in_feed') == 1000 ? ' selected="selected"' : '' ?>>1 000</option>
+					</select>
+					<?= _t('conf.reading.read.when_same_title') ?>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<label class="group-name" for="read_upon_reception"><?= _t('conf.reading.read.when') ?></label>
-			<div class="group-controls">
-				<select name="read_upon_reception" id="read_upon_reception" class="w50">
-					<option value=""<?= $this->feed->attributeBoolean('read_upon_reception') === null ? ' selected="selected"' : '' ?>><?= _t('gen.short.by_default') ?></option>
-					<option value="0"<?= $this->feed->attributeBoolean('read_upon_reception') === false ? ' selected="selected"' : '' ?>><?= _t('gen.short.no') ?></option>
-					<option value="1"<?= $this->feed->attributeBoolean('read_upon_reception') === true ? ' selected="selected"' : '' ?>><?= _t('gen.short.yes') ?></option>
-				</select>
-				<?= _t('conf.reading.read.upon_reception') ?>
+			<div class="form-group">
+				<label class="group-name" for="read_upon_reception"><?= _t('conf.reading.read.when') ?></label>
+				<div class="group-controls">
+					<select name="read_upon_reception" id="read_upon_reception" class="w50">
+						<option value=""<?= $this->feed->attributeBoolean('read_upon_reception') === null ? ' selected="selected"' : '' ?>><?= _t('gen.short.by_default') ?></option>
+						<option value="0"<?= $this->feed->attributeBoolean('read_upon_reception') === false ? ' selected="selected"' : '' ?>><?= _t('gen.short.no') ?></option>
+						<option value="1"<?= $this->feed->attributeBoolean('read_upon_reception') === true ? ' selected="selected"' : '' ?>><?= _t('gen.short.yes') ?></option>
+					</select>
+					<?= _t('conf.reading.read.upon_reception') ?>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<label class="group-name" for="read_upon_gone"><?= _t('conf.reading.read.when') ?></label>
-			<div class="group-controls">
-				<select name="read_upon_gone" id="read_upon_gone" class="w50">
-					<option value=""<?= $this->feed->attributeBoolean('read_upon_gone') === null ? ' selected="selected"' : '' ?>><?= _t('gen.short.by_default') ?></option>
-					<option value="0"<?= $this->feed->attributeBoolean('read_upon_gone') === false ? ' selected="selected"' : '' ?>><?= _t('gen.short.no') ?></option>
-					<option value="1"<?= $this->feed->attributeBoolean('read_upon_gone') === true ? ' selected="selected"' : '' ?>><?= _t('gen.short.yes') ?></option>
-				</select>
-				<?= _t('conf.reading.read.upon_gone') ?>
+			<div class="form-group">
+				<label class="group-name" for="read_upon_gone"><?= _t('conf.reading.read.when') ?></label>
+				<div class="group-controls">
+					<select name="read_upon_gone" id="read_upon_gone" class="w50">
+						<option value=""<?= $this->feed->attributeBoolean('read_upon_gone') === null ? ' selected="selected"' : '' ?>><?= _t('gen.short.by_default') ?></option>
+						<option value="0"<?= $this->feed->attributeBoolean('read_upon_gone') === false ? ' selected="selected"' : '' ?>><?= _t('gen.short.no') ?></option>
+						<option value="1"<?= $this->feed->attributeBoolean('read_upon_gone') === true ? ' selected="selected"' : '' ?>><?= _t('gen.short.yes') ?></option>
+					</select>
+					<?= _t('conf.reading.read.upon_gone') ?>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<label class="group-name" for="filteractions_read"><?= _t('conf.reading.read.when') ?></label>
-			<div class="group-controls">
-				<textarea name="filteractions_read" id="filteractions_read" class="w100"><?php
-					foreach ($this->feed->filtersAction('read') as $filterRead) {
-						echo $filterRead->getRawInput(), PHP_EOL;
-					}
-				?></textarea>
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.filteractions.help') ?></p>
+			<div class="form-group">
+				<label class="group-name" for="filteractions_read"><?= _t('conf.reading.read.when') ?></label>
+				<div class="group-controls">
+					<textarea name="filteractions_read" id="filteractions_read" class="w100"><?php
+						foreach ($this->feed->filtersAction('read') as $filterRead) {
+							echo $filterRead->getRawInput(), PHP_EOL;
+						}
+					?></textarea>
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.filteractions.help') ?></p>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<label class="group-name" for="keep_max_n_unread"><?= _t('conf.reading.read.keep_max_n_unread') ?></label>
-			<div class="group-controls">
-				<input type="number" name="keep_max_n_unread" id="keep_max_n_unread" class="w50" min="1" max="10000000"
-					data-leave-validation="<?= $this->feed->attributeInt('keep_max_n_unread') ?>"
-					value="<?= $this->feed->attributeInt('keep_max_n_unread') ?>"
-					placeholder="<?= _t('gen.short.by_default') ?>" />
+			<div class="form-group">
+				<label class="group-name" for="keep_max_n_unread"><?= _t('conf.reading.read.keep_max_n_unread') ?></label>
+				<div class="group-controls">
+					<input type="number" name="keep_max_n_unread" id="keep_max_n_unread" class="w50" min="1" max="10000000"
+						data-leave-validation="<?= $this->feed->attributeInt('keep_max_n_unread') ?>"
+						value="<?= $this->feed->attributeInt('keep_max_n_unread') ?>"
+						placeholder="<?= _t('gen.short.by_default') ?>" />
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
-				<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+					<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+				</div>
 			</div>
-		</div>
-
-		<legend><?= _t('sub.feed.archiving') ?></legend>
+		</fieldset>
 
-		<div class="form-group">
-			<div class="group-controls">
-				<?= _t('sub.feed.number_entries', $nbEntries) ?>
-				<a class="btn" href="<?= _url('feed', 'actualize', 'id', $this->feed->id(), '#', 'slider') ?>">
-					<?= _i('refresh') ?> <?= _t('gen.action.actualize') ?>
-				</a>
+		<fieldset>
+			<legend><?= _t('sub.feed.archiving') ?></legend>
+			<div class="form-group">
+				<div class="group-controls">
+					<?= _t('sub.feed.number_entries', $nbEntries) ?>
+					<a class="btn" href="<?= _url('feed', 'actualize', 'id', $this->feed->id(), '#', 'slider') ?>">
+						<?= _i('refresh') ?> <?= _t('gen.action.actualize') ?>
+					</a>
+				</div>
 			</div>
-		</div>
-		<?php
-			$archiving = $this->feed->attributeArray('archiving');
-			/** @var array<'default'?:bool,'keep_period'?:string,'keep_max'?:int,'keep_min'?:int,'keep_favourites'?:bool,'keep_labels'?:bool,'keep_unreads'?:bool>|null $archiving */
-			if (empty($archiving)) {
-				$archiving = [ 'default' => true ];
-			} else {
-				$archiving['default'] = false;
-			}
-			$volatile = [
-				'enable_keep_period' => false,
-				'keep_period_count' => '3',
-				'keep_period_unit' => 'P1M',
-			];
-			if (!empty($archiving['keep_period']) && is_string($archiving['keep_period'])) {
-				if (preg_match('/^PT?(?P<count>\d+)[YMWDH]$/', $archiving['keep_period'], $matches)) {
-					$volatile['enable_keep_period'] = true;
-					$volatile['keep_period_count'] = $matches['count'];
-					$volatile['keep_period_unit'] = str_replace($matches['count'], '1', $archiving['keep_period']);
+			<?php
+				$archiving = $this->feed->attributeArray('archiving');
+				/** @var array<'default'?:bool,'keep_period'?:string,'keep_max'?:int,'keep_min'?:int,'keep_favourites'?:bool,'keep_labels'?:bool,'keep_unreads'?:bool>|null $archiving */
+				if (empty($archiving)) {
+					$archiving = [ 'default' => true ];
+				} else {
+					$archiving['default'] = false;
+				}
+				$volatile = [
+					'enable_keep_period' => false,
+					'keep_period_count' => '3',
+					'keep_period_unit' => 'P1M',
+				];
+				if (!empty($archiving['keep_period']) && is_string($archiving['keep_period'])) {
+					if (preg_match('/^PT?(?P<count>\d+)[YMWDH]$/', $archiving['keep_period'], $matches)) {
+						$volatile['enable_keep_period'] = true;
+						$volatile['keep_period_count'] = $matches['count'];
+						$volatile['keep_period_unit'] = str_replace($matches['count'], '1', $archiving['keep_period']);
+					}
+				}
+				//Defaults
+				if (!isset($archiving['keep_max']) || !is_int($archiving['keep_max'])) {
+					$archiving['keep_max'] = 0;
+				}
+				if (!isset($archiving['keep_min']) || !is_int($archiving['keep_min'])) {
+					$archiving['keep_min'] = 50;
+				}
+				if (!isset($archiving['keep_favourites']) || !is_bool($archiving['keep_favourites'])) {
+					$archiving['keep_favourites'] = true;
+				}
+				if (!isset($archiving['keep_labels']) || !is_bool($archiving['keep_labels'])) {
+					$archiving['keep_labels'] = true;
 				}
-			}
-			//Defaults
-			if (!isset($archiving['keep_max']) || !is_int($archiving['keep_max'])) {
-				$archiving['keep_max'] = 0;
-			}
-			if (!isset($archiving['keep_min']) || !is_int($archiving['keep_min'])) {
-				$archiving['keep_min'] = 50;
-			}
-			if (!isset($archiving['keep_favourites']) || !is_bool($archiving['keep_favourites'])) {
-				$archiving['keep_favourites'] = true;
-			}
-			if (!isset($archiving['keep_labels']) || !is_bool($archiving['keep_labels'])) {
-				$archiving['keep_labels'] = true;
-			}
-			if (!isset($archiving['keep_unreads']) || !is_bool($archiving['keep_unreads'])) {
-				$archiving['keep_unreads'] = false;
-			}
-		?>
-
-		<p class="alert alert-warn">
-			<?= _t('conf.archiving.policy_warning') ?>
-		</p>
-
-		<div class="form-group">
-			<div class="group-name"><?= _t('conf.archiving.policy') ?></div>
-			<div class="group-controls">
-				<label class="checkbox">
-					<input type="checkbox" name="use_default_purge_options" id="use_default_purge_options" value="1"<?= $archiving['default'] ? ' checked="checked"' : '' ?>
-						data-leave-validation="<?= $archiving['default'] ? 1 : 0 ?>" />
-					<?= _t('gen.short.by_default') ?>
-				</label>
+				if (!isset($archiving['keep_unreads']) || !is_bool($archiving['keep_unreads'])) {
+					$archiving['keep_unreads'] = false;
+				}
+			?>
+
+			<p class="alert alert-warn">
+				<?= _t('conf.archiving.policy_warning') ?>
+			</p>
+
+			<div class="form-group">
+				<div class="group-name"><?= _t('conf.archiving.policy') ?></div>
+				<div class="group-controls">
+					<label class="checkbox">
+						<input type="checkbox" name="use_default_purge_options" id="use_default_purge_options" value="1"<?= $archiving['default'] ? ' checked="checked"' : '' ?>
+							data-leave-validation="<?= $archiving['default'] ? 1 : 0 ?>" />
+						<?= _t('gen.short.by_default') ?>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
-			<div class="group-controls">
-				<label class="checkbox" for="enable_keep_max">
-					<input type="checkbox" name="enable_keep_max" id="enable_keep_max" value="1"<?= empty($archiving['keep_max']) ? '' : ' checked="checked"' ?>
-						data-leave-validation="<?= empty($archiving['keep_max']) ? 0 : 1 ?>"/>
-					<?= _t('conf.archiving.keep_max') ?>
-					<input type="number" id="keep_max" name="keep_max" min="0" value="<?= empty($archiving['keep_max']) ? 200 : $archiving['keep_max'] ?>"
-						data-leave-validation="<?= empty($archiving['keep_max']) ? 200 : $archiving['keep_max'] ?>"/>
-				</label>
+			<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
+				<div class="group-controls">
+					<label class="checkbox" for="enable_keep_max">
+						<input type="checkbox" name="enable_keep_max" id="enable_keep_max" value="1"<?= empty($archiving['keep_max']) ? '' : ' checked="checked"' ?>
+							data-leave-validation="<?= empty($archiving['keep_max']) ? 0 : 1 ?>"/>
+						<?= _t('conf.archiving.keep_max') ?>
+						<input type="number" id="keep_max" name="keep_max" min="0" value="<?= empty($archiving['keep_max']) ? 200 : $archiving['keep_max'] ?>"
+							data-leave-validation="<?= empty($archiving['keep_max']) ? 200 : $archiving['keep_max'] ?>"/>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
-			<div class="group-controls">
-				<label class="checkbox" for="enable_keep_period">
-					<input type="checkbox" name="enable_keep_period" id="enable_keep_period" value="1"<?= $volatile['enable_keep_period'] ? ' checked="checked"' : '' ?>
-						data-leave-validation="<?= $volatile['enable_keep_period'] ? 1 : 0 ?>"/>
-					<?= _t('conf.archiving.keep_period') ?>
-					<input type="number" id="keep_period_count" name="keep_period_count" min="0" value="<?= $volatile['keep_period_count'] ?>"
-						data-leave-validation="<?= $volatile['keep_period_count'] ?>"/>
-					<select class="number" name="keep_period_unit" id="keep_period_unit" data-leave-validation="<?= $volatile['keep_period_unit'] ?>">
-						<option></option>
-						<option value="P1Y" <?= 'P1Y' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.years') ?></option>
-						<option value="P1M" <?= 'P1M' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.months') ?></option>
-						<option value="P1W" <?= 'P1W' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.weeks') ?></option>
-						<option value="P1D" <?= 'P1D' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.days') ?></option>
-						<option value="PT1H" <?= 'PT1H' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.hours') ?></option>
-					</select>
-				</label>
+			<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
+				<div class="group-controls">
+					<label class="checkbox" for="enable_keep_period">
+						<input type="checkbox" name="enable_keep_period" id="enable_keep_period" value="1"<?= $volatile['enable_keep_period'] ? ' checked="checked"' : '' ?>
+							data-leave-validation="<?= $volatile['enable_keep_period'] ? 1 : 0 ?>"/>
+						<?= _t('conf.archiving.keep_period') ?>
+						<input type="number" id="keep_period_count" name="keep_period_count" min="0" value="<?= $volatile['keep_period_count'] ?>"
+							data-leave-validation="<?= $volatile['keep_period_count'] ?>"/>
+						<select class="number" name="keep_period_unit" id="keep_period_unit" data-leave-validation="<?= $volatile['keep_period_unit'] ?>">
+							<option></option>
+							<option value="P1Y" <?= 'P1Y' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.years') ?></option>
+							<option value="P1M" <?= 'P1M' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.months') ?></option>
+							<option value="P1W" <?= 'P1W' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.weeks') ?></option>
+							<option value="P1D" <?= 'P1D' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.days') ?></option>
+							<option value="PT1H" <?= 'PT1H' === $volatile['keep_period_unit'] ? 'selected="selected"' : '' ?>><?= _t('gen.period.hours') ?></option>
+						</select>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
-			<div class="group-name"><?= _t('conf.archiving.exception') ?></div>
-			<div class="group-controls">
-				<label class="checkbox" for="keep_favourites">
-					<input type="checkbox" name="keep_favourites" id="keep_favourites" value="1"<?= $archiving['keep_favourites'] ? ' checked="checked"' : '' ?>
-						data-leave-validation="<?= $archiving['keep_favourites'] ? 1 : 0 ?>"/>
-					<?= _t('conf.archiving.keep_favourites') ?>
-				</label>
+			<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
+				<div class="group-name"><?= _t('conf.archiving.exception') ?></div>
+				<div class="group-controls">
+					<label class="checkbox" for="keep_favourites">
+						<input type="checkbox" name="keep_favourites" id="keep_favourites" value="1"<?= $archiving['keep_favourites'] ? ' checked="checked"' : '' ?>
+							data-leave-validation="<?= $archiving['keep_favourites'] ? 1 : 0 ?>"/>
+						<?= _t('conf.archiving.keep_favourites') ?>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
-			<div class="group-controls">
-				<label class="checkbox" for="keep_labels">
-					<input type="checkbox" name="keep_labels" id="keep_labels" value="1"<?= $archiving['keep_labels'] ? ' checked="checked"' : '' ?>
-						data-leave-validation="<?= $archiving['keep_labels'] ? 1 : 0 ?>"/>
-					<?= _t('conf.archiving.keep_labels') ?>
-				</label>
+			<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
+				<div class="group-controls">
+					<label class="checkbox" for="keep_labels">
+						<input type="checkbox" name="keep_labels" id="keep_labels" value="1"<?= $archiving['keep_labels'] ? ' checked="checked"' : '' ?>
+							data-leave-validation="<?= $archiving['keep_labels'] ? 1 : 0 ?>"/>
+						<?= _t('conf.archiving.keep_labels') ?>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
-			<div class="group-controls">
-				<label class="checkbox" for="keep_unreads">
-					<input type="checkbox" name="keep_unreads" id="keep_unreads" value="1"<?= $archiving['keep_unreads'] ? ' checked="checked"' : '' ?>
-						data-leave-validation="<?= $archiving['keep_unreads'] ?>"/>
-					<?= _t('conf.archiving.keep_unreads') ?>
-				</label>
+			<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
+				<div class="group-controls">
+					<label class="checkbox" for="keep_unreads">
+						<input type="checkbox" name="keep_unreads" id="keep_unreads" value="1"<?= $archiving['keep_unreads'] ? ' checked="checked"' : '' ?>
+							data-leave-validation="<?= $archiving['keep_unreads'] ?>"/>
+						<?= _t('conf.archiving.keep_unreads') ?>
+					</label>
+				</div>
 			</div>
-		</div>
-		<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
-			<div class="group-controls">
-				<label for="keep_min"><?= _t('sub.feed.keep_min') ?>
-					<input type="number" id="keep_min" name="keep_min" min="0" value="<?= $archiving['keep_min'] ?>"
-						data-leave-validation="<?= $archiving['keep_min'] ?>">
-				</label>
+			<div class="form-group archiving"<?= $archiving['default'] ? ' hidden="hidden"' : '' ?>>
+				<div class="group-controls">
+					<label for="keep_min"><?= _t('sub.feed.keep_min') ?>
+						<input type="number" id="keep_min" name="keep_min" min="0" value="<?= $archiving['keep_min'] ?>"
+							data-leave-validation="<?= $archiving['keep_min'] ?>">
+					</label>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
-				<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
-				<button type="submit" class="btn btn-attention confirm" formmethod="post" formaction="<?= _url('feed', 'truncate', 'id', $this->feed->id(), '#', 'slider') ?>"><?= _t('gen.action.truncate') ?></button>
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+					<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+					<button type="submit" class="btn btn-attention confirm" formmethod="post" formaction="<?= _url('feed', 'truncate', 'id', $this->feed->id(), '#', 'slider') ?>"><?= _t('gen.action.truncate') ?></button>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 
-		<legend><?= _t('sub.feed.kind') ?></legend>
-		<div class="form-group">
-			<label class="group-name" for="feed_kind"><?= _t('sub.feed.kind') ?></label>
-			<div class="group-controls">
-				<select name="feed_kind" id="feed_kind" class="select-show w100">
-					<option value="<?= FreshRSS_Feed::KIND_RSS ?>" <?= $this->feed->kind() === FreshRSS_Feed::KIND_RSS ? 'selected="selected"' : '' ?>><?= _t('sub.feed.kind.rss') ?></option>
-					<option value="<?= FreshRSS_Feed::KIND_HTML_XPATH ?>" <?= $this->feed->kind() === FreshRSS_Feed::KIND_HTML_XPATH ? 'selected="selected"' : '' ?> data-show="html_xpath"><?= _t('sub.feed.kind.html_xpath') ?></option>
-					<option value="<?= FreshRSS_Feed::KIND_XML_XPATH ?>" <?= $this->feed->kind() === FreshRSS_Feed::KIND_XML_XPATH ? 'selected="selected"' : '' ?> data-show="html_xpath"><?= _t('sub.feed.kind.xml_xpath') ?></option>
-					<option value="<?= FreshRSS_Feed::KIND_JSONFEED ?>" <?= $this->feed->kind() === FreshRSS_Feed::KIND_JSONFEED ? 'selected="selected"' : '' ?>><?= _t('sub.feed.kind.jsonfeed') ?></option>
-					<option value="<?= FreshRSS_Feed::KIND_JSON_DOTPATH ?>" <?= $this->feed->kind() === FreshRSS_Feed::KIND_JSON_DOTPATH ? 'selected="selected"' : '' ?> data-show="json_dotpath"><?= _t('sub.feed.kind.json_dotpath') ?></option>
-				</select>
+		<fieldset>
+			<legend><?= _t('sub.feed.kind') ?></legend>
+			<div class="form-group">
+				<label class="group-name" for="feed_kind"><?= _t('sub.feed.kind') ?></label>
+				<div class="group-controls">
+					<select name="feed_kind" id="feed_kind" class="select-show w100">
+						<option value="<?= FreshRSS_Feed::KIND_RSS ?>" <?= $this->feed->kind() === FreshRSS_Feed::KIND_RSS ? 'selected="selected"' : '' ?>><?= _t('sub.feed.kind.rss') ?></option>
+						<option value="<?= FreshRSS_Feed::KIND_HTML_XPATH ?>" <?= $this->feed->kind() === FreshRSS_Feed::KIND_HTML_XPATH ? 'selected="selected"' : '' ?> data-show="html_xpath"><?= _t('sub.feed.kind.html_xpath') ?></option>
+						<option value="<?= FreshRSS_Feed::KIND_XML_XPATH ?>" <?= $this->feed->kind() === FreshRSS_Feed::KIND_XML_XPATH ? 'selected="selected"' : '' ?> data-show="html_xpath"><?= _t('sub.feed.kind.xml_xpath') ?></option>
+						<option value="<?= FreshRSS_Feed::KIND_JSONFEED ?>" <?= $this->feed->kind() === FreshRSS_Feed::KIND_JSONFEED ? 'selected="selected"' : '' ?>><?= _t('sub.feed.kind.jsonfeed') ?></option>
+						<option value="<?= FreshRSS_Feed::KIND_JSON_DOTPATH ?>" <?= $this->feed->kind() === FreshRSS_Feed::KIND_JSON_DOTPATH ? 'selected="selected"' : '' ?> data-show="json_dotpath"><?= _t('sub.feed.kind.json_dotpath') ?></option>
+					</select>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 
 		<fieldset id="html_xpath">
 			<?php
@@ -586,175 +595,178 @@
 					<textarea class="valid-json w100" name="jsonItemUid" id="jsonItemUid" rows="2" cols="64" spellcheck="false" data-leave-validation="<?= $jsonSettings['itemUid'] ?? '' ?>"><?= $jsonSettings['itemUid'] ?? '' ?></textarea>
 				</div>
 			</div>
+
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+					<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+				</div>
+			</div>
 		</fieldset>
 
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button class="btn btn-important"><?= _t('gen.action.submit') ?></button>
-				<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+		<fieldset>
+			<legend><?= _t('sub.feed.advanced') ?></legend>
+			<div class="form-group">
+				<label class="group-name" for="path_entries"><?= _t('sub.feed.css_path') ?></label>
+				<div class="group-controls">
+					<div class="stick w100">
+						<input type="text" name="path_entries" id="path_entries" class="w100" value="<?= $this->feed->pathEntries() ?>"
+							data-leave-validation="<?= $this->feed->pathEntries() ?>" placeholder="<?= _t('gen.short.blank_to_disable') ?>" />
+						<a id="popup-preview-selector" class="btn" href="<?=
+							_url('feed', 'contentSelectorPreview', 'id', $this->feed->id(), 'selector', 'selector-token', 'selector_filter', 'selector-filter-token', '#', 'slider') ?>"><?= _i('look') ?></a>
+					</div>
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.css_help') ?></p>
+				</div>
 			</div>
-		</div>
 
-		<legend><?= _t('sub.feed.advanced') ?></legend>
-		<div class="form-group">
-			<label class="group-name" for="path_entries"><?= _t('sub.feed.css_path') ?></label>
-			<div class="group-controls">
-				<div class="stick w100">
-					<input type="text" name="path_entries" id="path_entries" class="w100" value="<?= $this->feed->pathEntries() ?>"
-						data-leave-validation="<?= $this->feed->pathEntries() ?>" placeholder="<?= _t('gen.short.blank_to_disable') ?>" />
-					<a id="popup-preview-selector" class="btn" href="<?=
-						_url('feed', 'contentSelectorPreview', 'id', $this->feed->id(), 'selector', 'selector-token', 'selector_filter', 'selector-filter-token', '#', 'slider') ?>"><?= _i('look') ?></a>
+			<div class="form-group">
+				<?php
+					$path_entries_filter = Minz_Helper::htmlspecialchars_utf8($this->feed->attributeString('path_entries_filter') ?? '');
+				?>
+				<label class="group-name" for="path_entries_filter"><?= _t('sub.feed.css_path_filter') ?></label>
+				<div class="group-controls">
+					<div class="w100">
+						<input type="text" name="path_entries_filter" id="path_entries_filter" class="w100" value="<?= $path_entries_filter ?>"
+							data-leave-validation="<?= $path_entries_filter ?>" placeholder="<?= _t('gen.short.blank_to_disable') ?>" />
+					</div>
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.css_path_filter.help') ?></p>
 				</div>
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.css_help') ?></p>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<?php
-				$path_entries_filter = Minz_Helper::htmlspecialchars_utf8($this->feed->attributeString('path_entries_filter') ?? '');
-			?>
-			<label class="group-name" for="path_entries_filter"><?= _t('sub.feed.css_path_filter') ?></label>
-			<div class="group-controls">
-				<div class="w100">
-					<input type="text" name="path_entries_filter" id="path_entries_filter" class="w100" value="<?= $path_entries_filter ?>"
-						data-leave-validation="<?= $path_entries_filter ?>" placeholder="<?= _t('gen.short.blank_to_disable') ?>" />
+			<div class="form-group">
+				<label class="group-name" for="curl_params_cookie"><?= _t('sub.feed.css_cookie') ?></label>
+				<div class="group-controls">
+					<input type="text" name="curl_params_cookie" id="curl_params_cookie" class="w100" value="<?=
+						$this->feed->attributeArray('curl_params') !== null && !empty($this->feed->attributeArray('curl_params')[CURLOPT_COOKIE]) ?
+							$this->feed->attributeArray('curl_params')[CURLOPT_COOKIE] : ''
+					?>" placeholder="<?= _t('gen.short.blank_to_disable') ?>" />
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.css_cookie_help') ?></p>
+					<label for="curl_params_cookiefile">
+						<input type="checkbox" name="curl_params_cookiefile" id="curl_params_cookiefile" value="1"<?=
+							$this->feed->attributeArray('curl_params') !== null && isset($this->feed->attributeArray('curl_params')[CURLOPT_COOKIEFILE]) ?
+								' checked="checked"' : ''
+						?> />
+						<?= _t('sub.feed.accept_cookies') ?>
+					</label>
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.accept_cookies_help') ?></p>
 				</div>
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.css_path_filter.help') ?></p>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<label class="group-name" for="curl_params_cookie"><?= _t('sub.feed.css_cookie') ?></label>
-			<div class="group-controls">
-				<input type="text" name="curl_params_cookie" id="curl_params_cookie" class="w100" value="<?=
-					$this->feed->attributeArray('curl_params') !== null && !empty($this->feed->attributeArray('curl_params')[CURLOPT_COOKIE]) ?
-						$this->feed->attributeArray('curl_params')[CURLOPT_COOKIE] : ''
-				?>" placeholder="<?= _t('gen.short.blank_to_disable') ?>" />
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.css_cookie_help') ?></p>
-				<label for="curl_params_cookiefile">
-					<input type="checkbox" name="curl_params_cookiefile" id="curl_params_cookiefile" value="1"<?=
-						$this->feed->attributeArray('curl_params') !== null && isset($this->feed->attributeArray('curl_params')[CURLOPT_COOKIEFILE]) ?
-							' checked="checked"' : ''
-					?> />
-					<?= _t('sub.feed.accept_cookies') ?>
-				</label>
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.accept_cookies_help') ?></p>
+			<div class="form-group">
+				<label class="group-name" for="curl_params_redirects"><?= _t('sub.feed.max_http_redir') ?></label>
+				<div class="group-controls">
+					<input type="number" name="curl_params_redirects" id="curl_params_redirects" class="w50" min="-1" value="<?=
+						$this->feed->attributeArray('curl_params') !== null && !empty($this->feed->attributeArray('curl_params')[CURLOPT_MAXREDIRS]) ?
+							$this->feed->attributeArray('curl_params')[CURLOPT_MAXREDIRS] : ''
+					?>" placeholder="<?= _t('gen.short.blank_to_disable') ?>" />
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.max_http_redir_help') ?></p>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<label class="group-name" for="curl_params_redirects"><?= _t('sub.feed.max_http_redir') ?></label>
-			<div class="group-controls">
-				<input type="number" name="curl_params_redirects" id="curl_params_redirects" class="w50" min="-1" value="<?=
-					$this->feed->attributeArray('curl_params') !== null && !empty($this->feed->attributeArray('curl_params')[CURLOPT_MAXREDIRS]) ?
-						$this->feed->attributeArray('curl_params')[CURLOPT_MAXREDIRS] : ''
-				?>" placeholder="<?= _t('gen.short.blank_to_disable') ?>" />
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.max_http_redir_help') ?></p>
+			<div class="form-group">
+				<label class="group-name" for="content_action"><?= _t('sub.feed.content_action') ?></label>
+				<div class="group-controls">
+					<select name="content_action" id="content_action" class="w50">
+						<option value="replace"<?= 'replace' === $this->feed->attributeString('content_action') ? ' selected="selected"' : '' ?>><?= _t('sub.feed.content_action.replace') ?></option>
+						<option value="prepend"<?= 'prepend' === $this->feed->attributeString('content_action') ? ' selected="selected"' : '' ?>><?= _t('sub.feed.content_action.prepend') ?></option>
+						<option value="append"<?= 'append' === $this->feed->attributeString('content_action') ? ' selected="selected"' : '' ?>><?= _t('sub.feed.content_action.append') ?></option>
+					</select>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<label class="group-name" for="content_action"><?= _t('sub.feed.content_action') ?></label>
-			<div class="group-controls">
-				<select name="content_action" id="content_action" class="w50">
-					<option value="replace"<?= 'replace' === $this->feed->attributeString('content_action') ? ' selected="selected"' : '' ?>><?= _t('sub.feed.content_action.replace') ?></option>
-					<option value="prepend"<?= 'prepend' === $this->feed->attributeString('content_action') ? ' selected="selected"' : '' ?>><?= _t('sub.feed.content_action.prepend') ?></option>
-					<option value="append"<?= 'append' === $this->feed->attributeString('content_action') ? ' selected="selected"' : '' ?>><?= _t('sub.feed.content_action.append') ?></option>
-				</select>
+			<div class="form-group">
+				<label class="group-name" for="curl_params_useragent"><?= _t('sub.feed.useragent') ?></label>
+				<div class="group-controls">
+					<input type="text" name="curl_params_useragent" id="curl_params_useragent" class="w100" value="<?=
+						$this->feed->attributeArray('curl_params') !== null && !empty($this->feed->attributeArray('curl_params')[CURLOPT_USERAGENT]) ?
+							$this->feed->attributeArray('curl_params')[CURLOPT_USERAGENT] : ''
+					?>" placeholder="<?= _t('gen.short.blank_to_disable') ?>" />
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.useragent_help') ?></p>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<label class="group-name" for="curl_params_useragent"><?= _t('sub.feed.useragent') ?></label>
-			<div class="group-controls">
-				<input type="text" name="curl_params_useragent" id="curl_params_useragent" class="w100" value="<?=
-					$this->feed->attributeArray('curl_params') !== null && !empty($this->feed->attributeArray('curl_params')[CURLOPT_USERAGENT]) ?
-						$this->feed->attributeArray('curl_params')[CURLOPT_USERAGENT] : ''
-				?>" placeholder="<?= _t('gen.short.blank_to_disable') ?>" />
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.useragent_help') ?></p>
+			<div class="form-group">
+				<label class="group-name" for="proxy_type"><?= _t('sub.feed.proxy') ?></label>
+				<div class="group-controls">
+					<select name="proxy_type" id="proxy_type"><?php
+						$type = '';
+						if ($this->feed->attributeArray('curl_params') !== null && isset($this->feed->attributeArray('curl_params')[CURLOPT_PROXYTYPE])) {
+							$type = $this->feed->attributeArray('curl_params')[CURLOPT_PROXYTYPE];
+						}
+						foreach(['' => '', 3 => 'NONE', 0 => 'HTTP', 2 => 'HTTPS', 4 => 'SOCKS4', 6 => 'SOCKS4A', 5 => 'SOCKS5', 7 => 'SOCKS5H'] as $k => $v) {
+							echo '<option value="' . $k . ($type === $k ? '" selected="selected' : '' ) . '">' . $v . '</option>';
+						}
+					?>
+					</select>
+					<input type="text" name="curl_params" id="curl_params" value="<?=
+						$this->feed->attributeArray('curl_params') !== null && !empty($this->feed->attributeArray('curl_params')[CURLOPT_PROXY]) ?
+							$this->feed->attributeArray('curl_params')[CURLOPT_PROXY] : ''
+					?>" placeholder="<?= _t('gen.short.blank_to_disable') ?>" />
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.proxy_help') ?></p>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<label class="group-name" for="proxy_type"><?= _t('sub.feed.proxy') ?></label>
-			<div class="group-controls">
-				<select name="proxy_type" id="proxy_type"><?php
-					$type = '';
-					if ($this->feed->attributeArray('curl_params') !== null && isset($this->feed->attributeArray('curl_params')[CURLOPT_PROXYTYPE])) {
-						$type = $this->feed->attributeArray('curl_params')[CURLOPT_PROXYTYPE];
+			<div class="form-group">
+				<label class="group-name" for="curl_method"><?= _t('sub.feed.method') ?></label>
+				<div class="group-controls">
+					<select class="number" name="curl_method" id="curl_method"><?php
+					$curl_method = 'GET';
+					if ($this->feed->attributeArray('curl_params') !== null && !empty($this->feed->attributeArray('curl_params')[CURLOPT_POST])) {
+						$curl_method = 'POST';
 					}
-					foreach(['' => '', 3 => 'NONE', 0 => 'HTTP', 2 => 'HTTPS', 4 => 'SOCKS4', 6 => 'SOCKS4A', 5 => 'SOCKS5', 7 => 'SOCKS5H'] as $k => $v) {
-						echo '<option value="' . $k . ($type === $k ? '" selected="selected' : '' ) . '">' . $v . '</option>';
+					foreach (['GET' => 'GET', 'POST' => 'POST'] as $k => $v) {
+						echo '<option value="' . $k . ($curl_method === $k ? '" selected="selected' : '') . '">' . $v . '</option>';
 					}
-				?>
-				</select>
-				<input type="text" name="curl_params" id="curl_params" value="<?=
-					$this->feed->attributeArray('curl_params') !== null && !empty($this->feed->attributeArray('curl_params')[CURLOPT_PROXY]) ?
-						$this->feed->attributeArray('curl_params')[CURLOPT_PROXY] : ''
-				?>" placeholder="<?= _t('gen.short.blank_to_disable') ?>" />
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.proxy_help') ?></p>
-			</div>
-		</div>
-
-		<div class="form-group">
-			<label class="group-name" for="curl_method"><?= _t('sub.feed.method') ?></label>
-			<div class="group-controls">
-				<select class="number" name="curl_method" id="curl_method"><?php
-				$curl_method = 'GET';
-				if ($this->feed->attributeArray('curl_params') !== null && !empty($this->feed->attributeArray('curl_params')[CURLOPT_POST])) {
-					$curl_method = 'POST';
-				}
-				foreach (['GET' => 'GET', 'POST' => 'POST'] as $k => $v) {
-					echo '<option value="' . $k . ($curl_method === $k ? '" selected="selected' : '') . '">' . $v . '</option>';
-				}
-				?>
-				</select>
-				<div class="stick">
-					<input type="text" name="curl_fields" id="curl_fields" value="<?=
-						$this->feed->attributeArray('curl_params') !== null && !empty($this->feed->attributeArray('curl_params')[CURLOPT_POSTFIELDS]) ?
-							htmlentities($this->feed->attributeArray('curl_params')[CURLOPT_POSTFIELDS], ENT_COMPAT) : ''
-					?>" placeholder="<?= _t('sub.feed.method_postparams') ?>" />
+					?>
+					</select>
+					<div class="stick">
+						<input type="text" name="curl_fields" id="curl_fields" value="<?=
+							$this->feed->attributeArray('curl_params') !== null && !empty($this->feed->attributeArray('curl_params')[CURLOPT_POSTFIELDS]) ?
+								htmlentities($this->feed->attributeArray('curl_params')[CURLOPT_POSTFIELDS], ENT_COMPAT) : ''
+						?>" placeholder="<?= _t('sub.feed.method_postparams') ?>" />
+					</div>
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.method_help') ?></p>
 				</div>
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.method_help') ?></p>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<label class="group-name" for="timeout"><?= _t('sub.feed.timeout') ?></label>
-			<div class="group-controls">
-				<input type="number" name="timeout" id="timeout" class="w50" min="3" max="900" value="<?= $this->feed->attributeInt('timeout') ?>" placeholder="<?= _t('gen.short.by_default') ?>" />
+			<div class="form-group">
+				<label class="group-name" for="timeout"><?= _t('sub.feed.timeout') ?></label>
+				<div class="group-controls">
+					<input type="number" name="timeout" id="timeout" class="w50" min="3" max="900" value="<?= $this->feed->attributeInt('timeout') ?>" placeholder="<?= _t('gen.short.by_default') ?>" />
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<label class="group-name" for="ssl_verify"><?= _t('sub.feed.ssl_verify') ?></label>
-			<div class="group-controls">
-				<select name="ssl_verify" id="ssl_verify" class="w50">
-					<option value=""<?= $this->feed->attributeBoolean('ssl_verify') === null ? ' selected="selected"' : '' ?>><?= _t('gen.short.by_default') ?></option>
-					<option value="0"<?= $this->feed->attributeBoolean('ssl_verify') === false ? ' selected="selected"' : '' ?>><?= _t('gen.short.no') ?></option>
-					<option value="1"<?= $this->feed->attributeBoolean('ssl_verify') === true ? ' selected="selected"' : '' ?>><?= _t('gen.short.yes') ?></option>
-				</select>
+			<div class="form-group">
+				<label class="group-name" for="ssl_verify"><?= _t('sub.feed.ssl_verify') ?></label>
+				<div class="group-controls">
+					<select name="ssl_verify" id="ssl_verify" class="w50">
+						<option value=""<?= $this->feed->attributeBoolean('ssl_verify') === null ? ' selected="selected"' : '' ?>><?= _t('gen.short.by_default') ?></option>
+						<option value="0"<?= $this->feed->attributeBoolean('ssl_verify') === false ? ' selected="selected"' : '' ?>><?= _t('gen.short.no') ?></option>
+						<option value="1"<?= $this->feed->attributeBoolean('ssl_verify') === true ? ' selected="selected"' : '' ?>><?= _t('gen.short.yes') ?></option>
+					</select>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group">
-			<div class="group-controls">
-				<label class="checkbox" for="clear_cache">
-					<input type="checkbox" name="clear_cache" id="clear_cache" value="1"<?= $this->feed->attributeBoolean('clear_cache') ? ' checked="checked"' : '' ?> />
-					<?= _t('sub.feed.clear_cache') ?>
-				</label>
+			<div class="form-group">
+				<div class="group-controls">
+					<label class="checkbox" for="clear_cache">
+						<input type="checkbox" name="clear_cache" id="clear_cache" value="1"<?= $this->feed->attributeBoolean('clear_cache') ? ' checked="checked"' : '' ?> />
+						<?= _t('sub.feed.clear_cache') ?>
+					</label>
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
-				<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+					<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 	</form>
 
-	<legend><?= _t('sub.feed.maintenance.title') ?></legend>
+	
+	<h2><?= _t('sub.feed.maintenance.title') ?></h2>
 	<div class="form-group">
 		<div class="group-controls">
 			<a class="btn btn-important" href="<?= _url('feed', 'clearCache', 'id', $this->feed->id(), '#', 'slider') ?>">

+ 42 - 44
app/views/index/logs.phtml

@@ -10,56 +10,54 @@
 
 	<h1><?= _t('index.log') ?></h1>
 
-
 	<?php
 		/** @var array<FreshRSS_Log> $items */
 		$items = $this->logsPaginator->items();
 	?>
 
 	<?php if (!empty($items)) { ?>
-	<?php $this->logsPaginator->render('logs_pagination.phtml', 'page'); ?>
-	<div id="loglist-wrapper" class="table-wrapper scrollbar-thin">
-		<table id="loglist">
-			<thead>
-				<th><?= _t('conf.logs.loglist.level') ?></th>
-				<th><?= _t('conf.logs.loglist.timestamp') ?></th>
-				<th><?= _t('conf.logs.loglist.message') ?></th>
-			</thead>
-			<tbody>
-		<?php foreach ($items as $log) { ?>
-		<tr class="log-item log-<?= $log->level() ?>">
-			<td class="log-level">
-				<?= _i($log->level()) ?>
-			</td>
-			<td class="log-date">
-				<time datetime="<?= date('Y-m-d H:i:s', @strtotime($log->date()) ?: 0) ?>">
-					<?= date('Y-m-d H:i:s', @strtotime($log->date()) ?: 0) ?>
-				</time>
-			</td>
-			<td class="log-message">
-				<?= htmlspecialchars($log->info(), ENT_NOQUOTES, 'UTF-8') ?>
-			</td>
-			</tr>
-		<?php } ?>
-		</tbody>
-		</table>
-	</div>
-	<?php $this->logsPaginator->render('logs_pagination.phtml', 'page'); ?>
-
-
+		<form method="post" action="<?= _url('index', 'logs') ?>">
+			<?php $this->logsPaginator->render('logs_pagination.phtml', 'page'); ?>
+			
+			<div id="loglist-wrapper" class="table-wrapper scrollbar-thin">
+				<table id="loglist">
+					<thead>
+						<th><?= _t('conf.logs.loglist.level') ?></th>
+						<th><?= _t('conf.logs.loglist.timestamp') ?></th>
+						<th><?= _t('conf.logs.loglist.message') ?></th>
+					</thead>
+					<tbody>
+				<?php foreach ($items as $log) { ?>
+				<tr class="log-item log-<?= $log->level() ?>">
+					<td class="log-level">
+						<?= _i($log->level()) ?>
+					</td>
+					<td class="log-date">
+						<time datetime="<?= date('Y-m-d H:i:s', @strtotime($log->date()) ?: 0) ?>">
+							<?= date('Y-m-d H:i:s', @strtotime($log->date()) ?: 0) ?>
+						</time>
+					</td>
+					<td class="log-message">
+						<?= htmlspecialchars($log->info(), ENT_NOQUOTES, 'UTF-8') ?>
+					</td>
+					</tr>
+				<?php } ?>
+				</tbody>
+				</table>
+			</div>
+			<?php $this->logsPaginator->render('logs_pagination.phtml', 'page'); ?>
+			
+			<div class="form-group form-actions">
+			<input type="hidden" name="_csrf" value="<?= FreshRSS_Auth::csrfToken() ?>" />
+				<input type="hidden" name="clearLogs" />
+				<div class="group-controls">
+				<button type="submit" class="btn btn-attention"><?= _t('index.log.clear') ?></button>
+				</div>
+			</div>
+		</form>
 
-	<form method="post" action="<?= _url('index', 'logs') ?>">
-	<div class="form-group form-actions">
-	<input type="hidden" name="_csrf" value="<?= FreshRSS_Auth::csrfToken() ?>" />
-		<input type="hidden" name="clearLogs" />
-		<div class="group-controls">
-		<button type="submit" class="btn btn-attention"><?= _t('index.log.clear') ?></button>
-		</div>
-	</div>
-	</form>
-
-	<?php } else { ?>
-	<p class="alert alert-warn"><?= _t('index.log.empty') ?></p>
+	<?php
+	} else { ?>
+		<p class="alert alert-warn"><?= _t('index.log.empty') ?></p>
 	<?php } ?>
-
 </main>

+ 26 - 22
app/views/tag/update.phtml

@@ -21,33 +21,37 @@
 	<form method="post" action="<?= _url('tag', 'update', 'id', $this->tag->id(), '#', 'slider') ?>" autocomplete="off">
 		<input type="hidden" name="_csrf" value="<?= FreshRSS_Auth::csrfToken() ?>" />
 
-		<legend><?= _t('sub.category.information') ?></legend>
-		<div class="form-group">
-			<label class="group-name" for="name"><?= _t('sub.tag.name') ?></label>
-			<div class="group-controls">
-				<input type="text" name="name" id="name" value="<?= $this->tag->name() ?>" />
+		<fieldset>
+			<legend><?= _t('sub.category.information') ?></legend>
+			<div class="form-group">
+				<label class="group-name" for="name"><?= _t('sub.tag.name') ?></label>
+				<div class="group-controls">
+					<input type="text" name="name" id="name" value="<?= $this->tag->name() ?>" />
+				</div>
 			</div>
-		</div>
 
-		<div class="form-group form-actions">
-			<div class="group-controls">
-				<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
-				<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+			<div class="form-group form-actions">
+				<div class="group-controls">
+					<button type="submit" class="btn btn-important"><?= _t('gen.action.submit') ?></button>
+					<button type="reset" class="btn"><?= _t('gen.action.cancel') ?></button>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 
-		<legend><?= _t('sub.feed.filteractions') ?></legend>
-		<div class="form-group">
-			<label class="group-name" for="filteractions_label"><?= _t('sub.tag.auto_label') ?></label>
-			<div class="group-controls">
-				<textarea name="filteractions_label" id="filteractions_label" class="w100"><?php
-					foreach ($this->tag->filtersAction('label') as $filterRead) {
-						echo $filterRead->getRawInput(), PHP_EOL;
-					}
-				?></textarea>
-				<p class="help"><?= _i('help') ?> <?= _t('sub.feed.filteractions.help') ?></p>
+		<fieldset>
+			<legend><?= _t('sub.feed.filteractions') ?></legend>
+			<div class="form-group">
+				<label class="group-name" for="filteractions_label"><?= _t('sub.tag.auto_label') ?></label>
+				<div class="group-controls">
+					<textarea name="filteractions_label" id="filteractions_label" class="w100"><?php
+						foreach ($this->tag->filtersAction('label') as $filterRead) {
+							echo $filterRead->getRawInput(), PHP_EOL;
+						}
+					?></textarea>
+					<p class="help"><?= _i('help') ?> <?= _t('sub.feed.filteractions.help') ?></p>
+				</div>
 			</div>
-		</div>
+		</fieldset>
 
 		<div class="form-group form-actions">
 			<div class="group-controls">

+ 1 - 1
app/views/user/profile.phtml

@@ -75,10 +75,10 @@
 		</div>
 	</form>
 
+	<h2><?= _t('conf.profile.api') ?></h2>
 	<?php if (FreshRSS_Context::systemConf()->api_enabled) { ?>
 		<form method="post" action="<?= _url('api', 'updatePassword') ?>">
 			<input type="hidden" name="_csrf" value="<?= FreshRSS_Auth::csrfToken() ?>" />
-			<legend><?= _t('conf.profile.api') ?></legend>
 
 			<div class="form-group">
 				<label class="group-name" for="apiPasswordPlain"><?= _t('conf.profile.password_api') ?></label>

+ 2 - 2
p/scripts/integration.js

@@ -15,7 +15,7 @@ const init_integration = function () {
 		const shareTypes = event.target.closest('.group-controls').querySelector('select');
 		const shareType = shareTypes.options[shareTypes.selectedIndex];
 		const template = document.getElementById(shareType.getAttribute('data-form') + '-share');
-		let newShare = template.content.cloneNode(true).querySelector('formgroup').outerHTML;
+		let newShare = template.content.cloneNode(true).querySelector('fieldset').outerHTML;
 
 		newShare = newShare.replace(/##label##/g, shareType.text);
 		newShare = newShare.replace(/##type##/g, shareType.value);
@@ -23,7 +23,7 @@ const init_integration = function () {
 		newShare = newShare.replace(/##key##/g, shares);
 		newShare = newShare.replace(/##method##/g, shareType.getAttribute('data-method'));
 		newShare = newShare.replace(/##field##/g, shareType.getAttribute('data-field'));
-		event.target.closest('formgroup').insertAdjacentHTML('beforebegin', newShare);
+		event.target.closest('fieldset').insertAdjacentHTML('beforebegin', newShare);
 		shares++;
 	});
 

+ 2 - 2
p/themes/Alternative-Dark/adark.css

@@ -129,8 +129,8 @@ th {
 	background: var(--background-color-light);
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Alternative-Dark/adark.rtl.css

@@ -129,8 +129,8 @@ th {
 	background: var(--background-color-light);
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Ansum/_tables.scss

@@ -13,8 +13,8 @@ th {
 	background: variables.$grey-lighter;
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Ansum/ansum.css

@@ -195,8 +195,8 @@ th {
 	background: #fcfaf8;
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Ansum/ansum.rtl.css

@@ -195,8 +195,8 @@ th {
 	background: #fcfaf8;
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Flat/flat.css

@@ -83,8 +83,8 @@ th {
 	background: #f6f6f6;
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Flat/flat.rtl.css

@@ -83,8 +83,8 @@ th {
 	background: #f6f6f6;
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Mapco/_tables.scss

@@ -13,8 +13,8 @@ th {
 	background: variables.$grey-lighter;
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Mapco/mapco.css

@@ -194,8 +194,8 @@ th {
 	background: #f9fafb;
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Mapco/mapco.rtl.css

@@ -194,8 +194,8 @@ th {
 	background: #f9fafb;
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Nord/nord.css

@@ -171,8 +171,8 @@ button.as-link[disabled] {
 }
 
 /*=== Tables */
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 }
 

+ 2 - 2
p/themes/Nord/nord.rtl.css

@@ -171,8 +171,8 @@ button.as-link[disabled] {
 }
 
 /*=== Tables */
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 }
 

+ 2 - 2
p/themes/Origine/origine.css

@@ -165,8 +165,8 @@ th {
 	background-color: var(--background-color-light-shadowed);
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Origine/origine.rtl.css

@@ -165,8 +165,8 @@ th {
 	background-color: var(--background-color-light-shadowed);
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Pafat/pafat.css

@@ -153,8 +153,8 @@ th {
 	background-color: var(--background-color-grey);
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Pafat/pafat.rtl.css

@@ -153,8 +153,8 @@ th {
 	background-color: var(--background-color-grey);
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Swage/swage.css

@@ -157,8 +157,8 @@ th {
 	background-color: var(--color-background-light);
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/Swage/swage.rtl.css

@@ -157,8 +157,8 @@ th {
 	background-color: var(--color-background-light);
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/base-theme/base.css

@@ -63,8 +63,8 @@ th, td {
 th {
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }

+ 2 - 2
p/themes/base-theme/base.rtl.css

@@ -63,8 +63,8 @@ th, td {
 th {
 }
 
-form td,
-form th {
+.config-articleicons td,
+.config-articleicons th {
 	font-weight: normal;
 	text-align: center;
 }