Merge branch 'master' into 'dev'

Master

See merge request Didvan/didvan-app!11
This commit is contained in:
MohammadTaha Basiri 2022-03-09 22:52:54 +00:00
commit cbdd407791
6 changed files with 21 additions and 148 deletions

View File

@ -3,11 +3,11 @@ name: app-test
spec: spec:
allow_http: false allow_http: false
disable_default_domains: true disable_default_domains: true
image: app-test:0.0.4 image: app:1.1.1
image_pull_policy: IfNotPresent image_pull_policy: IfNotPresent
path: / path: /
replicas: 1 replicas: 1
resources: resources:
memory: 50Mi memory: 150Mi
domains: domains:
- name: dev.didvan.app - name: web.didvan.app

View File

@ -1,6 +1,5 @@
import 'package:didvan/models/requests/news.dart'; import 'package:didvan/models/requests/news.dart';
import 'package:didvan/models/requests/radar.dart'; import 'package:didvan/models/requests/radar.dart';
import 'package:didvan/models/requests/studio.dart';
class RequestHelper { class RequestHelper {
static const String baseUrl = 'https://api.didvan.app'; static const String baseUrl = 'https://api.didvan.app';
@ -90,30 +89,6 @@ class RequestHelper {
MapEntry('search', args.search), MapEntry('search', args.search),
]); ]);
static String markStudioItem(int id) => _baseStudioUrl + '/$id/mark';
static String studioItemComments(int id) => _baseStudioUrl + '/$id/comments';
static String addStudioItemComment(int id) =>
_baseStudioUrl + '/$id/comments/add';
static String feedbackStudioItemComment(int radarId, int id) =>
_baseStudioUrl + '/$radarId/comments/$id/feedback';
static String studioItemDetails(int id, StudioRequestArgs args) =>
_baseStudioUrl +
'/$id' +
_urlConcatGenerator([
MapEntry('page', args.page.toString()),
MapEntry('search', args.search),
MapEntry('order', args.order),
MapEntry('type', args.type),
]);
static String studioItemOverviews({required StudioRequestArgs args}) =>
_baseStudioUrl +
_urlConcatGenerator([
MapEntry('page', args.page.toString()),
MapEntry('search', args.search),
MapEntry('order', args.order),
MapEntry('type', args.type),
]);
static String _urlConcatGenerator(List<MapEntry<String, String?>> additions) { static String _urlConcatGenerator(List<MapEntry<String, String?>> additions) {
String result = ''; String result = '';
additions.removeWhere((element) => element.value == null); additions.removeWhere((element) => element.value == null);

View File

@ -100,13 +100,15 @@ class _ProfileState extends State<Profile> {
email = value; email = value;
}, },
initialValue: state.user.email, initialValue: state.user.email,
validator: (value) async { validator: (value) {
if (value.isEmpty) return null;
bool emailValid = RegExp( bool emailValid = RegExp(
r"^[a-zA-Z0-9.a-zA-Z0-9.!#$%&'*+-/=?^_`{|}~]+@[a-zA-Z0-9]+\.[a-zA-Z]+") r"^[a-zA-Z0-9.a-zA-Z0-9.!#$%&'*+-/=?^_`{|}~]+@[a-zA-Z0-9]+\.[a-zA-Z]+")
.hasMatch(value); .hasMatch(value);
if (!emailValid) { if (!emailValid) {
return 'ایمیل وارد شده معتبر نمی‌باشد'; return 'ایمیل وارد شده معتبر نمی‌باشد';
} }
return null;
}, },
), ),
// const SizedBox(height: 16), // const SizedBox(height: 16),

View File

