Setting for Extract <title> as title option on individual watches (#229)

* Extract <title> as title option on individual items
pull/233/head
dgtlmoon 3 years ago committed by GitHub
parent 6901fc493d
commit 25476bfcb2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -2,3 +2,5 @@ recursive-include changedetectionio/templates *
recursive-include changedetectionio/static * recursive-include changedetectionio/static *
include changedetection.py include changedetection.py
global-exclude *.pyc global-exclude *.pyc
global-exclude *node_modules*
global-exclude venv

@ -411,7 +411,9 @@ def changedetection_app(config=None, datastore_o=None):
'fetch_backend': form.fetch_backend.data, 'fetch_backend': form.fetch_backend.data,
'trigger_text': form.trigger_text.data, 'trigger_text': form.trigger_text.data,
'notification_title': form.notification_title.data, 'notification_title': form.notification_title.data,
'notification_body': form.notification_body.data 'notification_body': form.notification_body.data,
'extract_title_as_title': form.extract_title_as_title.data
} }
# Notification URLs # Notification URLs

@ -170,7 +170,8 @@ class perform_site_check():
update_obj["previous_md5"] = fetched_md5 update_obj["previous_md5"] = fetched_md5
# Extract title as title # Extract title as title
if is_html and self.datastore.data['settings']['application']['extract_title_as_title']: if is_html:
if self.datastore.data['settings']['application']['extract_title_as_title'] or watch['extract_title_as_title']:
if not watch['title'] or not len(watch['title']): if not watch['title'] or not len(watch['title']):
update_obj['title'] = html_tools.extract_element(find='title', html_content=fetcher.content) update_obj['title'] = html_tools.extract_element(find='title', html_content=fetcher.content)

@ -203,6 +203,7 @@ class commonSettingsForm(Form):
notification_body = TextAreaField('Notification Body', default='{watch_url} had a change.', validators=[validators.Optional(), ValidateTokensList()]) notification_body = TextAreaField('Notification Body', default='{watch_url} had a change.', validators=[validators.Optional(), ValidateTokensList()])
trigger_check = BooleanField('Send test notification on save') trigger_check = BooleanField('Send test notification on save')
fetch_backend = RadioField(u'Fetch Method', choices=content_fetcher.available_fetchers(), validators=[ValidateContentFetcherIsReady()]) fetch_backend = RadioField(u'Fetch Method', choices=content_fetcher.available_fetchers(), validators=[ValidateContentFetcherIsReady()])
extract_title_as_title = BooleanField('Extract <title> from document and use as watch title', default=False)
class watchForm(commonSettingsForm): class watchForm(commonSettingsForm):
@ -225,4 +226,3 @@ class globalSettingsForm(commonSettingsForm):
minutes_between_check = html5.IntegerField('Maximum time in minutes until recheck', minutes_between_check = html5.IntegerField('Maximum time in minutes until recheck',
[validators.NumberRange(min=1)]) [validators.NumberRange(min=1)])
extract_title_as_title = BooleanField('Extract <title> from document and use as watch title')

@ -73,6 +73,7 @@ class ChangeDetectionStore:
'css_filter': "", 'css_filter': "",
'trigger_text': [], # List of text or regex to wait for until a change is detected 'trigger_text': [], # List of text or regex to wait for until a change is detected
'fetch_backend': None, 'fetch_backend': None,
'extract_title_as_title': False
} }
if path.isfile('changedetectionio/source.txt'): if path.isfile('changedetectionio/source.txt'):

@ -56,6 +56,9 @@ User-Agent: wonderbra 1.0") }}
<p>The <strong>Chrome/Javascript</strong> method requires a network connection to a running WebDriver+Chrome server. </p> <p>The <strong>Chrome/Javascript</strong> method requires a network connection to a running WebDriver+Chrome server. </p>
</span> </span>
</div> </div>
<div class="pure-control-group">
{{ render_field(form.extract_title_as_title) }}
</div>
</fieldset> </fieldset>
</div> </div>

Loading…
Cancel
Save