parsed_readmore 1.0.0 copy "parsed_readmore: ^1.0.0" to clipboard
parsed_readmore: ^1.0.0 copied to clipboard

A Flutter text widget which is expandable and can automatically parse urls present in the text it into clickable links.

example/lib/main.dart

import 'package:flutter/material.dart';
import 'package:parsed_readmore/parsed_readmore.dart';

const String inputData =
    "When using custom values we have specified 'the' to https://google.com is a very useful website. (rti..notNow should not be parsed) But Instagram.com is more fun to use. We should not forget the contribution of wikipedia.com played in the growth of web. If you like this package do consider liking it so that it could be useful to more developers like you. Thank you for your time";

void main() {
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({Key? key}) : super(key: key);

  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: const ParsedReadMoreDemo(),
    );
  }
}

class ParsedReadMoreDemo extends StatefulWidget {
  const ParsedReadMoreDemo({Key? key}) : super(key: key);

  @override
  State<ParsedReadMoreDemo> createState() => _ParsedReadMoreDemoState();
}

class _ParsedReadMoreDemoState extends State<ParsedReadMoreDemo> {
  @override
  Widget build(BuildContext context) {
    return DefaultTabController(
      length: 3,
      child: Scaffold(
          appBar: AppBar(
            title: const Text('Parsed Read More'),
            bottom: const TabBar(tabs: [
              Tab(
                text: 'Without',
              ),
              Tab(
                text: 'Default',
              ),
              Tab(
                text: 'Custom',
              ),
            ]),
          ),
          body: const TabBarView(children: [
            WithoutPackage(),
            DefaultValuesPackage(),
            CustomValuesPackage(),
          ])),
    );
  }
}

class WithoutPackage extends StatelessWidget {
  const WithoutPackage({super.key});

  @override
  Widget build(BuildContext context) {
    const TextStyle labelTextStyle = TextStyle(
        fontSize: 24, color: Colors.grey, fontWeight: FontWeight.bold);

    return const Padding(
      padding: EdgeInsets.all(8.0),
      child: SingleChildScrollView(
        child: Column(
          crossAxisAlignment: CrossAxisAlignment.start,
          children: [
            Text("Without using the package", style: labelTextStyle),
            SizedBox(height: 12),
            Text(inputData),
          ],
        ),
      ),
    );
  }
}

class DefaultValuesPackage extends StatelessWidget {
  const DefaultValuesPackage({super.key});

  @override
  Widget build(BuildContext context) {
    const TextStyle labelTextStyle = TextStyle(
        fontSize: 24, color: Colors.grey, fontWeight: FontWeight.bold);

    return const Padding(
      padding: EdgeInsets.all(8.0),
      child: SingleChildScrollView(
        child: Column(
          crossAxisAlignment: CrossAxisAlignment.start,
          children: [
            Text("Using package with default values", style: labelTextStyle),
            SizedBox(height: 12),

            //Package widget using only default values.
            ParsedReadMore(TextHighlightParser(data: inputData)),
          ],
        ),
      ),
    );
  }
}

class CustomValuesPackage extends StatelessWidget {
  const CustomValuesPackage({super.key});

  @override
  Widget build(BuildContext context) {
    const TextStyle textStyle = TextStyle(fontSize: 20);
    const TextStyle labelTextStyle = TextStyle(
        fontSize: 24, color: Colors.grey, fontWeight: FontWeight.bold);

    return Padding(
      padding: const EdgeInsets.all(8.0),
      child: SingleChildScrollView(
        child: Column(
          crossAxisAlignment: CrossAxisAlignment.start,
          children: [
            const Text(
              'Using package with custom values',
              style: labelTextStyle,
            ),
            const SizedBox(height: 12),
            ParsedReadMore(
              TextHighlightParser(
                urlRegex: r'https:\/\/[^\s]+',
                data: inputData,
                initialState: ReadMoreState.collapsed,
                urlTextStyle: textStyle.copyWith(
                  color: Colors.green,
                  decoration: TextDecoration.underline,
                ),
                trimMode: TrimMode.line,
                maxLines: 2,
                onTapLink: (url) {
                  ScaffoldMessenger.of(context).showSnackBar(
                    SnackBar(
                      content: Text(
                        """'$url' is displayed because we have used custom onTap function for hyperlinks""",
                      ),
                    ),
                  );
                },
                targetTextHighlights: TargetTextHighlights(targetHighlights: [
                  TargetTextHighlight(
                    priority: 1,
                    targetText: 'The',
                    style: TextStyle(
                      fontSize: 20.0,
                      fontStyle: FontStyle.italic,
                      color: Colors.blue[900],
                    ),
                  ),
                  TargetTextHighlight(
                      priority: 2,
                      targetText: 'he',
                      highlightInUrl: true,
                      style: const TextStyle(
                        fontSize: 20.0,
                        color: Colors.purple,
                      ),
                      onTap: (range) {
                        ScaffoldMessenger.of(context).showSnackBar(
                          SnackBar(
                            content: Text(
                                "'${range.textInside(inputData)}' is between the character no ${range.start} and ${range.end}"),
                          ),
                        );
                      }),
                ]),
              ),
              readMoreDelimiter: '+++',
              readLessDelimiter: ' ---',
              readMoreDelimiterStyle: textStyle.copyWith(color: Colors.black),
              readLessDelimiterStyle: textStyle.copyWith(color: Colors.black),
              style: textStyle.copyWith(color: Colors.grey),
              readMoreText: ' expand',
              readLessText: ' compress',
              readMoreTextStyle: textStyle.copyWith(color: Colors.blue),
              readLessTextStyle: textStyle.copyWith(color: Colors.pink),
            ),
            const SizedBox(height: 64),
          ],
        ),
      ),
    );
  }
}
37
likes
150
points
948
downloads

Publisher

unverified uploader

Weekly Downloads

A Flutter text widget which is expandable and can automatically parse urls present in the text it into clickable links.

Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (license)

Dependencies

flutter, url_launcher

More

Packages that depend on parsed_readmore