@ -1,130 +1,26 @@
import 'package:didvan/constants/app_icons.dart'; import 'package:didvan/config/theme_data.dart';
import 'package:didvan/models/view/action_sheet_data.dart'; import 'package:didvan/constants/assets.dart';
import 'package:didvan/utils/action_sheet.dart';
import 'package:didvan/views/home/studio/studio_state.dart';
import 'package:didvan/views/home/studio/widgets/slider.dart';
import 'package:didvan/views/home/studio/widgets/tab_bar.dart';
import 'package:didvan/views/home/widgets/logo_app_bar.dart'; import 'package:didvan/views/home/widgets/logo_app_bar.dart';
import 'package:didvan/views/home/widgets/search_field.dart'; import 'package:didvan/views/widgets/state_handlers/empty_state.dart';
import 'package:didvan/views/widgets/didvan/divider.dart';
import 'package:didvan/views/widgets/didvan/icon_button.dart';
import 'package:didvan/views/widgets/didvan/radial_button.dart';
import 'package:didvan/views/widgets/item_title.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
class Studio extends StatefulWidget { class Studio extends StatelessWidget {
const Studio({Key? key}) : super(key: key); const Studio({Key? key}) : super(key: key);
@override
State<Studio> createState() => _StudioState();
}
class _StudioState extends State<Studio> {
final FocusNode _focusNode = FocusNode();
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return CustomScrollView( return Column(
slivers: [
SliverToBoxAdapter(
child: Row(
children: [ children: [
const Expanded(child: LogoAppBar(type: 'studio')), const LogoAppBar(),
Padding( Expanded(
padding: child: EmptyState(
EdgeInsets.only(top: MediaQuery.of(context).padding.top), asset: Assets.emptyStudio,
child: DidvanIconButton( title: 'استودیو آینده',
icon: DidvanIcons.bookmark_regular, subtitle: 'به زودی...',
onPressed: () {}, titleColor: Theme.of(context).colorScheme.title,
), ),
), ),
], ],
),
),
const SliverToBoxAdapter(
child: StudioTabBar(),
),
SliverToBoxAdapter(
child: Padding(
padding: const EdgeInsets.all(16.0),
child: SearchField(
title: 'جستجو در استودیو',
onChanged: (value) {},
focusNode: _focusNode,
),
),
),
const SliverToBoxAdapter(
child: StudioSlider(),
),
const SliverPadding(
padding: EdgeInsets.symmetric(horizontal: 16),
sliver: SliverToBoxAdapter(
child: DidvanDivider(
verticalPadding: 0,
),
),
),
SliverPadding(
padding: const EdgeInsets.symmetric(horizontal: 16),
sliver: SliverToBoxAdapter(
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
const ItemTitle(title: 'تازه‌ترین‌ها'),
DidvanIconButton(
gestureSize: 36,
icon: DidvanIcons.sort_regular,
onPressed: _showSortDialog,
),
],
),
),
),
],
);
}
void _showSortDialog() {
final state = context.read<StudioState>();
ActionSheetUtils.showBottomSheet(
data: ActionSheetData(
content: StatefulBuilder(
builder: (context, setState) => Column(
children: [
DidvanRadialButton(
title: 'جدیدترین‌ها',
onSelected: () => setState(
() => state.selectedSortTypeIndex = 0,
),
value: state.selectedSortTypeIndex == 0,
),
const SizedBox(height: 24),
DidvanRadialButton(
title: 'پربازدیدترین‌ها',
onSelected: () => setState(
() => state.selectedSortTypeIndex = 1,
),
value: state.selectedSortTypeIndex == 1,
),
const SizedBox(height: 24),
DidvanRadialButton(
title: 'پربحث‌ترین‌ها',
onSelected: () => setState(
() => state.selectedSortTypeIndex = 2,
),
value: state.selectedSortTypeIndex == 2,
),
],
),
),
title: 'مرتب‌‌سازی',
titleIcon: DidvanIcons.sort_regular,
hasDismissButton: false,
confrimTitle: 'مرتب سازی',
onConfirmed: () {},
),
); );
} }
} }

View File

@ -18,7 +18,7 @@ class DidvanTextField extends StatefulWidget {
final dynamic initialValue; final dynamic initialValue;
final bool obsecureText; final bool obsecureText;
final bool acceptSpace; final bool acceptSpace;
final Function(String value)? validator; final String? Function(String value)? validator;
final TextInputType? textInputType; final TextInputType? textInputType;
const DidvanTextField({ const DidvanTextField({
Key? key, Key? key,

View File

@ -15,7 +15,7 @@ publish_to: 'none' # Remove this line if you wish to publish to pub.dev
# In iOS, build-name is used as CFBundleShortVersionString while build-number used as CFBundleVersion. # In iOS, build-name is used as CFBundleShortVersionString while build-number used as CFBundleVersion.
# Read more about iOS versioning at # Read more about iOS versioning at
# https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html # https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html
version: 1.0.5+5 version: 1.1.0+1
environment: environment:
sdk: ">=2.12.0 <3.0.0" sdk: ">=2.12.0 <3.0.0"